riscv/sifive_u: Add a serial property to the sifive_u machine
commit3ca109c3f8d6225efdfa801252d25f3e526b004a
authorBin Meng <bmeng.cn@gmail.com>
Sat, 16 Nov 2019 15:08:50 +0000 (16 07:08 -0800)
committerAlistair Francis <alistair.francis@wdc.com>
Wed, 29 Apr 2020 20:16:36 +0000 (29 13:16 -0700)
tree320c5925140884bfa01a8f00eee99fff7aca407a
parentfda5b000faf401cf595c4e87809eac3378ddbfd4
riscv/sifive_u: Add a serial property to the sifive_u machine

At present the board serial number is hard-coded to 1, and passed
to OTP model during initialization. Firmware (FSBL, U-Boot) uses
the serial number to generate a unique MAC address for the on-chip
ethernet controller. When multiple QEMU 'sifive_u' instances are
created and connected to the same subnet, they all have the same
MAC address hence it creates a unusable network.

A new "serial" property is introduced to specify the board serial
number. When not given, the default serial number 1 is used.

Signed-off-by: Bin Meng <bmeng.cn@gmail.com>
Reviewed-by: Palmer Dabbelt <palmerdabbelt@google.com>
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
Message-Id: <1573916930-19068-1-git-send-email-bmeng.cn@gmail.com>
[ Changed by AF:
 - Use the SoC's serial property to pass the info to the SoC
 - Fixup commit title
 - Rebase on file restructuring
]
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
hw/riscv/sifive_u.c
include/hw/riscv/sifive_u.h