mirror of
https://github.com/m-labs/artiq.git
synced 2024-12-24 10:54:02 +08:00
soc/runtime: add lwip (thanks Florent)
This commit is contained in:
parent
c1ece33e6d
commit
91cd79a8a3
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
[submodule "soc/runtime/lwip"]
|
||||
path = soc/runtime/lwip
|
||||
url = git://git.savannah.nongnu.org/lwip.git
|
56
soc/runtime/liblwip/Makefile
Normal file
56
soc/runtime/liblwip/Makefile
Normal file
@ -0,0 +1,56 @@
|
||||
include $(MSCDIR)/software/common.mak
|
||||
|
||||
LWIPDIR=../lwip/src
|
||||
|
||||
CFLAGS += $(CPPFLAGS) -I. \
|
||||
-I$(LWIPDIR)/include \
|
||||
-I$(LWIPDIR)/include/ipv4
|
||||
|
||||
# COREFILES, CORE4FILES: The minimum set of files needed for lwIP.
|
||||
COREOBJS=$(LWIPDIR)/core/mem.o \
|
||||
$(LWIPDIR)/core/memp.o \
|
||||
$(LWIPDIR)/core/netif.o \
|
||||
$(LWIPDIR)/core/pbuf.o \
|
||||
$(LWIPDIR)/core/raw.o \
|
||||
$(LWIPDIR)/core/stats.o \
|
||||
$(LWIPDIR)/core/sys.o \
|
||||
$(LWIPDIR)/core/tcp.o \
|
||||
$(LWIPDIR)/core/tcp_in.o \
|
||||
$(LWIPDIR)/core/tcp_out.o \
|
||||
$(LWIPDIR)/core/udp.o \
|
||||
$(LWIPDIR)/core/dhcp.o \
|
||||
$(LWIPDIR)/core/inet_chksum.o \
|
||||
$(LWIPDIR)/core/timers.o \
|
||||
$(LWIPDIR)/core/init.o
|
||||
|
||||
CORE4OBJS=$(LWIPDIR)/core/ipv4/icmp.o \
|
||||
$(LWIPDIR)/core/ipv4/ip4.o \
|
||||
$(LWIPDIR)/core/ipv4/ip4_addr.o \
|
||||
$(LWIPDIR)/core/ipv4/ip_frag.o
|
||||
|
||||
# NETIFOBJS: Files implementing various generic network interface functions.
|
||||
NETIFOBJS=$(LWIPDIR)/netif/etharp.o \
|
||||
netif/liteethif.o
|
||||
|
||||
# NETIFOBJS: All the above.
|
||||
LWIPOBJS=$(COREOBJS) $(CORE4OBJS) $(NETIFOBJS)
|
||||
OBJS_LIB+=$(LWIPOBJS)
|
||||
|
||||
LWIPLIB=liblwip.a
|
||||
|
||||
all: $(LWIPLIB)
|
||||
|
||||
.PHONY: all compile clean
|
||||
|
||||
%.o: %.c
|
||||
$(compile-dep)
|
||||
|
||||
%.o: %.S
|
||||
$(assemble)
|
||||
|
||||
clean:
|
||||
rm -f $(LWIPOBJS) $(LWIPOBJS:.o=.d) $(LWIPLIB)
|
||||
|
||||
liblwip.a: $(LWIPOBJS)
|
||||
$(AR) clr liblwip.a $(LWIPOBJS)
|
||||
$(RANLIB) liblwip.a
|
60
soc/runtime/liblwip/arch/cc.h
Normal file
60
soc/runtime/liblwip/arch/cc.h
Normal file
@ -0,0 +1,60 @@
|
||||
// This file is Copyright (c) 2015 Florent Kermarrec <florent@enjoy-digital.fr>
|
||||
// LiteETH lwIP port for ARTIQ
|
||||
// License: BSD
|
||||
|
||||
#ifndef __ARCH_CC_H__
|
||||
#define __ARCH_CC_H__
|
||||
|
||||
/* Include some files for defining library routines */
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
#define BYTE_ORDER BIG_ENDIAN
|
||||
|
||||
/* Define generic types */
|
||||
typedef unsigned char u8_t;
|
||||
typedef signed char s8_t;
|
||||
typedef unsigned short u16_t;
|
||||
typedef signed short s16_t;
|
||||
typedef unsigned long u32_t;
|
||||
typedef signed long s32_t;
|
||||
|
||||
typedef u32_t mem_ptr_t;
|
||||
|
||||
/* Define (sn)printf formatters for these types */
|
||||
#define U8_F "c"
|
||||
#define S8_F "c"
|
||||
#define X8_F "x"
|
||||
#define U16_F "u"
|
||||
#define S16_F "d"
|
||||
#define X16_F "x"
|
||||
#define U32_F "u"
|
||||
#define S32_F "d"
|
||||
#define X32_F "x"
|
||||
|
||||
/* Compiler hints for packing structures */
|
||||
#define PACK_STRUCT_FIELD(x) x
|
||||
#define PACK_STRUCT_STRUCT __attribute__((packed))
|
||||
#define PACK_STRUCT_BEGIN
|
||||
#define PACK_STRUCT_END
|
||||
|
||||
/* prototypes for printf() and abort() */
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include "console.h"
|
||||
#define pp_printf printf
|
||||
|
||||
/* Definitions for ASSERT/DIAG */
|
||||
#ifdef LWIP_NOASSERT
|
||||
#define LWIP_PLATFORM_ASSERT(x)
|
||||
#else
|
||||
#define LWIP_PLATFORM_ASSERT(x) do {pp_printf("Assertion \"%s\" failed at line %d in %s\n", \
|
||||
x, __LINE__, __FILE__); } while(0)
|
||||
#endif
|
||||
|
||||
#ifdef LWIP_DEBUG
|
||||
#define LWIP_PLATFORM_DIAG(x) do {pp_printf x;} while(0)
|
||||
#endif
|
||||
|
||||
#endif /* __ARCH_CC_H__ */
|
11
soc/runtime/liblwip/arch/perf.h
Normal file
11
soc/runtime/liblwip/arch/perf.h
Normal file
@ -0,0 +1,11 @@
|
||||
// This file is Copyright (c) 2015 Florent Kermarrec <florent@enjoy-digital.fr>
|
||||
// LiteETH lwIP port for ARTIQ
|
||||
// License: BSD
|
||||
|
||||
#ifndef __ARCH_PERF_H__
|
||||
#define __ARCH_PERF_H__
|
||||
|
||||
#define PERF_START /* null definition */
|
||||
#define PERF_STOP(x) /* null definition */
|
||||
|
||||
#endif /* __ARCH_PERF_H__ */
|
20
soc/runtime/liblwip/arch/sys_arch.h
Normal file
20
soc/runtime/liblwip/arch/sys_arch.h
Normal file
@ -0,0 +1,20 @@
|
||||
// This file is Copyright (c) 2015 Florent Kermarrec <florent@enjoy-digital.fr>
|
||||
// LiteETH lwIP port for ARTIQ
|
||||
// License: BSD
|
||||
|
||||
#ifndef __ARCH_SYS_ARCH_H__
|
||||
#define __ARCH_SYS_ARCH_H__
|
||||
|
||||
#define SYS_MBOX_NULL NULL
|
||||
#define SYS_SEM_NULL NULL
|
||||
|
||||
typedef void * sys_prot_t;
|
||||
|
||||
typedef void * sys_sem_t;
|
||||
|
||||
typedef void * sys_mbox_t;
|
||||
|
||||
typedef void * sys_thread_t;
|
||||
|
||||
#endif /* __ARCH_SYS_ARCH_H__ */
|
||||
|
213
soc/runtime/liblwip/lwipopts.h
Normal file
213
soc/runtime/liblwip/lwipopts.h
Normal file
@ -0,0 +1,213 @@
|
||||
// This file is Copyright (c) 2015 Florent Kermarrec <florent@enjoy-digital.fr>
|
||||
// LiteETH lwIP port for ARTIQ
|
||||
// License: BSD
|
||||
|
||||
#ifndef __LWIPOPTS_H__
|
||||
#define __LWIPOPTS_H__
|
||||
|
||||
//#define LWIP_DEBUG
|
||||
#include <lwip/debug.h>
|
||||
|
||||
/*----------------------------General options ------------------------------ */
|
||||
#define NO_SYS 1
|
||||
#define LWIP_NETCONN 0
|
||||
#define LWIP_SOCKET 0
|
||||
#define LWIP_IPV6 0
|
||||
|
||||
/* ------------------------ Memory options -------------------------------- */
|
||||
/* MEM_ALIGNMENT: should be set to the alignment of the CPU for which
|
||||
lwIP is compiled. 4 byte alignment -> define MEM_ALIGNMENT to 4, 2
|
||||
byte alignment -> define MEM_ALIGNMENT to 2. */
|
||||
#define MEM_ALIGNMENT 4 /* MUST BE 4 */
|
||||
|
||||
/* MEM_SIZE: the size of the heap memory. If the application will send
|
||||
a lot of data that needs to be copied, this should be set high. */
|
||||
#define MEM_SIZE 16000
|
||||
|
||||
/* MEMP_NUM_PBUF: the number of memp struct pbufs. If the application
|
||||
sends a lot of data out of ROM (or other static memory), this
|
||||
should be set high. */
|
||||
#define MEMP_NUM_PBUF 20
|
||||
/* MEMP_NUM_UDP_PCB: the number of UDP protocol control blocks. One
|
||||
per active UDP "connection". */
|
||||
#define MEMP_NUM_UDP_PCB 4
|
||||
/* MEMP_NUM_TCP_PCB: the number of simulatenously active TCP
|
||||
connections. */
|
||||
#define MEMP_NUM_TCP_PCB 10
|
||||
/* MEMP_NUM_TCP_PCB_LISTEN: the number of listening TCP
|
||||
connections. */
|
||||
#define MEMP_NUM_TCP_PCB_LISTEN 8
|
||||
/* MEMP_NUM_TCP_SEG: the number of simultaneously queued TCP
|
||||
segments. */
|
||||
#define MEMP_NUM_TCP_SEG 8
|
||||
/* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active
|
||||
timeouts. */
|
||||
#define MEMP_NUM_SYS_TIMEOUT 3
|
||||
|
||||
/* The following four are used only with the sequential API and can be
|
||||
set to 0 if the application only will use the raw API. */
|
||||
/* MEMP_NUM_NETBUF: the number of struct netbufs. */
|
||||
//#define MEMP_NUM_NETBUF 4
|
||||
/* MEMP_NUM_NETCONN: the number of struct netconns. */
|
||||
//#define MEMP_NUM_NETCONN 4
|
||||
|
||||
/* These two control is reclaimer functions should be compiled
|
||||
in. Should always be turned on (1). */
|
||||
#define MEM_RECLAIM 1
|
||||
#define MEMP_RECLAIM 1
|
||||
|
||||
/* ---------- Pbuf options ---------- */
|
||||
/* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */
|
||||
#define PBUF_POOL_SIZE 4
|
||||
|
||||
/* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */
|
||||
#define PBUF_POOL_BUFSIZE 1024
|
||||
|
||||
/* PBUF_LINK_HLEN: the number of bytes that should be allocated for a
|
||||
link level header. */
|
||||
#define PBUF_LINK_HLEN 16
|
||||
|
||||
/* ------------------------ TCP options ----------------------------------- */
|
||||
#define LWIP_TCP 1
|
||||
#define TCP_TTL 255
|
||||
|
||||
/* Controls if TCP should queue segments that arrive out of
|
||||
order. Define to 0 if your device is low on memory. */
|
||||
#define TCP_QUEUE_OOSEQ 1
|
||||
|
||||
/* TCP Maximum segment size. */
|
||||
#define TCP_MSS 256
|
||||
|
||||
/* TCP sender buffer space (bytes). */
|
||||
#define TCP_SND_BUF 512
|
||||
|
||||
/* TCP sender buffer space (pbufs). This must be at least = 2 *
|
||||
TCP_SND_BUF/TCP_MSS for things to work. */
|
||||
#define TCP_SND_QUEUELEN 4 * TCP_SND_BUF/TCP_MSS
|
||||
|
||||
/* TCP receive window. */
|
||||
#define TCP_WND 256
|
||||
|
||||
/* Maximum number of retransmissions of data segments. */
|
||||
#define TCP_MAXRTX 12
|
||||
|
||||
/* Maximum number of retransmissions of SYN segments. */
|
||||
#define TCP_SYNMAXRTX 4
|
||||
|
||||
/* ------------------------ ARP options ----------------------------------- */
|
||||
#define LWIP_ARP 1
|
||||
#define ARP_TABLE_SIZE 10
|
||||
#define ARP_QUEUEING 1
|
||||
|
||||
/* ------------------------ IP options ------------------------------------ */
|
||||
/* Define IP_FORWARD to 1 if you wish to have the ability to forward
|
||||
IP packets across network interfaces. If you are going to run lwIP
|
||||
on a device with only one network interface, define this to 0. */
|
||||
#define IP_FORWARD 0
|
||||
|
||||
/* If defined to 1, IP options are allowed (but not parsed). If
|
||||
defined to 0, all packets with IP options are dropped. */
|
||||
#define IP_OPTIONS 0 /* set it to 1 to allow IP options in hdr */
|
||||
#define IP_REASSEMBLY 0 /* set it to 1 to enable tcp/ip reassembly */
|
||||
#define IP_FRAG 0 /* Outgoing fragmentation of IP packets occurs
|
||||
* when the packet-size exceeds the path maximum
|
||||
* packet-size (path MTU). To avoid fragmentation,
|
||||
* don't allow application OR lwIP to generate packets larger
|
||||
* than anticipated path maximum transmission unit.
|
||||
*
|
||||
* For TCP, setting TCP_MSS to much less than anticipated
|
||||
* path MTU avoids frag/defrag. For UDP it depends on app
|
||||
* and path MTU. For ping (ICMP), with large payload,
|
||||
* frag/reass is required. Some network stacks have
|
||||
* path MTU discovery capability but not sure if LwIP
|
||||
* supports it
|
||||
*/
|
||||
#define LWIP_RAW 1 /* set it to 1 to enable raw support */
|
||||
|
||||
/* ------------------------ ICMP options ---------------------------------- */
|
||||
#define ICMP_TTL 255
|
||||
|
||||
/* ------------------------ DHCP options ---------------------------------- */
|
||||
/* Define LWIP_DHCP to 1 if you want DHCP configuration of
|
||||
interfaces. DHCP is not implemented in lwIP 0.5.1, however, so
|
||||
turning this on does currently not work. */
|
||||
#define LWIP_DHCP 0
|
||||
|
||||
/* 1 if you want to do an ARP check on the offered address
|
||||
(recommended). */
|
||||
//#define DHCP_DOES_ARP_CHECK 1
|
||||
|
||||
/* ------------------------ UDP options ----------------------------------- */
|
||||
#define LWIP_UDP 1 /* set it to 1 to enable UDP */
|
||||
#define UDP_TTL 255 /* time to live for udp */
|
||||
#define CHECKSUM_GEN_UDP 0 /* don't generate UDP chksum, if UDP enabled*/
|
||||
#define CHECKSUM_CHECK_UDP 0 /* check chksum in rx UDP pkts if enabled */
|
||||
|
||||
#define LWIP_STATS 0
|
||||
#define LWIP_COMPAT_SOCKETS 0
|
||||
|
||||
/* Override the default dynamic memory alloc functions (malloc copy)*/
|
||||
//#include "memmgr.h"
|
||||
|
||||
//#define mem_init()
|
||||
//#define mem_free memmgr_free
|
||||
//#define mem_malloc memmgr_alloc
|
||||
//#define mem_calloc(c, n) memmgr_alloc((c) * (n))
|
||||
//#define mem_realloc(p, sz) (p)
|
||||
|
||||
#ifdef LWIP_DEBUG
|
||||
/*
|
||||
* for a list of options for the flags, please refer to
|
||||
* lwip/src/include/lwip/debug.h
|
||||
******************NOTE********************************
|
||||
*
|
||||
* TO TURN OFF A SPECIFIC DEBUG SOURCE, SET THE VALUE TO
|
||||
* DBG_OFF
|
||||
*
|
||||
* DO NOT MODIFY DBG_TYPES_ON OR DBG_MIN_LEVEL UNLESS YOU
|
||||
* ARE AWARE WHAT YOU'RE DOING!!
|
||||
*
|
||||
*/
|
||||
#define LWIP_DBG_TYPES_ON LWIP_DBG_ON
|
||||
#define DBG_TYPES_ON LWIP_DBG_TRACE
|
||||
|
||||
#define LWIP_DBG_MIN_LEVEL LWIP_DBG_LEVEL_ALL
|
||||
#define ETHARP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define NETIF_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define PBUF_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define API_LIB_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define API_MSG_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define SOCKETS_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define ICMP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define INET_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define IP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define IP_REASS_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define RAW_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define MEM_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define MEMP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define SYS_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_INPUT_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_FR_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_RTO_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_CWND_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_WND_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_OUTPUT_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_RST_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCP_QLEN_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define UDP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TCPIP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define PPP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define SLIP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define DHCP_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
#define TIMERS_DEBUG LWIP_DBG_ON|LWIP_DBG_TRACE
|
||||
|
||||
/* APPLICATION DEBUGGING */
|
||||
/* #define HTTPD_DEBUG (1) */
|
||||
#endif
|
||||
|
||||
|
||||
/* Perform DHCP */
|
||||
/*#define LWIP_DHCP (1)*/
|
||||
|
||||
#endif /* __LWIPOPTS_H__ */
|
137
soc/runtime/liblwip/netif/liteethif.c
Normal file
137
soc/runtime/liblwip/netif/liteethif.c
Normal file
@ -0,0 +1,137 @@
|
||||
// This file is Copyright (c) 2015 Florent Kermarrec <florent@enjoy-digital.fr>
|
||||
// LiteETH lwIP port for ARTIQ
|
||||
// License: BSD
|
||||
|
||||
#include <lwip/opt.h>
|
||||
#include <lwip/mem.h>
|
||||
|
||||
#include <netif/etharp.h>
|
||||
#include "netif/liteethif.h"
|
||||
|
||||
#include <generated/csr.h>
|
||||
#include <hw/flags.h>
|
||||
#include <hw/ethmac_mem.h>
|
||||
|
||||
typedef union {
|
||||
unsigned char raw[1514];
|
||||
} ethernet_buffer;
|
||||
|
||||
static unsigned int rxslot;
|
||||
static unsigned int rxlen;
|
||||
static ethernet_buffer *rxbuffer;
|
||||
static ethernet_buffer *rxbuffer0;
|
||||
static ethernet_buffer *rxbuffer1;
|
||||
static unsigned int txslot;
|
||||
static unsigned int txlen;
|
||||
static ethernet_buffer *txbuffer;
|
||||
static ethernet_buffer *txbuffer0;
|
||||
static ethernet_buffer *txbuffer1;
|
||||
|
||||
#define IFNAME0 'e'
|
||||
#define IFNAME1 't'
|
||||
|
||||
static void liteeth_low_level_init(struct netif *netif)
|
||||
{
|
||||
int i;
|
||||
|
||||
netif->hwaddr_len = 6;
|
||||
for(i=0;i<netif->hwaddr_len;i++)
|
||||
netif->hwaddr[i] = macadr[i];
|
||||
netif->mtu = 1514;
|
||||
netif->flags = NETIF_FLAG_BROADCAST | NETIF_FLAG_ETHARP;
|
||||
|
||||
ethmac_sram_reader_ev_pending_write(ETHMAC_EV_SRAM_READER);
|
||||
ethmac_sram_writer_ev_pending_write(ETHMAC_EV_SRAM_WRITER);
|
||||
|
||||
rxbuffer0 = (ethernet_buffer *)ETHMAC_RX0_BASE;
|
||||
rxbuffer1 = (ethernet_buffer *)ETHMAC_RX1_BASE;
|
||||
txbuffer0 = (ethernet_buffer *)ETHMAC_TX0_BASE;
|
||||
txbuffer1 = (ethernet_buffer *)ETHMAC_TX1_BASE;
|
||||
|
||||
rxslot = 0;
|
||||
txslot = 0;
|
||||
|
||||
rxbuffer = rxbuffer0;
|
||||
txbuffer = txbuffer0;
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
static err_t liteeth_low_level_output(struct netif *netif, struct pbuf *p)
|
||||
{
|
||||
struct pbuf *q;
|
||||
|
||||
txlen = 0;
|
||||
for(q = p; q != NULL; q = q->next) {
|
||||
memcpy(txbuffer->raw, q->payload, q->len);
|
||||
txbuffer += q->len;
|
||||
txlen += q->len;
|
||||
}
|
||||
|
||||
ethmac_sram_reader_slot_write(txslot);
|
||||
ethmac_sram_reader_length_write(txlen);
|
||||
while(!(ethmac_sram_reader_ready_read()));
|
||||
ethmac_sram_reader_start_write(1);
|
||||
|
||||
txslot = (txslot+1)%2;
|
||||
if (txslot)
|
||||
txbuffer = txbuffer1;
|
||||
else
|
||||
txbuffer = txbuffer0;
|
||||
|
||||
return ERR_OK;
|
||||
}
|
||||
|
||||
static struct pbuf * liteeth_low_level_input(struct netif *netif)
|
||||
{
|
||||
struct pbuf *p, *q;
|
||||
|
||||
rxslot = ethmac_sram_writer_slot_read();
|
||||
rxlen = ethmac_sram_writer_length_read();
|
||||
if (rxslot)
|
||||
rxbuffer = rxbuffer1;
|
||||
else
|
||||
rxbuffer = rxbuffer0;
|
||||
|
||||
p = pbuf_alloc(PBUF_RAW, rxlen, PBUF_POOL);
|
||||
if (p != NULL) {
|
||||
for(q = p; q != NULL; q = q->next) {
|
||||
memcpy(q->payload, rxbuffer->raw, q->len);
|
||||
rxbuffer += q->len;
|
||||
}
|
||||
}
|
||||
|
||||
return p;
|
||||
}
|
||||
|
||||
void liteeth_input(struct netif *netif)
|
||||
{
|
||||
struct pbuf *p;
|
||||
p = liteeth_low_level_input(netif);
|
||||
if (p != NULL) {
|
||||
netif->input(p, netif);
|
||||
}
|
||||
}
|
||||
|
||||
err_t liteeth_init(struct netif *netif)
|
||||
{
|
||||
struct liteethif *liteethif;
|
||||
|
||||
liteethif = mem_malloc(sizeof(struct liteethif));
|
||||
if (liteethif == NULL)
|
||||
return ERR_MEM;
|
||||
netif->state = liteethif;
|
||||
|
||||
netif->hwaddr_len = 6;
|
||||
netif->name[0] = IFNAME0;
|
||||
netif->name[1] = IFNAME1;
|
||||
netif->output = etharp_output;
|
||||
netif->linkoutput = liteeth_low_level_output;
|
||||
netif->mtu = 1514;
|
||||
|
||||
liteethif->ethaddr = (struct eth_addr *)&(netif->hwaddr[0]);
|
||||
|
||||
liteeth_low_level_init(netif);
|
||||
|
||||
return ERR_OK;
|
||||
}
|
17
soc/runtime/liblwip/netif/liteethif.h
Normal file
17
soc/runtime/liblwip/netif/liteethif.h
Normal file
@ -0,0 +1,17 @@
|
||||
// This file is Copyright (c) 2015 Florent Kermarrec <florent@enjoy-digital.fr>
|
||||
// LiteETH lwIP port for ARTIQ
|
||||
// License: BSD
|
||||
|
||||
#ifndef __LITEETHIF_H__
|
||||
#define __LITEETHIF_H__
|
||||
|
||||
extern unsigned char macadr[];
|
||||
|
||||
struct liteethif {
|
||||
struct eth_addr *ethaddr;
|
||||
};
|
||||
|
||||
void liteeth_input(struct netif *netif);
|
||||
err_t liteeth_init(struct netif *netif);
|
||||
|
||||
#endif /* __LITEETH_IF_H__ */
|
1
soc/runtime/lwip
Submodule
1
soc/runtime/lwip
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit caf9fc568715b82587ed9698658fdcd40c6c0a9d
|
Loading…
Reference in New Issue
Block a user