Re: [PATCH v3] ppc/amigaone: Allow running AmigaOS without firmware image

2023-11-30 Thread BALATON Zoltan

On Thu, 30 Nov 2023, Nicholas Piggin wrote:

On Thu Nov 30, 2023 at 8:49 AM AEST, BALATON Zoltan wrote:

On Tue, 28 Nov 2023, Cédric Le Goater wrote:

On 11/28/23 02:32, BALATON Zoltan wrote:

The machine uses a modified U-Boot under GPL license but the sources
of it are lost with only a binary available so it cannot be included
in QEMU. Allow running without the firmware image which can be used
when calling a boot loader directly and thus simplifying booting
guests. We need a small routine that AmigaOS calls from ROM which is
added in this case to allow booting AmigaOS without external firmware
image.

Signed-off-by: BALATON Zoltan 


Since this is 8.2 material :


Fixes: d9656f860a38 ("hw/ppc: Add emulation of AmigaOne XE board")


This has missed rc2 but I hope there still will be a pull request before
rc3 which is the last chance now. I've sent a v4 which simpilifies the


Sigh, yes a few hiccups but I will send a PR with your v3 and a SLOF
update.


inserted code as I've found there's no need to do it like in the rom as
the only place it's called from just cares about the result.

I forgot the Fixes tag again, sorry, but the one above is still the same.


That's okay I added it. I'll just keep v3 since I have done some
tests with it. If it matches the the old rom then it seems like
a good starting point anyway, can always patch it later.


The only change is the code in it so it should not change any test results 
but v3 could work too, it just now seems unnecessary to include that much 
code when the short version is the same. Anyway, eiher v3 or v4 is OK.


Regards,
BALATON Zoltan

Re: [PATCH v3] ppc/amigaone: Allow running AmigaOS without firmware image

2023-11-30 Thread Nicholas Piggin
On Thu Nov 30, 2023 at 8:49 AM AEST, BALATON Zoltan wrote:
> On Tue, 28 Nov 2023, Cédric Le Goater wrote:
> > On 11/28/23 02:32, BALATON Zoltan wrote:
> >> The machine uses a modified U-Boot under GPL license but the sources
> >> of it are lost with only a binary available so it cannot be included
> >> in QEMU. Allow running without the firmware image which can be used
> >> when calling a boot loader directly and thus simplifying booting
> >> guests. We need a small routine that AmigaOS calls from ROM which is
> >> added in this case to allow booting AmigaOS without external firmware
> >> image.
> >> 
> >> Signed-off-by: BALATON Zoltan 
> >
> > Since this is 8.2 material :
> >
> >
> > Fixes: d9656f860a38 ("hw/ppc: Add emulation of AmigaOne XE board")
>
> This has missed rc2 but I hope there still will be a pull request before 
> rc3 which is the last chance now. I've sent a v4 which simpilifies the 

Sigh, yes a few hiccups but I will send a PR with your v3 and a SLOF
update.

> inserted code as I've found there's no need to do it like in the rom as 
> the only place it's called from just cares about the result.
>
> I forgot the Fixes tag again, sorry, but the one above is still the same.

That's okay I added it. I'll just keep v3 since I have done some
tests with it. If it matches the the old rom then it seems like
a good starting point anyway, can always patch it later.

Thanks,
Nick



Re: [PATCH v3] ppc/amigaone: Allow running AmigaOS without firmware image

2023-11-29 Thread BALATON Zoltan

On Tue, 28 Nov 2023, Cédric Le Goater wrote:

On 11/28/23 02:32, BALATON Zoltan wrote:

The machine uses a modified U-Boot under GPL license but the sources
of it are lost with only a binary available so it cannot be included
in QEMU. Allow running without the firmware image which can be used
when calling a boot loader directly and thus simplifying booting
guests. We need a small routine that AmigaOS calls from ROM which is
added in this case to allow booting AmigaOS without external firmware
image.

Signed-off-by: BALATON Zoltan 


Since this is 8.2 material :


Fixes: d9656f860a38 ("hw/ppc: Add emulation of AmigaOne XE board")


