]>
Commit | Line | Data |
---|---|---|
cb9c377f | 1 | #ifndef HW_NE2000_H |
175de524 | 2 | #define HW_NE2000_H |
cb9c377f | 3 | |
872a2b7c | 4 | #include "qemu/units.h" |
489983d6 PMD |
5 | #include "net/net.h" |
6 | ||
872a2b7c PMD |
7 | #define NE2000_PMEM_SIZE (32 * KiB) |
8 | #define NE2000_PMEM_START (16 * KiB) | |
9453c5bc GH |
9 | #define NE2000_PMEM_END (NE2000_PMEM_SIZE+NE2000_PMEM_START) |
10 | #define NE2000_MEM_SIZE NE2000_PMEM_END | |
11 | ||
12 | typedef struct NE2000State { | |
1ec4e1dd | 13 | MemoryRegion io; |
9453c5bc GH |
14 | uint8_t cmd; |
15 | uint32_t start; | |
16 | uint32_t stop; | |
17 | uint8_t boundary; | |
18 | uint8_t tsr; | |
19 | uint8_t tpsr; | |
20 | uint16_t tcnt; | |
21 | uint16_t rcnt; | |
22 | uint32_t rsar; | |
23 | uint8_t rsr; | |
24 | uint8_t rxcr; | |
25 | uint8_t isr; | |
26 | uint8_t dcfg; | |
27 | uint8_t imr; | |
28 | uint8_t phys[6]; /* mac address */ | |
29 | uint8_t curpag; | |
30 | uint8_t mult[8]; /* multicast mask array */ | |
31 | qemu_irq irq; | |
1c2045b5 | 32 | NICState *nic; |
93db6685 | 33 | NICConf c; |
9453c5bc GH |
34 | uint8_t mem[NE2000_MEM_SIZE]; |
35 | } NE2000State; | |
36 | ||
dcb117bf | 37 | void ne2000_setup_io(NE2000State *s, DeviceState *dev, unsigned size); |
7c131dd5 | 38 | extern const VMStateDescription vmstate_ne2000; |
9453c5bc | 39 | void ne2000_reset(NE2000State *s); |
35277d14 | 40 | ssize_t ne2000_receive(NetClientState *nc, const uint8_t *buf, size_t size_); |
cb9c377f PB |
41 | |
42 | #endif |