Revision: 44938
Initial Code
Initial URL
Initial Description
Initial Title
Initial Tags
Initial Language
at April 21, 2011 03:17 by TioSolid
Initial Code
/*
* Examples : Arduino Experiment Examples By....Thai Micro Tech
* Program : Hardware LED
* Hardware : Arduino 328 and ENC28J60
* : ET-MINI ENC28J60(Select VCC = +5V)
* : SDO -> MOSI(PB3) = Digital-11
* : SDI <- MISO(PB4) = Digital-12
* : SCK -> SCK(PB5) = Digital-13
* : CS# -> SS#(PB2) = Digital-10
* : LED -> Output Pin(PB1) = Digital-9
* Function : Webserver Control LED
*/
#include "etherShield.h"
#define ledPin 9 // LED Source Drive ("1" = ON , "0" = OFF)
#define ledPin2 8 // LED Source Drive ("1" = ON , "0" = OFF)
#define ledPin3 6 // LED Source Drive ("1" = ON , "0" = OFF)
#define ledPin4 5 // LED Source Drive ("1" = ON , "0" = OFF)
// please modify the following two lines. mac and ip have to be unique
// in your local area network. You can not have the same numbers in
// two devices:
static uint8_t mymac[6] = {0x54,0x55,0x58,0x10,0x00,0x24};
static uint8_t myip[4] = {192,168,1,201};
static char baseurl[] = "http://192.168.1.201/";
static uint16_t mywwwport = 80; // listen port for tcp/www (max range 1-254)
#define BUFFER_SIZE 500
static uint8_t buf[BUFFER_SIZE+1];
#define STR_BUFFER_SIZE 22
static char strbuf[STR_BUFFER_SIZE+1];
EtherShield es=EtherShield();
// prepare the webpage by writing the data to the tcp send buffer
uint16_t print_webpage(uint8_t *buf, byte led_status);
int8_t analyse_cmd(char *str);
void setup()
{
/*initialize enc28j60*/
es.ES_enc28j60Init(mymac);
es.ES_enc28j60clkout(2); // change clkout from 6.25MHz to 12.5MHz
delay(10);
/* Magjack leds configuration, see enc28j60 datasheet, page 11 */
// LEDA=greed LEDB=yellow
//
// 0x880 is PHLCON LEDB=on, LEDA=on
// enc28j60PhyWrite(PHLCON,0b0000 1000 1000 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x880);
delay(500);
//
// 0x990 is PHLCON LEDB=off, LEDA=off
// enc28j60PhyWrite(PHLCON,0b0000 1001 1001 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x990);
delay(500);
//
// 0x880 is PHLCON LEDB=on, LEDA=on
// enc28j60PhyWrite(PHLCON,0b0000 1000 1000 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x880);
delay(500);
//
// 0x990 is PHLCON LEDB=off, LEDA=off
// enc28j60PhyWrite(PHLCON,0b0000 1001 1001 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x990);
delay(500);
//
// 0x476 is PHLCON LEDA=links status, LEDB=receive/transmit
// enc28j60PhyWrite(PHLCON,0b0000 0100 0111 01 10);
es.ES_enc28j60PhyWrite(PHLCON,0x476);
delay(100);
//init the ethernet/ip layer:
es.ES_init_ip_arp_udp_tcp(mymac,myip,80);
pinMode(ledPin, OUTPUT);
digitalWrite(ledPin, LOW); // switch off LED
pinMode(ledPin2, OUTPUT);
digitalWrite(ledPin2, LOW); // switch off LED
pinMode(ledPin3, OUTPUT);
digitalWrite(ledPin3, LOW); // switch off LED
pinMode(ledPin4, OUTPUT);
digitalWrite(ledPin4, LOW); // switch off LED
}
void loop()
{
uint16_t plen, dat_p;
int8_t cmd;
int8_t cmd2;
int8_t cmd3;
int8_t cmd4;
static byte led_status = 0;
plen = es.ES_enc28j60PacketReceive(BUFFER_SIZE, buf);
/*plen will ne unequal to zero if there is a valid packet (without crc error) */
if(plen!=0)
{
// arp is broadcast if unknown but a host may also verify the mac address by sending it to a unicast address.
if(es.ES_eth_type_is_arp_and_my_ip(buf,plen))
{
es.ES_make_arp_answer_from_request(buf);
return;
}
// check if ip packets are for us:
if(es.ES_eth_type_is_ip_and_my_ip(buf,plen)==0)
{
return;
}
if(buf[IP_PROTO_P]==IP_PROTO_ICMP_V && buf[ICMP_TYPE_P]==ICMP_TYPE_ECHOREQUEST_V)
{
es.ES_make_echo_reply_from_request(buf,plen);
return;
}
// tcp port www start, compare only the lower byte
if (buf[IP_PROTO_P]==IP_PROTO_TCP_V&&buf[TCP_DST_PORT_H_P]==0&&buf[TCP_DST_PORT_L_P]==mywwwport)
{
if (buf[TCP_FLAGS_P] & TCP_FLAGS_SYN_V)
{
es.ES_make_tcp_synack_from_syn(buf); // make_tcp_synack_from_syn does already send the syn,ack
return;
}
if (buf[TCP_FLAGS_P] & TCP_FLAGS_ACK_V)
{
es.ES_init_len_info(buf); // init some data structures
dat_p=es.ES_get_tcp_data_pointer();
if (dat_p==0)
{ // we can possibly have no data, just ack:
if (buf[TCP_FLAGS_P] & TCP_FLAGS_FIN_V)
{
es.ES_make_tcp_ack_from_any(buf);
}
return;
}
if (strncmp("GET ",(char *)&(buf[dat_p]),4)!=0) // GET /?cmd=0, GET /?cmd=1
{
// head, post and other methods for possible status codes see:
// http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html
plen=es.ES_fill_tcp_data_p(buf,0,PSTR("HTTP/1.0 200 OK
Content-Type: text/html
<h1>200 OK</h1>"));
goto SENDTCP;
}
if (strncmp("/ ",(char *)&(buf[dat_p+4]),2)==0)
{
plen=print_webpage(buf, led_status);
goto SENDTCP;
}
cmd=analyse_cmd((char *)&(buf[dat_p+5]));
cmd2=analyse_cmd((char *)&(buf[dat_p+5]));
cmd3=analyse_cmd((char *)&(buf[dat_p+5]));
cmd4=analyse_cmd((char *)&(buf[dat_p+5]));
// 192.168.1.201/?led=0
if (cmd==0) // ?led=0 --> OFF
{
led_status = 0;
digitalWrite(ledPin, LOW); // LED = OFF
}
// 192.168.1.201/?led=1
else if (cmd==1) // ?led=1 --> ON
{
led_status = 1;
digitalWrite(ledPin, HIGH); // LED = ON
}
plen=print_webpage(buf, led_status);
SENDTCP:es.ES_make_tcp_ack_from_any(buf); // send ack for http get
es.ES_make_tcp_ack_with_data(buf,plen); // send data
}
}
}
}
// The returned value is stored in the global var strbuf
uint8_t find_key_val(char *str,char *key)
{
uint8_t found=0;
uint8_t i=0;
char *kp;
kp=key;
while(*str && *str!=' ' && found==0)
{
if (*str == *kp)
{
kp++;
if (*kp == '\0')
{
str++;
kp=key;
if (*str == '=')
{
found=1;
}
}
}
else
{
kp=key;
}
str++;
}
if (found==1)
{
// copy the value to a buffer and terminate it with '\0'
while(*str && *str!=' ' && *str!='&' && i<STR_BUFFER_SIZE)
{
strbuf[i]=*str;
i++;
str++;
}
strbuf[i]='\0';
}
return(found);
}
int8_t analyse_cmd(char *str)
{
int8_t r=-1;
if (find_key_val(str,"led"))
{
if (*strbuf < 0x3a && *strbuf > 0x2f) //'0'..'9'
{
// is a ASCII number, return it
r=(*strbuf-0x30); // Convert '0'..'9' to 0..9
}
}
return r;
}
uint16_t print_webpage(uint8_t *buf, byte on_off)
{
int i=0;
uint16_t plen;
// HTML Header
plen=es.ES_fill_tcp_data_p(buf,0,PSTR("HTTP/1.0 200 OK
Content-Type: text/html
"));
// HTML Body
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<center><p><h1>Thai Micro Tech Test Control</h1>"));
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<center><hr>"));
// Start of Form
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<br><form METHOD=get action=\""));
plen=es.ES_fill_tcp_data(buf,plen,baseurl);
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("\">"));
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<h2>Status</h2> "));
if(on_off==0)
{
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<h1><font color=\"#FF0000\"> "));
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("OFF"));
}
else if(on_off==1)
{
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<h1><font color=\"#00FF00\"> "));
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("ON"));
}
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("</font></h1><br>"));
if(on_off==0)
{
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=led value=1>"));
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"SW1 ON\">"));
}
else if(on_off==1)
{
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=led value=0>"));
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"SW1 OFF\">"));
}
// End of Form
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("</form>"));
plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("</center><hr> <p>Webserver Control By.Thai Micro Tech <a href=\"http://www.thaimicrotech.com\"> Thai Micro Tech <a>"));
return(plen);
}
Initial URL
http://code-all.blogspot.com/2011/01/arduino-ethernet-control-led.html
Initial Description
Initial Title
Arduino + ET-MINI ENC28J60
Initial Tags
Initial Language
C