This has missed rc2 but I hope there still will be a pull request before 
rc3 which is the last chance now. I've sent a v4 which simpilifies the 
inserted code as I've found there's no need to do it like in the rom as 
the only place it's called from just cares about the result.


I forgot the Fixes tag again, sorry, but the one above is still the same.

Regards,
BALATON Zoltan




Thanks,

C.




---
v3: Instead of -bios none do this when no -bios option given, use
constants for address and rom_add_blob_fixed() to add dummy_fw.
This makes both code and usage a bit simpler.

  hw/ppc/amigaone.c | 35 +++
  1 file changed, 23 insertions(+), 12 deletions(-)

diff --git a/hw/ppc/amigaone.c b/hw/ppc/amigaone.c
index 992a55e632..ddfa09457a 100644
--- a/hw/ppc/amigaone.c
+++ b/hw/ppc/amigaone.c
@@ -36,10 +36,19 @@
   * -device VGA,romfile=VGABIOS-lgpl-latest.bin
   * from http://www.nongnu.org/vgabios/ instead.
   */
-#define PROM_FILENAME "u-boot-amigaone.bin"
  #define PROM_ADDR 0xfff0
  #define PROM_SIZE (512 * KiB)
  +/* AmigaOS calls this routine from ROM, use this if no firmware loaded 
*/

+static const char dummy_fw[] = {
+0x38, 0x00, 0x00, 0x08, /* li  r0,8 */
+0x7c, 0x09, 0x03, 0xa6, /* mtctr   r0 */
+0x54, 0x63, 0xf8, 0x7e, /* srwir3,r3,1 */
+0x42, 0x00, 0xff, 0xfc, /* bdnz0x8 */
+0x7c, 0x63, 0x18, 0xf8, /* not r3,r3 */
+0x4e, 0x80, 0x00, 0x20, /* blr */
+};
+
  static void amigaone_cpu_reset(void *opaque)
  {
  PowerPCCPU *cpu = opaque;
@@ -60,8 +69,6 @@ static void amigaone_init(MachineState *machine)
  PowerPCCPU *cpu;
  CPUPPCState *env;
  MemoryRegion *rom, *pci_mem, *mr;
-const char *fwname = machine->firmware ?: PROM_FILENAME;
-char *filename;
  ssize_t sz;
  PCIBus *pci_bus;
  Object *via;
@@ -94,20 +101,24 @@ static void amigaone_init(MachineState *machine)
  }
