123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- #include "lwip_dm9k.h"
- #include "dm9k.h"
- #include "ethernetif_dm9k.h"
- #include "lwip/tcpip.h"
- #include "lwip_init.h"
- #include "malloc.h"
- #include "memory_manager.h"
- struct netif dm9k_netif = {0};
- #define DM9K_TASK_PRIO 10
- #define DM9K_TASK_STK_SIZE 512
- CPU_STK dm9k_task_stk[DM9K_TASK_STK_SIZE];
- static void ethernet_link_status_updated(struct netif *netif);
- void lwip_dm9k_default_ip_set(__lwip_dev *lwipx)
- {
-
- lwipx->remoteip[0] = 192;
- lwipx->remoteip[1] = 168;
- lwipx->remoteip[2] = 1;
- lwipx->remoteip[3] = 10;
-
- lwipx->mac[0] = 2;
- lwipx->mac[1] = 0;
- lwipx->mac[2] = 0;
- lwipx->mac[3] = 0x90;
- lwipx->mac[4] = 0x00;
- lwipx->mac[5] = 0xae;
-
- lwipx->ip[0] = 192;
- lwipx->ip[1] = 168;
- lwipx->ip[2] = 1;
- lwipx->ip[3] = 40;
-
- lwipx->netmask[0] = 255;
- lwipx->netmask[1] = 255;
- lwipx->netmask[2] = 255;
- lwipx->netmask[3] = 0;
-
- lwipx->gateway[0] = 192;
- lwipx->gateway[1] = 168;
- lwipx->gateway[2] = 1;
- lwipx->gateway[3] = 1;
- lwipx->dhcpstatus = 0;
- }
- void ethernet_dm9k_link_thread(void const *argument)
- {
- struct netif *netif = (struct netif *)(argument);
- for (;;)
- {
- ethernet_link_check_state(netif);
- OSTimeDly(2000);
- }
- }
- void lwip_dm9k_init(void)
- {
- ip4_addr_t ipaddr;
- ip4_addr_t netmask;
- ip4_addr_t gw;
- lwip_dm9k_default_ip_set(&dm9kdev);
- dm9k_init();
- #ifdef USE_DHCP
- ip_addr_set_zero_ip4(&ipaddr);
- ip_addr_set_zero_ip4(&netmask);
- ip_addr_set_zero_ip4(&gw);
- #else
- IP4_ADDR(&ipaddr, dm9kdev.ip[0], dm9kdev.ip[1], dm9kdev.ip[2], dm9kdev.ip[3]);
- IP4_ADDR(&netmask, dm9kdev.netmask[0], dm9kdev.netmask[1], dm9kdev.netmask[2], dm9kdev.netmask[3]);
- IP4_ADDR(&gw, dm9kdev.gateway[0], dm9kdev.gateway[1], dm9kdev.gateway[2], dm9kdev.gateway[3]);
- #endif
- netif_add(&dm9k_netif, &ipaddr, &netmask, &gw, NULL, ðernetif_dm9k_init, &tcpip_input);
- netif_set_default(&dm9k_netif);
-
- #if LWIP_NETIF_LINK_CALLBACK
- netif_set_link_callback(&dm9k_netif, ethernet_link_status_updated);
- #endif
- OSTaskCreateExt((void (*)(void *))ethernet_dm9k_link_thread,
- (void const *)&dm9k_netif,
- (OS_STK *)&dm9k_task_stk[DM9K_TASK_STK_SIZE - 1],
- (INT8U)DM9K_TASK_PRIO,
- (INT16U)DM9K_TASK_PRIO,
- (OS_STK *)&dm9k_task_stk[0],
- (INT32U)DM9K_TASK_STK_SIZE,
- (void *)0,
- (INT16U)OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR | OS_TASK_OPT_SAVE_FP);
-
-
-
-
-
- }
- static void ethernet_link_status_updated(struct netif *netif)
- {
- #if LWIP_DHCP
- if (DHCPSemaphore == NULL)
- {
- osSemaphoreDef(ETH_SEM);
- DHCPSemaphore = osSemaphoreCreate(osSemaphore(ETH_SEM), 1);
- }
- #else
- ip_addr_t ipaddr;
- ip_addr_t netmask;
- ip_addr_t gw;
- #endif
- if (netif_is_link_up(netif))
- {
- #if LWIP_DHCP
-
- dm9kdev.dhcpstatus = DHCP_START;
- osSemaphoreRelease(DHCPSemaphore);
- #else
- IP4_ADDR(&ipaddr, dm9kdev.ip[0], dm9kdev.ip[1], dm9kdev.ip[2], dm9kdev.ip[3]);
- IP4_ADDR(&netmask, dm9kdev.netmask[0], dm9kdev.netmask[1], dm9kdev.netmask[2], dm9kdev.netmask[3]);
- IP4_ADDR(&gw, dm9kdev.gateway[0], dm9kdev.gateway[1], dm9kdev.gateway[2], dm9kdev.gateway[3]);
- dm9kdev.dhcpstatus = DHCP_ADDRESS_ASSIGNED;
- #endif
- }
- else
- {
- #if LWIP_DHCP
-
- osSemaphoreRelease(DHCPSemaphore);
- #endif
- dm9kdev.dhcpstatus = DHCP_LINK_DOWN;
- }
- }
|