hw: Use IEC binary prefix definitions from "qemu/units.h"
Code change produced with: $ git ls-files | egrep '\.[ch]$' | \ xargs sed -i -e 's/\(\W[KMGTPE]\)_BYTE/\1iB/g' Suggested-by: Stefan Weil <sw@weilnetz.de> Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Acked-by: David Gibson <david@gibson.dropbear.id.au> (ppc parts) Message-Id: <20180625124238.25339-6-f4bug@amsat.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
5fa96cad01
commit
d23b6caadb
@ -40,14 +40,14 @@
|
|||||||
|
|
||||||
#define SRAM_BASE_ADDRESS 0x20000000
|
#define SRAM_BASE_ADDRESS 0x20000000
|
||||||
|
|
||||||
#define MSF2_ENVM_MAX_SIZE (512 * K_BYTE)
|
#define MSF2_ENVM_MAX_SIZE (512 * KiB)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* eSRAM max size is 80k without SECDED(Single error correction and
|
* eSRAM max size is 80k without SECDED(Single error correction and
|
||||||
* dual error detection) feature and 64k with SECDED.
|
* dual error detection) feature and 64k with SECDED.
|
||||||
* We do not support SECDED now.
|
* We do not support SECDED now.
|
||||||
*/
|
*/
|
||||||
#define MSF2_ESRAM_MAX_SIZE (80 * K_BYTE)
|
#define MSF2_ESRAM_MAX_SIZE (80 * KiB)
|
||||||
|
|
||||||
static const uint32_t spi_addr[MSF2_NUM_SPIS] = { 0x40001000 , 0x40011000 };
|
static const uint32_t spi_addr[MSF2_NUM_SPIS] = { 0x40001000 , 0x40011000 };
|
||||||
static const uint32_t uart_addr[MSF2_NUM_UARTS] = { 0x40000000 , 0x40010000 };
|
static const uint32_t uart_addr[MSF2_NUM_UARTS] = { 0x40000000 , 0x40010000 };
|
||||||
|
@ -33,10 +33,10 @@
|
|||||||
#include "cpu.h"
|
#include "cpu.h"
|
||||||
|
|
||||||
#define DDR_BASE_ADDRESS 0xA0000000
|
#define DDR_BASE_ADDRESS 0xA0000000
|
||||||
#define DDR_SIZE (64 * M_BYTE)
|
#define DDR_SIZE (64 * MiB)
|
||||||
|
|
||||||
#define M2S010_ENVM_SIZE (256 * K_BYTE)
|
#define M2S010_ENVM_SIZE (256 * KiB)
|
||||||
#define M2S010_ESRAM_SIZE (64 * K_BYTE)
|
#define M2S010_ESRAM_SIZE (64 * KiB)
|
||||||
|
|
||||||
static void emcraft_sf2_s2s010_init(MachineState *machine)
|
static void emcraft_sf2_s2s010_init(MachineState *machine)
|
||||||
{
|
{
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
|
#include "qemu/units.h"
|
||||||
#include "exec/memory.h"
|
#include "exec/memory.h"
|
||||||
#include "hw/loader.h"
|
#include "hw/loader.h"
|
||||||
#include "hw/loader-fit.h"
|
#include "hw/loader-fit.h"
|
||||||
@ -194,7 +195,7 @@ static int fit_load_fdt(const struct fit_loader *ldr, const void *itb,
|
|||||||
|
|
||||||
err = fit_image_addr(itb, img_off, "load", &load_addr);
|
err = fit_image_addr(itb, img_off, "load", &load_addr);
|
||||||
if (err == -ENOENT) {
|
if (err == -ENOENT) {
|
||||||
load_addr = ROUND_UP(kernel_end, 64 * K_BYTE) + (10 * M_BYTE);
|
load_addr = ROUND_UP(kernel_end, 64 * KiB) + (10 * MiB);
|
||||||
} else if (err) {
|
} else if (err) {
|
||||||
ret = err;
|
ret = err;
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -522,7 +522,7 @@ static void machine_class_init(ObjectClass *oc, void *data)
|
|||||||
MachineClass *mc = MACHINE_CLASS(oc);
|
MachineClass *mc = MACHINE_CLASS(oc);
|
||||||
|
|
||||||
/* Default 128 MB as guest ram size */
|
/* Default 128 MB as guest ram size */
|
||||||
mc->default_ram_size = 128 * M_BYTE;
|
mc->default_ram_size = 128 * MiB;
|
||||||
mc->rom_file_has_mr = true;
|
mc->rom_file_has_mr = true;
|
||||||
|
|
||||||
/* numa node memory size aligned on 8MB by default.
|
/* numa node memory size aligned on 8MB by default.
|
||||||
|
@ -452,12 +452,12 @@
|
|||||||
|
|
||||||
/* SM501 local memory size taken from "linux/drivers/mfd/sm501.c" */
|
/* SM501 local memory size taken from "linux/drivers/mfd/sm501.c" */
|
||||||
static const uint32_t sm501_mem_local_size[] = {
|
static const uint32_t sm501_mem_local_size[] = {
|
||||||
[0] = 4 * M_BYTE,
|
[0] = 4 * MiB,
|
||||||
[1] = 8 * M_BYTE,
|
[1] = 8 * MiB,
|
||||||
[2] = 16 * M_BYTE,
|
[2] = 16 * MiB,
|
||||||
[3] = 32 * M_BYTE,
|
[3] = 32 * MiB,
|
||||||
[4] = 64 * M_BYTE,
|
[4] = 64 * MiB,
|
||||||
[5] = 2 * M_BYTE,
|
[5] = 2 * MiB,
|
||||||
};
|
};
|
||||||
#define get_local_mem_size(s) sm501_mem_local_size[(s)->local_mem_size_index]
|
#define get_local_mem_size(s) sm501_mem_local_size[(s)->local_mem_size_index]
|
||||||
|
|
||||||
@ -1829,7 +1829,7 @@ static void sm501_realize_pci(PCIDevice *dev, Error **errp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Property sm501_pci_properties[] = {
|
static Property sm501_pci_properties[] = {
|
||||||
DEFINE_PROP_UINT32("vram-size", SM501PCIState, vram_size, 64 * M_BYTE),
|
DEFINE_PROP_UINT32("vram-size", SM501PCIState, vram_size, 64 * MiB),
|
||||||
DEFINE_PROP_END_OF_LIST(),
|
DEFINE_PROP_END_OF_LIST(),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -275,7 +275,7 @@ static void machine_hppa_machine_init(MachineClass *mc)
|
|||||||
mc->max_cpus = HPPA_MAX_CPUS;
|
mc->max_cpus = HPPA_MAX_CPUS;
|
||||||
mc->default_cpus = 1;
|
mc->default_cpus = 1;
|
||||||
mc->is_default = 1;
|
mc->is_default = 1;
|
||||||
mc->default_ram_size = 512 * M_BYTE;
|
mc->default_ram_size = 512 * MiB;
|
||||||
mc->default_boot_order = "cd";
|
mc->default_boot_order = "cd";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,7 +200,7 @@ static uint64_t boston_platreg_read(void *opaque, hwaddr addr,
|
|||||||
val |= PLAT_BUILD_CFG_PCIE2_EN;
|
val |= PLAT_BUILD_CFG_PCIE2_EN;
|
||||||
return val;
|
return val;
|
||||||
case PLAT_DDR_CFG:
|
case PLAT_DDR_CFG:
|
||||||
val = s->mach->ram_size / G_BYTE;
|
val = s->mach->ram_size / GiB;
|
||||||
assert(!(val & ~PLAT_DDR_CFG_SIZE));
|
assert(!(val & ~PLAT_DDR_CFG_SIZE));
|
||||||
val |= PLAT_DDR_CFG_MHZ;
|
val |= PLAT_DDR_CFG_MHZ;
|
||||||
return val;
|
return val;
|
||||||
@ -355,7 +355,7 @@ static const void *boston_fdt_filter(void *opaque, const void *fdt_orig,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ram_low_sz = MIN(256 * M_BYTE, machine->ram_size);
|
ram_low_sz = MIN(256 * MiB, machine->ram_size);
|
||||||
ram_high_sz = machine->ram_size - ram_low_sz;
|
ram_high_sz = machine->ram_size - ram_low_sz;
|
||||||
qemu_fdt_setprop_sized_cells(fdt, "/memory@0", "reg",
|
qemu_fdt_setprop_sized_cells(fdt, "/memory@0", "reg",
|
||||||
1, 0x00000000, 1, ram_low_sz,
|
1, 0x00000000, 1, ram_low_sz,
|
||||||
@ -436,8 +436,8 @@ static void boston_mach_init(MachineState *machine)
|
|||||||
int fw_size, fit_err;
|
int fw_size, fit_err;
|
||||||
bool is_64b;
|
bool is_64b;
|
||||||
|
|
||||||
if ((machine->ram_size % G_BYTE) ||
|
if ((machine->ram_size % GiB) ||
|
||||||
(machine->ram_size > (2 * G_BYTE))) {
|
(machine->ram_size > (2 * GiB))) {
|
||||||
error_report("Memory size must be 1GB or 2GB");
|
error_report("Memory size must be 1GB or 2GB");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
@ -471,7 +471,7 @@ static void boston_mach_init(MachineState *machine)
|
|||||||
sysbus_mmio_map_overlap(SYS_BUS_DEVICE(s->cps), 0, 0, 1);
|
sysbus_mmio_map_overlap(SYS_BUS_DEVICE(s->cps), 0, 0, 1);
|
||||||
|
|
||||||
flash = g_new(MemoryRegion, 1);
|
flash = g_new(MemoryRegion, 1);
|
||||||
memory_region_init_rom(flash, NULL, "boston.flash", 128 * M_BYTE, &err);
|
memory_region_init_rom(flash, NULL, "boston.flash", 128 * MiB, &err);
|
||||||
memory_region_add_subregion_overlap(sys_mem, 0x18000000, flash, 0);
|
memory_region_add_subregion_overlap(sys_mem, 0x18000000, flash, 0);
|
||||||
|
|
||||||
ddr = g_new(MemoryRegion, 1);
|
ddr = g_new(MemoryRegion, 1);
|
||||||
@ -481,22 +481,22 @@ static void boston_mach_init(MachineState *machine)
|
|||||||
|
|
||||||
ddr_low_alias = g_new(MemoryRegion, 1);
|
ddr_low_alias = g_new(MemoryRegion, 1);
|
||||||
memory_region_init_alias(ddr_low_alias, NULL, "boston_low.ddr",
|
memory_region_init_alias(ddr_low_alias, NULL, "boston_low.ddr",
|
||||||
ddr, 0, MIN(machine->ram_size, (256 * M_BYTE)));
|
ddr, 0, MIN(machine->ram_size, (256 * MiB)));
|
||||||
memory_region_add_subregion_overlap(sys_mem, 0, ddr_low_alias, 0);
|
memory_region_add_subregion_overlap(sys_mem, 0, ddr_low_alias, 0);
|
||||||
|
|
||||||
xilinx_pcie_init(sys_mem, 0,
|
xilinx_pcie_init(sys_mem, 0,
|
||||||
0x10000000, 32 * M_BYTE,
|
0x10000000, 32 * MiB,
|
||||||
0x40000000, 1 * G_BYTE,
|
0x40000000, 1 * GiB,
|
||||||
get_cps_irq(s->cps, 2), false);
|
get_cps_irq(s->cps, 2), false);
|
||||||
|
|
||||||
xilinx_pcie_init(sys_mem, 1,
|
xilinx_pcie_init(sys_mem, 1,
|
||||||
0x12000000, 32 * M_BYTE,
|
0x12000000, 32 * MiB,
|
||||||
0x20000000, 512 * M_BYTE,
|
0x20000000, 512 * MiB,
|
||||||
get_cps_irq(s->cps, 1), false);
|
get_cps_irq(s->cps, 1), false);
|
||||||
|
|
||||||
pcie2 = xilinx_pcie_init(sys_mem, 2,
|
pcie2 = xilinx_pcie_init(sys_mem, 2,
|
||||||
0x14000000, 32 * M_BYTE,
|
0x14000000, 32 * MiB,
|
||||||
0x16000000, 1 * M_BYTE,
|
0x16000000, 1 * MiB,
|
||||||
get_cps_irq(s->cps, 0), true);
|
get_cps_irq(s->cps, 0), true);
|
||||||
|
|
||||||
platreg = g_new(MemoryRegion, 1);
|
platreg = g_new(MemoryRegion, 1);
|
||||||
@ -526,7 +526,7 @@ static void boston_mach_init(MachineState *machine)
|
|||||||
|
|
||||||
if (machine->firmware) {
|
if (machine->firmware) {
|
||||||
fw_size = load_image_targphys(machine->firmware,
|
fw_size = load_image_targphys(machine->firmware,
|
||||||
0x1fc00000, 4 * M_BYTE);
|
0x1fc00000, 4 * MiB);
|
||||||
if (fw_size == -1) {
|
if (fw_size == -1) {
|
||||||
error_printf("unable to load firmware image '%s'\n",
|
error_printf("unable to load firmware image '%s'\n",
|
||||||
machine->firmware);
|
machine->firmware);
|
||||||
@ -552,7 +552,7 @@ static void boston_mach_class_init(MachineClass *mc)
|
|||||||
mc->desc = "MIPS Boston";
|
mc->desc = "MIPS Boston";
|
||||||
mc->init = boston_mach_init;
|
mc->init = boston_mach_init;
|
||||||
mc->block_default_type = IF_IDE;
|
mc->block_default_type = IF_IDE;
|
||||||
mc->default_ram_size = 1 * G_BYTE;
|
mc->default_ram_size = 1 * GiB;
|
||||||
mc->max_cpus = 16;
|
mc->max_cpus = 16;
|
||||||
mc->default_cpu_type = MIPS_CPU_TYPE_NAME("I6400");
|
mc->default_cpu_type = MIPS_CPU_TYPE_NAME("I6400");
|
||||||
}
|
}
|
||||||
|
@ -556,7 +556,7 @@ static void pnv_init(MachineState *machine)
|
|||||||
char *chip_typename;
|
char *chip_typename;
|
||||||
|
|
||||||
/* allocate RAM */
|
/* allocate RAM */
|
||||||
if (machine->ram_size < (1 * G_BYTE)) {
|
if (machine->ram_size < (1 * GiB)) {
|
||||||
warn_report("skiboot may not work with < 1GB of RAM");
|
warn_report("skiboot may not work with < 1GB of RAM");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1174,7 +1174,7 @@ static void pnv_machine_class_init(ObjectClass *oc, void *data)
|
|||||||
* storage */
|
* storage */
|
||||||
mc->no_parallel = 1;
|
mc->no_parallel = 1;
|
||||||
mc->default_boot_order = NULL;
|
mc->default_boot_order = NULL;
|
||||||
mc->default_ram_size = 1 * G_BYTE;
|
mc->default_ram_size = 1 * GiB;
|
||||||
xic->icp_get = pnv_icp_get;
|
xic->icp_get = pnv_icp_get;
|
||||||
xic->ics_get = pnv_ics_get;
|
xic->ics_get = pnv_ics_get;
|
||||||
xic->ics_resend = pnv_ics_resend;
|
xic->ics_resend = pnv_ics_resend;
|
||||||
|
@ -215,13 +215,13 @@ void ppc4xx_l2sram_init(CPUPPCState *env)
|
|||||||
l2sram = g_malloc0(sizeof(*l2sram));
|
l2sram = g_malloc0(sizeof(*l2sram));
|
||||||
/* XXX: Size is 4*64kB for 460ex, cf. U-Boot, ppc4xx-isram.h */
|
/* XXX: Size is 4*64kB for 460ex, cf. U-Boot, ppc4xx-isram.h */
|
||||||
memory_region_init_ram(&l2sram->bank[0], NULL, "ppc4xx.l2sram_bank0",
|
memory_region_init_ram(&l2sram->bank[0], NULL, "ppc4xx.l2sram_bank0",
|
||||||
64 * K_BYTE, &error_abort);
|
64 * KiB, &error_abort);
|
||||||
memory_region_init_ram(&l2sram->bank[1], NULL, "ppc4xx.l2sram_bank1",
|
memory_region_init_ram(&l2sram->bank[1], NULL, "ppc4xx.l2sram_bank1",
|
||||||
64 * K_BYTE, &error_abort);
|
64 * KiB, &error_abort);
|
||||||
memory_region_init_ram(&l2sram->bank[2], NULL, "ppc4xx.l2sram_bank2",
|
memory_region_init_ram(&l2sram->bank[2], NULL, "ppc4xx.l2sram_bank2",
|
||||||
64 * K_BYTE, &error_abort);
|
64 * KiB, &error_abort);
|
||||||
memory_region_init_ram(&l2sram->bank[3], NULL, "ppc4xx.l2sram_bank3",
|
memory_region_init_ram(&l2sram->bank[3], NULL, "ppc4xx.l2sram_bank3",
|
||||||
64 * K_BYTE, &error_abort);
|
64 * KiB, &error_abort);
|
||||||
qemu_register_reset(&l2sram_reset, l2sram);
|
qemu_register_reset(&l2sram_reset, l2sram);
|
||||||
ppc_dcr_register(env, DCR_L2CACHE_CFG,
|
ppc_dcr_register(env, DCR_L2CACHE_CFG,
|
||||||
l2sram, &dcr_read_l2sram, &dcr_write_l2sram);
|
l2sram, &dcr_read_l2sram, &dcr_write_l2sram);
|
||||||
@ -513,28 +513,28 @@ static uint32_t sdram_bcr(hwaddr ram_base, hwaddr ram_size)
|
|||||||
uint32_t bcr;
|
uint32_t bcr;
|
||||||
|
|
||||||
switch (ram_size) {
|
switch (ram_size) {
|
||||||
case (8 * M_BYTE):
|
case (8 * MiB):
|
||||||
bcr = 0xffc0;
|
bcr = 0xffc0;
|
||||||
break;
|
break;
|
||||||
case (16 * M_BYTE):
|
case (16 * MiB):
|
||||||
bcr = 0xff80;
|
bcr = 0xff80;
|
||||||
break;
|
break;
|
||||||
case (32 * M_BYTE):
|
case (32 * MiB):
|
||||||
bcr = 0xff00;
|
bcr = 0xff00;
|
||||||
break;
|
break;
|
||||||
case (64 * M_BYTE):
|
case (64 * MiB):
|
||||||
bcr = 0xfe00;
|
bcr = 0xfe00;
|
||||||
break;
|
break;
|
||||||
case (128 * M_BYTE):
|
case (128 * MiB):
|
||||||
bcr = 0xfc00;
|
bcr = 0xfc00;
|
||||||
break;
|
break;
|
||||||
case (256 * M_BYTE):
|
case (256 * MiB):
|
||||||
bcr = 0xf800;
|
bcr = 0xf800;
|
||||||
break;
|
break;
|
||||||
case (512 * M_BYTE):
|
case (512 * MiB):
|
||||||
bcr = 0xf000;
|
bcr = 0xf000;
|
||||||
break;
|
break;
|
||||||
case (1 * G_BYTE):
|
case (1 * GiB):
|
||||||
bcr = 0xe000;
|
bcr = 0xe000;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -561,7 +561,7 @@ static target_ulong sdram_size(uint32_t bcr)
|
|||||||
if (sh == 0) {
|
if (sh == 0) {
|
||||||
size = -1;
|
size = -1;
|
||||||
} else {
|
} else {
|
||||||
size = 8 * M_BYTE * sh;
|
size = 8 * MiB * sh;
|
||||||
}
|
}
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
|
@ -884,7 +884,7 @@ static void ibm_40p_machine_init(MachineClass *mc)
|
|||||||
mc->desc = "IBM RS/6000 7020 (40p)",
|
mc->desc = "IBM RS/6000 7020 (40p)",
|
||||||
mc->init = ibm_40p_init;
|
mc->init = ibm_40p_init;
|
||||||
mc->max_cpus = 1;
|
mc->max_cpus = 1;
|
||||||
mc->default_ram_size = 128 * M_BYTE;
|
mc->default_ram_size = 128 * MiB;
|
||||||
mc->block_default_type = IF_SCSI;
|
mc->block_default_type = IF_SCSI;
|
||||||
mc->default_boot_order = "c";
|
mc->default_boot_order = "c";
|
||||||
mc->default_cpu_type = POWERPC_CPU_TYPE_NAME("604");
|
mc->default_cpu_type = POWERPC_CPU_TYPE_NAME("604");
|
||||||
|
@ -597,7 +597,7 @@ static void sam460ex_machine_init(MachineClass *mc)
|
|||||||
mc->desc = "aCube Sam460ex";
|
mc->desc = "aCube Sam460ex";
|
||||||
mc->init = sam460ex_init;
|
mc->init = sam460ex_init;
|
||||||
mc->default_cpu_type = POWERPC_CPU_TYPE_NAME("460exb");
|
mc->default_cpu_type = POWERPC_CPU_TYPE_NAME("460exb");
|
||||||
mc->default_ram_size = 512 * M_BYTE;
|
mc->default_ram_size = 512 * MiB;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEFINE_MACHINE("sam460ex", sam460ex_machine_init)
|
DEFINE_MACHINE("sam460ex", sam460ex_machine_init)
|
||||||
|
@ -2324,7 +2324,7 @@ static void spapr_validate_node_memory(MachineState *machine, Error **errp)
|
|||||||
error_setg(errp, "Memory size 0x" RAM_ADDR_FMT
|
error_setg(errp, "Memory size 0x" RAM_ADDR_FMT
|
||||||
" is not aligned to %llu MiB",
|
" is not aligned to %llu MiB",
|
||||||
machine->ram_size,
|
machine->ram_size,
|
||||||
SPAPR_MEMORY_BLOCK_SIZE / M_BYTE);
|
SPAPR_MEMORY_BLOCK_SIZE / MiB);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2332,7 +2332,7 @@ static void spapr_validate_node_memory(MachineState *machine, Error **errp)
|
|||||||
error_setg(errp, "Maximum memory size 0x" RAM_ADDR_FMT
|
error_setg(errp, "Maximum memory size 0x" RAM_ADDR_FMT
|
||||||
" is not aligned to %llu MiB",
|
" is not aligned to %llu MiB",
|
||||||
machine->ram_size,
|
machine->ram_size,
|
||||||
SPAPR_MEMORY_BLOCK_SIZE / M_BYTE);
|
SPAPR_MEMORY_BLOCK_SIZE / MiB);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2342,7 +2342,7 @@ static void spapr_validate_node_memory(MachineState *machine, Error **errp)
|
|||||||
"Node %d memory size 0x%" PRIx64
|
"Node %d memory size 0x%" PRIx64
|
||||||
" is not aligned to %llu MiB",
|
" is not aligned to %llu MiB",
|
||||||
i, numa_info[i].node_mem,
|
i, numa_info[i].node_mem,
|
||||||
SPAPR_MEMORY_BLOCK_SIZE / M_BYTE);
|
SPAPR_MEMORY_BLOCK_SIZE / MiB);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3209,7 +3209,7 @@ static void spapr_memory_pre_plug(HotplugHandler *hotplug_dev, DeviceState *dev,
|
|||||||
|
|
||||||
if (size % SPAPR_MEMORY_BLOCK_SIZE) {
|
if (size % SPAPR_MEMORY_BLOCK_SIZE) {
|
||||||
error_setg(errp, "Hotplugged memory size must be a multiple of "
|
error_setg(errp, "Hotplugged memory size must be a multiple of "
|
||||||
"%lld MB", SPAPR_MEMORY_BLOCK_SIZE / M_BYTE);
|
"%lld MB", SPAPR_MEMORY_BLOCK_SIZE / MiB);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3961,7 +3961,7 @@ static void spapr_machine_class_init(ObjectClass *oc, void *data)
|
|||||||
mc->max_cpus = 1024;
|
mc->max_cpus = 1024;
|
||||||
mc->no_parallel = 1;
|
mc->no_parallel = 1;
|
||||||
mc->default_boot_order = "";
|
mc->default_boot_order = "";
|
||||||
mc->default_ram_size = 512 * M_BYTE;
|
mc->default_ram_size = 512 * MiB;
|
||||||
mc->kvm_type = spapr_kvm_type;
|
mc->kvm_type = spapr_kvm_type;
|
||||||
machine_class_allow_dynamic_sysbus_dev(mc, TYPE_SPAPR_PCI_HOST_BRIDGE);
|
machine_class_allow_dynamic_sysbus_dev(mc, TYPE_SPAPR_PCI_HOST_BRIDGE);
|
||||||
mc->pci_allow_0_address = true;
|
mc->pci_allow_0_address = true;
|
||||||
|
@ -241,7 +241,7 @@ static void rtas_ibm_get_system_parameter(PowerPCCPU *cpu,
|
|||||||
"DesProcs=%d,"
|
"DesProcs=%d,"
|
||||||
"MaxPlatProcs=%d",
|
"MaxPlatProcs=%d",
|
||||||
max_cpus,
|
max_cpus,
|
||||||
current_machine->ram_size / M_BYTE,
|
current_machine->ram_size / MiB,
|
||||||
smp_cpus,
|
smp_cpus,
|
||||||
max_cpus);
|
max_cpus);
|
||||||
ret = sysparm_st(buffer, length, param_val, strlen(param_val) + 1);
|
ret = sysparm_st(buffer, length, param_val, strlen(param_val) + 1);
|
||||||
|
@ -305,7 +305,7 @@ static void sd_ocr_powerup(void *opaque)
|
|||||||
/* card power-up OK */
|
/* card power-up OK */
|
||||||
sd->ocr = FIELD_DP32(sd->ocr, OCR, CARD_POWER_UP, 1);
|
sd->ocr = FIELD_DP32(sd->ocr, OCR, CARD_POWER_UP, 1);
|
||||||
|
|
||||||
if (sd->size > 1 * G_BYTE) {
|
if (sd->size > 1 * GiB) {
|
||||||
sd->ocr = FIELD_DP32(sd->ocr, OCR, CARD_CAPACITY, 1);
|
sd->ocr = FIELD_DP32(sd->ocr, OCR, CARD_CAPACITY, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -377,7 +377,7 @@ static void sd_set_csd(SDState *sd, uint64_t size)
|
|||||||
uint32_t sectsize = (1 << (SECTOR_SHIFT + 1)) - 1;
|
uint32_t sectsize = (1 << (SECTOR_SHIFT + 1)) - 1;
|
||||||
uint32_t wpsize = (1 << (WPGROUP_SHIFT + 1)) - 1;
|
uint32_t wpsize = (1 << (WPGROUP_SHIFT + 1)) - 1;
|
||||||
|
|
||||||
if (size <= 1 * G_BYTE) { /* Standard Capacity SD */
|
if (size <= 1 * GiB) { /* Standard Capacity SD */
|
||||||
sd->csd[0] = 0x00; /* CSD structure */
|
sd->csd[0] = 0x00; /* CSD structure */
|
||||||
sd->csd[1] = 0x26; /* Data read access-time-1 */
|
sd->csd[1] = 0x26; /* Data read access-time-1 */
|
||||||
sd->csd[2] = 0x00; /* Data read access-time-2 */
|
sd->csd[2] = 0x00; /* Data read access-time-2 */
|
||||||
|
@ -409,7 +409,7 @@ static void sdhci_end_transfer(SDHCIState *s)
|
|||||||
/*
|
/*
|
||||||
* Programmed i/o data transfer
|
* Programmed i/o data transfer
|
||||||
*/
|
*/
|
||||||
#define BLOCK_SIZE_MASK (4 * K_BYTE - 1)
|
#define BLOCK_SIZE_MASK (4 * KiB - 1)
|
||||||
|
|
||||||
/* Fill host controller's read buffer with BLKSIZE bytes of data from card */
|
/* Fill host controller's read buffer with BLKSIZE bytes of data from card */
|
||||||
static void sdhci_read_block_from_card(SDHCIState *s)
|
static void sdhci_read_block_from_card(SDHCIState *s)
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#define QEMU_CUTILS_H
|
#define QEMU_CUTILS_H
|
||||||
|
|
||||||
#include "qemu/fprintf-fn.h"
|
#include "qemu/fprintf-fn.h"
|
||||||
|
#include "qemu/units.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* pstrcpy:
|
* pstrcpy:
|
||||||
@ -155,13 +156,6 @@ int qemu_strtosz(const char *nptr, char **end, uint64_t *result);
|
|||||||
int qemu_strtosz_MiB(const char *nptr, char **end, uint64_t *result);
|
int qemu_strtosz_MiB(const char *nptr, char **end, uint64_t *result);
|
||||||
int qemu_strtosz_metric(const char *nptr, char **end, uint64_t *result);
|
int qemu_strtosz_metric(const char *nptr, char **end, uint64_t *result);
|
||||||
|
|
||||||
#define K_BYTE (1ULL << 10)
|
|
||||||
#define M_BYTE (1ULL << 20)
|
|
||||||
#define G_BYTE (1ULL << 30)
|
|
||||||
#define T_BYTE (1ULL << 40)
|
|
||||||
#define P_BYTE (1ULL << 50)
|
|
||||||
#define E_BYTE (1ULL << 60)
|
|
||||||
|
|
||||||
/* used to print char* safely */
|
/* used to print char* safely */
|
||||||
#define STR_OR_NULL(str) ((str) ? (str) : "null")
|
#define STR_OR_NULL(str) ((str) ? (str) : "null")
|
||||||
|
|
||||||
|
@ -26,8 +26,9 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
|
#include "qemu/units.h"
|
||||||
#include "qemu/cutils.h"
|
#include "qemu/cutils.h"
|
||||||
|
#include "qemu/units.h"
|
||||||
|
|
||||||
static void test_parse_uint_null(void)
|
static void test_parse_uint_null(void)
|
||||||
{
|
{
|
||||||
@ -2022,7 +2023,7 @@ static void test_qemu_strtosz_units(void)
|
|||||||
/* default is M */
|
/* default is M */
|
||||||
err = qemu_strtosz_MiB(none, &endptr, &res);
|
err = qemu_strtosz_MiB(none, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, M_BYTE);
|
g_assert_cmpint(res, ==, MiB);
|
||||||
g_assert(endptr == none + 1);
|
g_assert(endptr == none + 1);
|
||||||
|
|
||||||
err = qemu_strtosz(b, &endptr, &res);
|
err = qemu_strtosz(b, &endptr, &res);
|
||||||
@ -2032,32 +2033,32 @@ static void test_qemu_strtosz_units(void)
|
|||||||
|
|
||||||
err = qemu_strtosz(k, &endptr, &res);
|
err = qemu_strtosz(k, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, K_BYTE);
|
g_assert_cmpint(res, ==, KiB);
|
||||||
g_assert(endptr == k + 2);
|
g_assert(endptr == k + 2);
|
||||||
|
|
||||||
err = qemu_strtosz(m, &endptr, &res);
|
err = qemu_strtosz(m, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, M_BYTE);
|
g_assert_cmpint(res, ==, MiB);
|
||||||
g_assert(endptr == m + 2);
|
g_assert(endptr == m + 2);
|
||||||
|
|
||||||
err = qemu_strtosz(g, &endptr, &res);
|
err = qemu_strtosz(g, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, G_BYTE);
|
g_assert_cmpint(res, ==, GiB);
|
||||||
g_assert(endptr == g + 2);
|
g_assert(endptr == g + 2);
|
||||||
|
|
||||||
err = qemu_strtosz(t, &endptr, &res);
|
err = qemu_strtosz(t, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, T_BYTE);
|
g_assert_cmpint(res, ==, TiB);
|
||||||
g_assert(endptr == t + 2);
|
g_assert(endptr == t + 2);
|
||||||
|
|
||||||
err = qemu_strtosz(p, &endptr, &res);
|
err = qemu_strtosz(p, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, P_BYTE);
|
g_assert_cmpint(res, ==, PiB);
|
||||||
g_assert(endptr == p + 2);
|
g_assert(endptr == p + 2);
|
||||||
|
|
||||||
err = qemu_strtosz(e, &endptr, &res);
|
err = qemu_strtosz(e, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, E_BYTE);
|
g_assert_cmpint(res, ==, EiB);
|
||||||
g_assert(endptr == e + 2);
|
g_assert(endptr == e + 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2070,7 +2071,7 @@ static void test_qemu_strtosz_float(void)
|
|||||||
|
|
||||||
err = qemu_strtosz(str, &endptr, &res);
|
err = qemu_strtosz(str, &endptr, &res);
|
||||||
g_assert_cmpint(err, ==, 0);
|
g_assert_cmpint(err, ==, 0);
|
||||||
g_assert_cmpint(res, ==, 12.345 * M_BYTE);
|
g_assert_cmpint(res, ==, 12.345 * MiB);
|
||||||
g_assert(endptr == str + 7);
|
g_assert(endptr == str + 7);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2106,7 +2107,7 @@ static void test_qemu_strtosz_trailing(void)
|
|||||||
|
|
||||||
str = "123xxx";
|
str = "123xxx";
|
||||||
err = qemu_strtosz_MiB(str, &endptr, &res);
|
err = qemu_strtosz_MiB(str, &endptr, &res);
|
||||||
g_assert_cmpint(res, ==, 123 * M_BYTE);
|
g_assert_cmpint(res, ==, 123 * MiB);
|
||||||
g_assert(endptr == str + 3);
|
g_assert(endptr == str + 3);
|
||||||
|
|
||||||
err = qemu_strtosz(str, NULL, &res);
|
err = qemu_strtosz(str, NULL, &res);
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
|
#include "qemu/units.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
#include "qapi/qmp/qdict.h"
|
#include "qapi/qmp/qdict.h"
|
||||||
#include "qapi/qmp/qlist.h"
|
#include "qapi/qmp/qlist.h"
|
||||||
@ -457,11 +458,11 @@ static void test_keyval_visit_size(void)
|
|||||||
visit_type_size(v, "sz2", &sz, &error_abort);
|
visit_type_size(v, "sz2", &sz, &error_abort);
|
||||||
g_assert_cmpuint(sz, ==, 1536);
|
g_assert_cmpuint(sz, ==, 1536);
|
||||||
visit_type_size(v, "sz3", &sz, &error_abort);
|
visit_type_size(v, "sz3", &sz, &error_abort);
|
||||||
g_assert_cmphex(sz, ==, 2 * M_BYTE);
|
g_assert_cmphex(sz, ==, 2 * MiB);
|
||||||
visit_type_size(v, "sz4", &sz, &error_abort);
|
visit_type_size(v, "sz4", &sz, &error_abort);
|
||||||
g_assert_cmphex(sz, ==, G_BYTE / 10);
|
g_assert_cmphex(sz, ==, GiB / 10);
|
||||||
visit_type_size(v, "sz5", &sz, &error_abort);
|
visit_type_size(v, "sz5", &sz, &error_abort);
|
||||||
g_assert_cmphex(sz, ==, 16777215 * T_BYTE);
|
g_assert_cmphex(sz, ==, 16777215ULL * TiB);
|
||||||
visit_check_struct(v, &error_abort);
|
visit_check_struct(v, &error_abort);
|
||||||
visit_end_struct(v, NULL);
|
visit_end_struct(v, NULL);
|
||||||
visit_free(v);
|
visit_free(v);
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qemu/cutils.h"
|
#include "qemu/units.h"
|
||||||
#include "qemu/option.h"
|
#include "qemu/option.h"
|
||||||
#include "qemu/option_int.h"
|
#include "qemu/option_int.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
@ -704,13 +704,12 @@ static void test_opts_parse_size(void)
|
|||||||
g_assert_cmpuint(opts_count(opts), ==, 3);
|
g_assert_cmpuint(opts_count(opts), ==, 3);
|
||||||
g_assert_cmphex(qemu_opt_get_size(opts, "size1", 0), ==, 8);
|
g_assert_cmphex(qemu_opt_get_size(opts, "size1", 0), ==, 8);
|
||||||
g_assert_cmphex(qemu_opt_get_size(opts, "size2", 0), ==, 1536);
|
g_assert_cmphex(qemu_opt_get_size(opts, "size2", 0), ==, 1536);
|
||||||
g_assert_cmphex(qemu_opt_get_size(opts, "size3", 0), ==, 2 * M_BYTE);
|
g_assert_cmphex(qemu_opt_get_size(opts, "size3", 0), ==, 2 * MiB);
|
||||||
opts = qemu_opts_parse(&opts_list_02, "size1=0.1G,size2=16777215T",
|
opts = qemu_opts_parse(&opts_list_02, "size1=0.1G,size2=16777215T",
|
||||||
false, &error_abort);
|
false, &error_abort);
|
||||||
g_assert_cmpuint(opts_count(opts), ==, 2);
|
g_assert_cmpuint(opts_count(opts), ==, 2);
|
||||||
g_assert_cmphex(qemu_opt_get_size(opts, "size1", 0), ==, G_BYTE / 10);
|
g_assert_cmphex(qemu_opt_get_size(opts, "size1", 0), ==, GiB / 10);
|
||||||
g_assert_cmphex(qemu_opt_get_size(opts, "size2", 0),
|
g_assert_cmphex(qemu_opt_get_size(opts, "size2", 0), ==, 16777215ULL * TiB);
|
||||||
==, 16777215 * T_BYTE);
|
|
||||||
|
|
||||||
/* Beyond limit with suffix */
|
/* Beyond limit with suffix */
|
||||||
opts = qemu_opts_parse(&opts_list_02, "size1=16777216T",
|
opts = qemu_opts_parse(&opts_list_02, "size1=16777216T",
|
||||||
|
Loading…
Reference in New Issue
Block a user