/* allocate and load firmware */
-filename = qemu_find_file(QEMU_FILE_TYPE_BIOS, fwname);
-if (filename) {
-rom = g_new(MemoryRegion, 1);
-memory_region_init_rom(rom, NULL, "rom", PROM_SIZE, _fatal);
-memory_region_add_subregion(get_system_memory(), PROM_ADDR, rom);
+rom = g_new(MemoryRegion, 1);
+memory_region_init_rom(rom, NULL, "rom", PROM_SIZE, _fatal);
+memory_region_add_subregion(get_system_memory(), PROM_ADDR, rom);
+if (!machine->firmware) {
+rom_add_blob_fixed("dummy-fw", dummy_fw, sizeof(dummy_fw),
+   PROM_ADDR + PROM_SIZE - 0x80);
+} else {
+g_autofree char *filename = qemu_find_file(QEMU_FILE_TYPE_BIOS,
+   machine->firmware);
+if (!filename) {
+error_report("Could not find firmware '%s'", 
machine->firmware);

+exit(1);
+}
  sz = load_image_targphys(filename, PROM_ADDR, PROM_SIZE);
  if (sz <= 0 || sz > PROM_SIZE) {
  error_report("Could not load firmware '%s'", filename);
  exit(1);
  }
-g_free(filename);
-} else if (!qtest_enabled()) {
-error_report("Could not find firmware '%s'", fwname);
-exit(1);
  }
/* Articia S */





Re: [PATCH v3] ppc/amigaone: Allow running AmigaOS without firmware image

2023-11-28 Thread Cédric Le Goater

On 11/28/23 02:32, BALATON Zoltan wrote:

The machine uses a modified U-Boot under GPL license but the sources
of it are lost with only a binary available so it cannot be included
in QEMU. Allow running without the firmware image which can be used
when calling a boot loader directly and thus simplifying booting
guests. We need a small routine that AmigaOS calls from ROM which is
added in this case to allow booting AmigaOS without external firmware
image.

Signed-off-by: BALATON Zoltan 


Since this is 8.2 material :


Fixes: d9656f860a38 ("hw/ppc: Add emulation of AmigaOne XE board")


Thanks,

C.




---
v3: Instead of -bios none do this when no -bios option given, use
constants for address and rom_add_blob_fixed() to add dummy_fw.
This makes both code and usage a bit simpler.

  hw/ppc/amigaone.c | 35 +++
  1 file changed, 23 insertions(+), 12 deletions(-)

diff --git a/hw/ppc/amigaone.c b/hw/ppc/amigaone.c
index 992a55e632..ddfa09457a 100644
--- a/hw/ppc/amigaone.c
+++ b/hw/ppc/amigaone.c
@@ -36,10 +36,19 @@
   * -device VGA,romfile=VGABIOS-lgpl-latest.bin
   * from http://www.nongnu.org/vgabios/ instead.
   */
-#define PROM_FILENAME "u-boot-amigaone.bin"
  #define PROM_ADDR 0xfff0
  #define PROM_SIZE (512 * KiB)
  
+/* AmigaOS calls this routine from ROM, use this if no firmware loaded */

+static const char dummy_fw[] = {
+0x38, 0x00, 0x00, 0x08, /* li  r0,8 */
+0x7c, 0x09, 0x03, 0xa6, /* mtctr   r0 */
+0x54, 0x63, 0xf8, 0x7e, /* srwir3,r3,1 */
+0x42, 0x00, 0xff, 0xfc, /* bdnz0x8 */
+0x7c, 0x63, 0x18, 0xf8, /* not r3,r3 */
+0x4e, 0x80, 0x00, 0x20, /* blr */
+};
+
  static void amigaone_cpu_reset(void *opaque)
  {
  PowerPCCPU *cpu = opaque;
@@ -60,8 +69,6 @@ static void amigaone_init(MachineState *machine)
  PowerPCCPU *cpu;
  CPUPPCState *env;
  MemoryRegion *rom, *pci_mem, *mr;
-const char *fwname = machine->firmware ?: PROM_FILENAME;
-char *filename;
  ssize_t sz;
  PCIBus *pci_bus;
  Object *via;
@@ -94,20 +101,24 @@ static void amigaone_init(MachineState *machine)
  }
  
  /* allocate and load firmware */

-filename = qemu_find_file(QEMU_FILE_TYPE_BIOS, fwname);
-if (filename) {
-rom = g_new(MemoryRegion, 1);
-memory_region_init_rom(rom, NULL, "rom", PROM_SIZE, _fatal);
-memory_region_add_subregion(get_system_memory(), PROM_ADDR, rom);
+rom = g_new(MemoryRegion, 1);
+memory_region_init_rom(rom, NULL, "rom", PROM_SIZE, _fatal);
+memory_region_add_subregion(get_system_memory(), PROM_ADDR, rom);
+if (!machine->firmware) {
+rom_add_blob_fixed("dummy-fw", dummy_fw, sizeof(dummy_fw),
+   PROM_ADDR + PROM_SIZE - 0x80);
+} else {
+g_autofree char *filename = qemu_find_file(QEMU_FILE_TYPE_BIOS,
+   machine->firmware);
+if (!filename) {
+error_report("Could not find firmware '%s'", machine->firmware);
+exit(1);
+}
  sz = load_image_targphys(filename, PROM_ADDR, PROM_SIZE);
  if (sz <= 0 || sz > PROM_SIZE) {
  error_report("Could not load firmware '%s'", filename);
  exit(1);
  }
-g_free(filename);
-} else if (!qtest_enabled()) {
-error_report("Could not find firmware '%s'", fwname);
-exit(1);
  }
  
  /* Articia S */





[PATCH v3] ppc/amigaone: Allow running AmigaOS without firmware image

2023-11-27 Thread BALATON Zoltan
The machine uses a modified U-Boot under GPL license but the sources
of it are lost with only a binary available so it cannot be included
in QEMU. Allow running without the firmware image which can be used
when calling a boot loader directly and thus simplifying booting
guests. We need a small routine that AmigaOS calls from ROM which is
added in this case to allow booting AmigaOS without external firmware
image.

Signed-off-by: BALATON Zoltan 
---
v3: Instead of -bios none do this when no -bios option given, use
constants for address and rom_add_blob_fixed() to add dummy_fw.
This makes both code and usage a bit simpler.

 hw/ppc/amigaone.c | 35 +++
 1 file changed, 23 insertions(+), 12 deletions(-)

diff --git a/hw/ppc/amigaone.c b/hw/ppc/amigaone.c
index 992a55e632..ddfa09457a 100644
--- a/hw/ppc/amigaone.c
+++ b/hw/ppc/amigaone.c
@@ -36,10 +36,19 @@
  * -device VGA,romfile=VGABIOS-lgpl-latest.bin
  * from http://www.nongnu.org/vgabios/ instead.
  */
-#define PROM_FILENAME "u-boot-amigaone.bin"
 #define PROM_ADDR 0xfff0
 #define PROM_SIZE (512 * KiB)
 
+/* AmigaOS calls this routine from ROM, use this if no firmware loaded */
+static const char dummy_fw[] = {
+0x38, 0x00, 0x00, 0x08, /* li  r0,8 */
+0x7c, 0x09, 0x03, 0xa6, /* mtctr   r0 */
+0x54, 0x63, 0xf8, 0x7e, /* srwir3,r3,1 */
+0x42, 0x00, 0xff, 0xfc, /* bdnz0x8 */
+0x7c, 0x63, 0x18, 0xf8, /* not r3,r3 */
+0x4e, 0x80, 0x00, 0x20, /* blr */
+};
+
 static void amigaone_cpu_reset(void *opaque)
 {
 PowerPCCPU *cpu = opaque;
@@ -60,8 +69,6 @@ static void amigaone_init(MachineState *machine)
 PowerPCCPU *cpu;
 CPUPPCState *env;
 MemoryRegion *rom, *pci_mem, *mr;
-const char *fwname = machine->firmware ?: PROM_FILENAME;
-char *filename;
 ssize_t sz;
 PCIBus *pci_bus;
 Object *via;
@@ -94,20 +101,24 @@ static void amigaone_init(MachineState *machine)
 }
 
 /* allocate and load firmware */
-filename = qemu_find_file(QEMU_FILE_TYPE_BIOS, fwname);
-if (filename) {
-rom = g_new(MemoryRegion, 1);
-memory_region_init_rom(rom, NULL, "rom", PROM_SIZE, _fatal);
-memory_region_add_subregion(get_system_memory(), PROM_ADDR, rom);
+rom = g_new(MemoryRegion, 1);
+memory_region_init_rom(rom, NULL, "rom", PROM_SIZE, _fatal);
+memory_region_add_subregion(get_system_memory(), PROM_ADDR, rom);
+if (!machine->firmware) {
+rom_add_blob_fixed("dummy-fw", dummy_fw, sizeof(dummy_fw),
+   PROM_ADDR + PROM_SIZE - 0x80);
+} else {
+g_autofree char *filename = qemu_find_file(QEMU_FILE_TYPE_BIOS,
+   machine->firmware);
+if (!filename) {
+error_report("Could not find firmware '%s'", machine->firmware);
+exit(1);
+}
 sz = load_image_targphys(filename, PROM_ADDR, PROM_SIZE);
 if (sz <= 0 || sz > PROM_SIZE) {
 error_report("Could not load firmware '%s'", filename);
 exit(1);
 }
-g_free(filename);
-} else if (!qtest_enabled()) {
-error_report("Could not find firmware '%s'", fwname);
-exit(1);
 }
 
 /* Articia S */
-- 
2.30.9