Paolo Bonzini | cb9c377 | 2012-12-06 12:15:58 +0100 | [diff] [blame] | 1 | #ifndef HW_NE2000_H |
| 2 | #define HW_NE2000_H 1 |
| 3 | |
Gerd Hoffmann | 9453c5b | 2009-09-10 11:43:33 +0200 | [diff] [blame] | 4 | #define NE2000_PMEM_SIZE (32*1024) |
| 5 | #define NE2000_PMEM_START (16*1024) |
| 6 | #define NE2000_PMEM_END (NE2000_PMEM_SIZE+NE2000_PMEM_START) |
| 7 | #define NE2000_MEM_SIZE NE2000_PMEM_END |
| 8 | |
| 9 | typedef struct NE2000State { |
Avi Kivity | 1ec4e1d | 2011-08-08 16:09:18 +0300 | [diff] [blame] | 10 | MemoryRegion io; |
Gerd Hoffmann | 9453c5b | 2009-09-10 11:43:33 +0200 | [diff] [blame] | 11 | uint8_t cmd; |
| 12 | uint32_t start; |
| 13 | uint32_t stop; |
| 14 | uint8_t boundary; |
| 15 | uint8_t tsr; |
| 16 | uint8_t tpsr; |
| 17 | uint16_t tcnt; |
| 18 | uint16_t rcnt; |
| 19 | uint32_t rsar; |
| 20 | uint8_t rsr; |
| 21 | uint8_t rxcr; |
| 22 | uint8_t isr; |
| 23 | uint8_t dcfg; |
| 24 | uint8_t imr; |
| 25 | uint8_t phys[6]; /* mac address */ |
| 26 | uint8_t curpag; |
| 27 | uint8_t mult[8]; /* multicast mask array */ |
| 28 | qemu_irq irq; |
Mark McLoughlin | 1c2045b | 2009-11-25 18:49:14 +0000 | [diff] [blame] | 29 | NICState *nic; |
Gerd Hoffmann | 93db668 | 2009-10-21 15:25:27 +0200 | [diff] [blame] | 30 | NICConf c; |
Gerd Hoffmann | 9453c5b | 2009-09-10 11:43:33 +0200 | [diff] [blame] | 31 | uint8_t mem[NE2000_MEM_SIZE]; |
| 32 | } NE2000State; |
| 33 | |
Paolo Bonzini | dcb117b | 2013-06-25 15:04:35 +0200 | [diff] [blame] | 34 | void ne2000_setup_io(NE2000State *s, DeviceState *dev, unsigned size); |
Juan Quintela | 7c131dd | 2009-10-19 18:26:11 +0200 | [diff] [blame] | 35 | extern const VMStateDescription vmstate_ne2000; |
Gerd Hoffmann | 9453c5b | 2009-09-10 11:43:33 +0200 | [diff] [blame] | 36 | void ne2000_reset(NE2000State *s); |
Stefan Hajnoczi | 35277d1 | 2012-07-24 16:35:14 +0100 | [diff] [blame] | 37 | ssize_t ne2000_receive(NetClientState *nc, const uint8_t *buf, size_t size_); |
Paolo Bonzini | cb9c377 | 2012-12-06 12:15:58 +0100 | [diff] [blame] | 38 | |
| 39 | #endif |