Darran Shepherd / Mbed 2 deprecated Bonjour

Dependencies:   mbed

Committer:
darran
Date:
Fri Jun 18 09:11:35 2010 +0000
Revision:
0:55a05330f8cc

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
darran 0:55a05330f8cc 1
darran 0:55a05330f8cc 2 /*
darran 0:55a05330f8cc 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
darran 0:55a05330f8cc 4
darran 0:55a05330f8cc 5 Permission is hereby granted, free of charge, to any person obtaining a copy
darran 0:55a05330f8cc 6 of this software and associated documentation files (the "Software"), to deal
darran 0:55a05330f8cc 7 in the Software without restriction, including without limitation the rights
darran 0:55a05330f8cc 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
darran 0:55a05330f8cc 9 copies of the Software, and to permit persons to whom the Software is
darran 0:55a05330f8cc 10 furnished to do so, subject to the following conditions:
darran 0:55a05330f8cc 11
darran 0:55a05330f8cc 12 The above copyright notice and this permission notice shall be included in
darran 0:55a05330f8cc 13 all copies or substantial portions of the Software.
darran 0:55a05330f8cc 14
darran 0:55a05330f8cc 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
darran 0:55a05330f8cc 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
darran 0:55a05330f8cc 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
darran 0:55a05330f8cc 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
darran 0:55a05330f8cc 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
darran 0:55a05330f8cc 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
darran 0:55a05330f8cc 21 THE SOFTWARE.
darran 0:55a05330f8cc 22 */
darran 0:55a05330f8cc 23
darran 0:55a05330f8cc 24 #include "netCfg.h"
darran 0:55a05330f8cc 25 #if NET_ETH
darran 0:55a05330f8cc 26
darran 0:55a05330f8cc 27 #include "mbed.h"
darran 0:55a05330f8cc 28
darran 0:55a05330f8cc 29 Ethernet *pEth = NULL;
darran 0:55a05330f8cc 30 #ifdef __cplusplus
darran 0:55a05330f8cc 31 extern "C" {
darran 0:55a05330f8cc 32 #endif
darran 0:55a05330f8cc 33
darran 0:55a05330f8cc 34 #include "lwip/opt.h"
darran 0:55a05330f8cc 35
darran 0:55a05330f8cc 36 #include "lwip/def.h"
darran 0:55a05330f8cc 37 #include "lwip/pbuf.h"
darran 0:55a05330f8cc 38 #include "lwip/sys.h"
darran 0:55a05330f8cc 39 #include "lwip/stats.h"
darran 0:55a05330f8cc 40 #include "netif/etharp.h"
darran 0:55a05330f8cc 41 #include "string.h"
darran 0:55a05330f8cc 42
darran 0:55a05330f8cc 43 //#include "eth_drv.h"
darran 0:55a05330f8cc 44
darran 0:55a05330f8cc 45 #define IFNAME0 'E'
darran 0:55a05330f8cc 46 #define IFNAME1 'X'
darran 0:55a05330f8cc 47
darran 0:55a05330f8cc 48 #define min(x,y) (((x)<(y))?(x):(y))
darran 0:55a05330f8cc 49
darran 0:55a05330f8cc 50 struct netif* eth_netif;
darran 0:55a05330f8cc 51
darran 0:55a05330f8cc 52 static err_t eth_output(struct netif *netif, struct pbuf *p) {
darran 0:55a05330f8cc 53 #if ETH_PAD_SIZE
darran 0:55a05330f8cc 54 pbuf_header(p, -ETH_PAD_SIZE); /* drop the padding word */
darran 0:55a05330f8cc 55 #endif
darran 0:55a05330f8cc 56
darran 0:55a05330f8cc 57 do {
darran 0:55a05330f8cc 58 pEth->write((const char *)p->payload, p->len);
darran 0:55a05330f8cc 59 } while((p = p->next)!=NULL);
darran 0:55a05330f8cc 60
darran 0:55a05330f8cc 61 pEth->send();
darran 0:55a05330f8cc 62
darran 0:55a05330f8cc 63 #if ETH_PAD_SIZE
darran 0:55a05330f8cc 64 pbuf_header(p, ETH_PAD_SIZE); /* reclaim the padding word */
darran 0:55a05330f8cc 65 #endif
darran 0:55a05330f8cc 66
darran 0:55a05330f8cc 67 LINK_STATS_INC(link.xmit);
darran 0:55a05330f8cc 68 return ERR_OK;
darran 0:55a05330f8cc 69 }
darran 0:55a05330f8cc 70
darran 0:55a05330f8cc 71 /*
darran 0:55a05330f8cc 72 void show(char *buf, int size) {
darran 0:55a05330f8cc 73 printf("Destination: %02hx:%02hx:%02hx:%02hx:%02hx:%02hx\n",
darran 0:55a05330f8cc 74 buf[0], buf[1], buf[2], buf[3], buf[4], buf[5]);
darran 0:55a05330f8cc 75 printf("Source: %02hx:%02hx:%02hx:%02hx:%02hx:%02hx\n",
darran 0:55a05330f8cc 76 buf[6], buf[7], buf[8], buf[9], buf[10], buf[11]);
darran 0:55a05330f8cc 77
darran 0:55a05330f8cc 78 printf("Type %hd\n", htons((short)buf[12]));
darran 0:55a05330f8cc 79
darran 0:55a05330f8cc 80 // hexview(buf, size);
darran 0:55a05330f8cc 81 }
darran 0:55a05330f8cc 82 */
darran 0:55a05330f8cc 83
darran 0:55a05330f8cc 84 void eth_poll() {
darran 0:55a05330f8cc 85 struct eth_hdr *ethhdr;
darran 0:55a05330f8cc 86 struct pbuf *frame, *p;
darran 0:55a05330f8cc 87 int len, read;
darran 0:55a05330f8cc 88
darran 0:55a05330f8cc 89 while((len = pEth->receive()) != 0) {
darran 0:55a05330f8cc 90 frame = pbuf_alloc(PBUF_RAW, len, PBUF_POOL);
darran 0:55a05330f8cc 91 if(frame == NULL) {
darran 0:55a05330f8cc 92 return;
darran 0:55a05330f8cc 93 }
darran 0:55a05330f8cc 94 p = frame;
darran 0:55a05330f8cc 95 /* no packet could be read, silently ignore this */
darran 0:55a05330f8cc 96 if (p == NULL) return;
darran 0:55a05330f8cc 97 do {
darran 0:55a05330f8cc 98 read = pEth->read((char *)p->payload, p->len);
darran 0:55a05330f8cc 99 p = p->next;
darran 0:55a05330f8cc 100 } while(p != NULL && read != 0);
darran 0:55a05330f8cc 101
darran 0:55a05330f8cc 102 #if ETH_PAD_SIZE
darran 0:55a05330f8cc 103 pbuf_header(p, ETH_PAD_SIZE);
darran 0:55a05330f8cc 104 #endif
darran 0:55a05330f8cc 105
darran 0:55a05330f8cc 106 ethhdr = (struct eth_hdr *)(frame->payload);
darran 0:55a05330f8cc 107
darran 0:55a05330f8cc 108 // show((char*)ethhdr, 13);
darran 0:55a05330f8cc 109
darran 0:55a05330f8cc 110 /*
darran 0:55a05330f8cc 111 switch(htons(ethhdr->type)) {
darran 0:55a05330f8cc 112
darran 0:55a05330f8cc 113 case ETHTYPE_IP:
darran 0:55a05330f8cc 114 etharp_ip_input(gnetif, frame);
darran 0:55a05330f8cc 115 pbuf_header(frame, -((s16_t) sizeof(struct eth_hdr)));
darran 0:55a05330f8cc 116 gnetif->input(frame, gnetif);
darran 0:55a05330f8cc 117 break;
darran 0:55a05330f8cc 118
darran 0:55a05330f8cc 119 case ETHTYPE_ARP:
darran 0:55a05330f8cc 120 etharp_arp_input(gnetif, (struct eth_addr *)(gnetif->hwaddr), frame);
darran 0:55a05330f8cc 121 break;
darran 0:55a05330f8cc 122
darran 0:55a05330f8cc 123 default:
darran 0:55a05330f8cc 124 break;
darran 0:55a05330f8cc 125 }*/
darran 0:55a05330f8cc 126
darran 0:55a05330f8cc 127
darran 0:55a05330f8cc 128
darran 0:55a05330f8cc 129 //ethernet_input(frame, gnetif);
darran 0:55a05330f8cc 130
darran 0:55a05330f8cc 131 switch (htons(ethhdr->type)) {
darran 0:55a05330f8cc 132 /* IP or ARP packet? */
darran 0:55a05330f8cc 133 case ETHTYPE_IP:
darran 0:55a05330f8cc 134 case ETHTYPE_ARP:
darran 0:55a05330f8cc 135 #if PPPOE_SUPPORT
darran 0:55a05330f8cc 136 /* PPPoE packet? */
darran 0:55a05330f8cc 137 case ETHTYPE_PPPOEDISC:
darran 0:55a05330f8cc 138 case ETHTYPE_PPPOE:
darran 0:55a05330f8cc 139 #endif /* PPPOE_SUPPORT */
darran 0:55a05330f8cc 140 /* full packet send to tcpip_thread to process */
darran 0:55a05330f8cc 141 //if (netif->input(p, gnetif)!=ERR_OK)
darran 0:55a05330f8cc 142 if (ethernet_input(frame, eth_netif)!=ERR_OK)
darran 0:55a05330f8cc 143 { LWIP_DEBUGF(NETIF_DEBUG, ("ethernetif_input: IP input error\n"));
darran 0:55a05330f8cc 144 pbuf_free(frame);
darran 0:55a05330f8cc 145 frame = NULL;
darran 0:55a05330f8cc 146 }
darran 0:55a05330f8cc 147 break;
darran 0:55a05330f8cc 148
darran 0:55a05330f8cc 149 default:
darran 0:55a05330f8cc 150 pbuf_free(frame);
darran 0:55a05330f8cc 151 frame = NULL;
darran 0:55a05330f8cc 152 break;
darran 0:55a05330f8cc 153 }
darran 0:55a05330f8cc 154
darran 0:55a05330f8cc 155 /* pbuf_free(frame); */
darran 0:55a05330f8cc 156 }
darran 0:55a05330f8cc 157
darran 0:55a05330f8cc 158
darran 0:55a05330f8cc 159
darran 0:55a05330f8cc 160
darran 0:55a05330f8cc 161 }
darran 0:55a05330f8cc 162
darran 0:55a05330f8cc 163 err_t eth_init(struct netif *netif) {
darran 0:55a05330f8cc 164 LWIP_ASSERT("netif != NULL", (netif != NULL));
darran 0:55a05330f8cc 165
darran 0:55a05330f8cc 166 NETIF_INIT_SNMP(netif, snmp_ifType_ethernet_csmacd, 0x2EA);
darran 0:55a05330f8cc 167
darran 0:55a05330f8cc 168 /* maximum transfer unit */
darran 0:55a05330f8cc 169 netif->mtu = 0x2EA;
darran 0:55a05330f8cc 170
darran 0:55a05330f8cc 171 /* device capabilities */
darran 0:55a05330f8cc 172 /* don't set NETIF_FLAG_ETHARP if this device is not an ethernet one */
darran 0:55a05330f8cc 173 netif->flags = NETIF_FLAG_BROADCAST | NETIF_FLAG_ETHARP | NETIF_FLAG_LINK_UP;
darran 0:55a05330f8cc 174
darran 0:55a05330f8cc 175 netif->state = NULL;
darran 0:55a05330f8cc 176 eth_netif = netif;
darran 0:55a05330f8cc 177
darran 0:55a05330f8cc 178 netif->name[0] = IFNAME0;
darran 0:55a05330f8cc 179 netif->name[1] = IFNAME1;
darran 0:55a05330f8cc 180
darran 0:55a05330f8cc 181 /* We directly use etharp_output() here to save a function call.
darran 0:55a05330f8cc 182 * You can instead declare your own function an call etharp_output()
darran 0:55a05330f8cc 183 * from it if you have to do some checks before sending (e.g. if link
darran 0:55a05330f8cc 184 * is available...) */
darran 0:55a05330f8cc 185 netif->output = etharp_output;
darran 0:55a05330f8cc 186 netif->linkoutput = eth_output;
darran 0:55a05330f8cc 187
darran 0:55a05330f8cc 188 pEth = new Ethernet();
darran 0:55a05330f8cc 189
darran 0:55a05330f8cc 190 return ERR_OK;
darran 0:55a05330f8cc 191 }
darran 0:55a05330f8cc 192
darran 0:55a05330f8cc 193 void eth_free()
darran 0:55a05330f8cc 194 {
darran 0:55a05330f8cc 195 if(pEth)
darran 0:55a05330f8cc 196 delete pEth;
darran 0:55a05330f8cc 197 pEth = NULL;
darran 0:55a05330f8cc 198 }
darran 0:55a05330f8cc 199
darran 0:55a05330f8cc 200 void eth_address(char* mac) {
darran 0:55a05330f8cc 201 pEth->address(mac);
darran 0:55a05330f8cc 202 }
darran 0:55a05330f8cc 203
darran 0:55a05330f8cc 204 #ifdef __cplusplus
darran 0:55a05330f8cc 205 };
darran 0:55a05330f8cc 206 #endif
darran 0:55a05330f8cc 207
darran 0:55a05330f8cc 208 #endif