/* * QEMU NS SONIC DP8393x netcard * * Copyright (c) 2008-2009 Herve Poussineau * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, see . */ #ifndef HW_NET_DP8393X_H #define HW_NET_DP8393X_H #include "hw/sysbus.h" #include "net/net.h" #include "exec/memory.h" #define SONIC_REG_COUNT 0x40 #define TYPE_DP8393X "dp8393x" OBJECT_DECLARE_SIMPLE_TYPE(dp8393xState, DP8393X) struct dp8393xState { SysBusDevice parent_obj; /* Hardware */ uint8_t it_shift; bool big_endian; bool last_rba_is_full; qemu_irq irq; int irq_level; QEMUTimer *watchdog; int64_t wt_last_update; NICConf conf; NICState *nic; MemoryRegion mmio; /* Registers */ uint16_t cam[16][3]; uint16_t regs[SONIC_REG_COUNT]; /* Temporaries */ uint8_t tx_buffer[0x10000]; int loopback_packet; /* Memory access */ MemoryRegion *dma_mr; AddressSpace as; }; #endif