Skip to content

Commit

Permalink
hw/net/lan9118: use qemu_configure_nic_device()
Browse files Browse the repository at this point in the history
Some callers instantiate the device unconditionally, others will do so only
if there is a NICInfo to go with it. This appears to be fairly random, but
preseve the existing behaviour for now.

Signed-off-by: David Woodhouse <dwmw@amazon.co.uk>
Reviewed-by: Thomas Huth <thuth@redhat.com>
  • Loading branch information
dwmw2 committed Feb 2, 2024
1 parent cd53991 commit f138ed5
Show file tree
Hide file tree
Showing 6 changed files with 10 additions and 13 deletions.
4 changes: 2 additions & 2 deletions hw/arm/kzm.c
Original file line number Diff line number Diff line change
Expand Up @@ -113,8 +113,8 @@ static void kzm_init(MachineState *machine)
alias_offset += ram[i].size;
}

if (nd_table[0].used) {
lan9118_init(&nd_table[0], KZM_LAN9118_ADDR,
if (qemu_find_nic_info("lan9118", true, NULL)) {
lan9118_init(KZM_LAN9118_ADDR,
qdev_get_gpio_in(DEVICE(&s->soc.avic), 52));
}

Expand Down
2 changes: 1 addition & 1 deletion hw/arm/mps2.c
Original file line number Diff line number Diff line change
Expand Up @@ -456,7 +456,7 @@ static void mps2_common_init(MachineState *machine)
/* In hardware this is a LAN9220; the LAN9118 is software compatible
* except that it doesn't support the checksum-offload feature.
*/
lan9118_init(&nd_table[0], mmc->ethernet_base,
lan9118_init(mmc->ethernet_base,
qdev_get_gpio_in(armv7m,
mmc->fpga_type == FPGA_AN511 ? 47 : 13));

Expand Down
6 changes: 2 additions & 4 deletions hw/arm/realview.c
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,6 @@ static void realview_init(MachineState *machine,
SysBusDevice *busdev;
qemu_irq pic[64];
PCIBus *pci_bus = NULL;
NICInfo *nd;
DriveInfo *dinfo;
I2CBus *i2c;
int n;
Expand Down Expand Up @@ -296,10 +295,9 @@ static void realview_init(MachineState *machine,
}
}

nd = qemu_find_nic_info(is_pb ? "lan9118" : "smc91c111", true, NULL);
if (nd) {
if (qemu_find_nic_info(is_pb ? "lan9118" : "smc91c111", true, NULL)) {
if (is_pb) {
lan9118_init(nd, 0x4e000000, pic[28]);
lan9118_init(0x4e000000, pic[28]);
} else {
smc91c111_init(0x4e000000, pic[28]);
}
Expand Down
4 changes: 2 additions & 2 deletions hw/arm/vexpress.c
Original file line number Diff line number Diff line change
Expand Up @@ -679,8 +679,8 @@ static void vexpress_common_init(MachineState *machine)
memory_region_add_subregion(sysmem, map[VE_VIDEORAM], &vms->vram);

/* 0x4e000000 LAN9118 Ethernet */
if (nd_table[0].used) {
lan9118_init(&nd_table[0], map[VE_ETHERNET], pic[15]);
if (qemu_find_nic_info("lan9118", true, NULL)) {
lan9118_init(map[VE_ETHERNET], pic[15]);
}

/* VE_USB: not modelled */
Expand Down
5 changes: 2 additions & 3 deletions hw/net/lan9118.c
Original file line number Diff line number Diff line change
Expand Up @@ -1408,14 +1408,13 @@ static void lan9118_register_types(void)

/* Legacy helper function. Should go away when machine config files are
implemented. */
void lan9118_init(NICInfo *nd, uint32_t base, qemu_irq irq)
void lan9118_init(uint32_t base, qemu_irq irq)
{
DeviceState *dev;
SysBusDevice *s;

qemu_check_nic_model(nd, "lan9118");
dev = qdev_new(TYPE_LAN9118);
qdev_set_nic_properties(dev, nd);
qemu_configure_nic_device(dev, true, NULL);
s = SYS_BUS_DEVICE(dev);
sysbus_realize_and_unref(s, &error_fatal);
sysbus_mmio_map(s, 0, base);
Expand Down
2 changes: 1 addition & 1 deletion include/hw/net/lan9118.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,6 @@

#define TYPE_LAN9118 "lan9118"

void lan9118_init(NICInfo *, uint32_t, qemu_irq);
void lan9118_init(uint32_t, qemu_irq);

#endif

0 comments on commit f138ed5

Please sign in to comment.