forked from M-Labs/artiq
soc/runtime: add lwip (thanks Florent)
This commit is contained in:
parent
c1ece33e6d
commit
91cd79a8a3
|
@ -0,0 +1,3 @@
|
||||||
|
[submodule "soc/runtime/lwip"]
|
||||||
|
path = soc/runtime/lwip
|
||||||
|
url = git://git.savannah.nongnu.org/lwip.git
|
|
@ -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
|
|
@ -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__ */
|
|
@ -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__ */
|
|
@ -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__ */
|
||||||
|
|
|
@ -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__ */
|
|
@ -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;
|
||||||
|
}
|
|
@ -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__ */
|
|
@ -0,0 +1 @@
|
||||||
|
Subproject commit caf9fc568715b82587ed9698658fdcd40c6c0a9d
|
Loading…
Reference in New Issue