mirror of
https://github.com/arduino/Arduino.git
synced 2025-01-11 00:52:21 +01:00
a642f0a15d
The switch from checking _sock against a default value, combined with the checking for unconnected clients in status(), broke the Client. I went back to checking the value of _sock against the default and removed the _connected member altogether because it was redundant (and therefore needed to be kept in sync with _sock).
37 lines
845 B
C++
37 lines
845 B
C++
#include "w5100.h"
|
|
#include "Ethernet.h"
|
|
|
|
// XXX: don't make assumptions about the value of MAX_SOCK_NUM.
|
|
uint8_t EthernetClass::_state[MAX_SOCK_NUM] = {
|
|
0, 0, 0, 0 };
|
|
uint16_t EthernetClass::_server_port[MAX_SOCK_NUM] = {
|
|
0, 0, 0, 0 };
|
|
|
|
void EthernetClass::begin(uint8_t *mac, uint8_t *ip)
|
|
{
|
|
uint8_t gateway[4];
|
|
gateway[0] = ip[0];
|
|
gateway[1] = ip[1];
|
|
gateway[2] = ip[2];
|
|
gateway[3] = 1;
|
|
begin(mac, ip, gateway);
|
|
}
|
|
|
|
void EthernetClass::begin(uint8_t *mac, uint8_t *ip, uint8_t *gateway)
|
|
{
|
|
uint8_t subnet[] = {
|
|
255, 255, 255, 0 };
|
|
begin(mac, ip, gateway, subnet);
|
|
}
|
|
|
|
void EthernetClass::begin(uint8_t *mac, uint8_t *ip, uint8_t *gateway, uint8_t *subnet)
|
|
{
|
|
W5100.init();
|
|
W5100.setMACAddress(mac);
|
|
W5100.setIPAddress(ip);
|
|
W5100.setGatewayIp(gateway);
|
|
W5100.setSubnetMask(subnet);
|
|
}
|
|
|
|
EthernetClass Ethernet;
|