mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 08:13:54 -06:00
load_aout: replace bswap_needed with big_endian
Targets know whether they are big-endian more than they know if the endianness is different from the host: the former is mostly a constant, at least in machine creation code, while the latter has to be computed with TARGET_BIG_ENDIAN != HOST_BIG_ENDIAN or something like that. load_aout, however, takes a "bswap_needed" argument. Replace it with a "big_endian" argument; even though all users are big-endian, it is cheap enough to keep the optional swapping functionality even for little-endian boards. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
cc3d262aa9
commit
134ab17fff
6 changed files with 7 additions and 31 deletions
|
@ -226,7 +226,7 @@ static void bswap_ahdr(struct exec *e)
|
||||||
|
|
||||||
|
|
||||||
ssize_t load_aout(const char *filename, hwaddr addr, int max_sz,
|
ssize_t load_aout(const char *filename, hwaddr addr, int max_sz,
|
||||||
int bswap_needed, hwaddr target_page_size)
|
bool big_endian, hwaddr target_page_size)
|
||||||
{
|
{
|
||||||
int fd;
|
int fd;
|
||||||
ssize_t size, ret;
|
ssize_t size, ret;
|
||||||
|
@ -241,7 +241,7 @@ ssize_t load_aout(const char *filename, hwaddr addr, int max_sz,
|
||||||
if (size < 0)
|
if (size < 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
if (bswap_needed) {
|
if (big_endian != HOST_BIG_ENDIAN) {
|
||||||
bswap_ahdr(&e);
|
bswap_ahdr(&e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -197,11 +197,6 @@ static void ppc_core99_init(MachineState *machine)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (machine->kernel_filename) {
|
if (machine->kernel_filename) {
|
||||||
int bswap_needed = 0;
|
|
||||||
|
|
||||||
#ifdef BSWAP_NEEDED
|
|
||||||
bswap_needed = 1;
|
|
||||||
#endif
|
|
||||||
kernel_base = KERNEL_LOAD_ADDR;
|
kernel_base = KERNEL_LOAD_ADDR;
|
||||||
kernel_size = load_elf(machine->kernel_filename, NULL,
|
kernel_size = load_elf(machine->kernel_filename, NULL,
|
||||||
translate_kernel_address, NULL, NULL, NULL,
|
translate_kernel_address, NULL, NULL, NULL,
|
||||||
|
@ -209,7 +204,7 @@ static void ppc_core99_init(MachineState *machine)
|
||||||
if (kernel_size < 0) {
|
if (kernel_size < 0) {
|
||||||
kernel_size = load_aout(machine->kernel_filename, kernel_base,
|
kernel_size = load_aout(machine->kernel_filename, kernel_base,
|
||||||
machine->ram_size - kernel_base,
|
machine->ram_size - kernel_base,
|
||||||
bswap_needed, TARGET_PAGE_SIZE);
|
true, TARGET_PAGE_SIZE);
|
||||||
}
|
}
|
||||||
if (kernel_size < 0) {
|
if (kernel_size < 0) {
|
||||||
kernel_size = load_image_targphys(machine->kernel_filename,
|
kernel_size = load_image_targphys(machine->kernel_filename,
|
||||||
|
|
|
@ -153,11 +153,6 @@ static void ppc_heathrow_init(MachineState *machine)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (machine->kernel_filename) {
|
if (machine->kernel_filename) {
|
||||||
int bswap_needed = 0;
|
|
||||||
|
|
||||||
#ifdef BSWAP_NEEDED
|
|
||||||
bswap_needed = 1;
|
|
||||||
#endif
|
|
||||||
kernel_base = KERNEL_LOAD_ADDR;
|
kernel_base = KERNEL_LOAD_ADDR;
|
||||||
kernel_size = load_elf(machine->kernel_filename, NULL,
|
kernel_size = load_elf(machine->kernel_filename, NULL,
|
||||||
translate_kernel_address, NULL, NULL, NULL,
|
translate_kernel_address, NULL, NULL, NULL,
|
||||||
|
@ -165,7 +160,7 @@ static void ppc_heathrow_init(MachineState *machine)
|
||||||
if (kernel_size < 0) {
|
if (kernel_size < 0) {
|
||||||
kernel_size = load_aout(machine->kernel_filename, kernel_base,
|
kernel_size = load_aout(machine->kernel_filename, kernel_base,
|
||||||
machine->ram_size - kernel_base,
|
machine->ram_size - kernel_base,
|
||||||
bswap_needed, TARGET_PAGE_SIZE);
|
true, TARGET_PAGE_SIZE);
|
||||||
}
|
}
|
||||||
if (kernel_size < 0) {
|
if (kernel_size < 0) {
|
||||||
kernel_size = load_image_targphys(machine->kernel_filename,
|
kernel_size = load_image_targphys(machine->kernel_filename,
|
||||||
|
|
|
@ -233,20 +233,13 @@ static unsigned long sun4m_load_kernel(const char *kernel_filename,
|
||||||
|
|
||||||
kernel_size = 0;
|
kernel_size = 0;
|
||||||
if (linux_boot) {
|
if (linux_boot) {
|
||||||
int bswap_needed;
|
|
||||||
|
|
||||||
#ifdef BSWAP_NEEDED
|
|
||||||
bswap_needed = 1;
|
|
||||||
#else
|
|
||||||
bswap_needed = 0;
|
|
||||||
#endif
|
|
||||||
kernel_size = load_elf(kernel_filename, NULL,
|
kernel_size = load_elf(kernel_filename, NULL,
|
||||||
translate_kernel_address, NULL,
|
translate_kernel_address, NULL,
|
||||||
NULL, NULL, NULL, NULL,
|
NULL, NULL, NULL, NULL,
|
||||||
ELFDATA2MSB, EM_SPARC, 0, 0);
|
ELFDATA2MSB, EM_SPARC, 0, 0);
|
||||||
if (kernel_size < 0)
|
if (kernel_size < 0)
|
||||||
kernel_size = load_aout(kernel_filename, KERNEL_LOAD_ADDR,
|
kernel_size = load_aout(kernel_filename, KERNEL_LOAD_ADDR,
|
||||||
RAM_size - KERNEL_LOAD_ADDR, bswap_needed,
|
RAM_size - KERNEL_LOAD_ADDR, true,
|
||||||
TARGET_PAGE_SIZE);
|
TARGET_PAGE_SIZE);
|
||||||
if (kernel_size < 0)
|
if (kernel_size < 0)
|
||||||
kernel_size = load_image_targphys(kernel_filename,
|
kernel_size = load_image_targphys(kernel_filename,
|
||||||
|
|
|
@ -168,13 +168,6 @@ static uint64_t sun4u_load_kernel(const char *kernel_filename,
|
||||||
|
|
||||||
kernel_size = 0;
|
kernel_size = 0;
|
||||||
if (linux_boot) {
|
if (linux_boot) {
|
||||||
int bswap_needed;
|
|
||||||
|
|
||||||
#ifdef BSWAP_NEEDED
|
|
||||||
bswap_needed = 1;
|
|
||||||
#else
|
|
||||||
bswap_needed = 0;
|
|
||||||
#endif
|
|
||||||
kernel_size = load_elf(kernel_filename, NULL, NULL, NULL, kernel_entry,
|
kernel_size = load_elf(kernel_filename, NULL, NULL, NULL, kernel_entry,
|
||||||
kernel_addr, &kernel_top, NULL,
|
kernel_addr, &kernel_top, NULL,
|
||||||
ELFDATA2MSB, EM_SPARCV9, 0, 0);
|
ELFDATA2MSB, EM_SPARCV9, 0, 0);
|
||||||
|
@ -182,7 +175,7 @@ static uint64_t sun4u_load_kernel(const char *kernel_filename,
|
||||||
*kernel_addr = KERNEL_LOAD_ADDR;
|
*kernel_addr = KERNEL_LOAD_ADDR;
|
||||||
*kernel_entry = KERNEL_LOAD_ADDR;
|
*kernel_entry = KERNEL_LOAD_ADDR;
|
||||||
kernel_size = load_aout(kernel_filename, KERNEL_LOAD_ADDR,
|
kernel_size = load_aout(kernel_filename, KERNEL_LOAD_ADDR,
|
||||||
RAM_size - KERNEL_LOAD_ADDR, bswap_needed,
|
RAM_size - KERNEL_LOAD_ADDR, true,
|
||||||
TARGET_PAGE_SIZE);
|
TARGET_PAGE_SIZE);
|
||||||
}
|
}
|
||||||
if (kernel_size < 0) {
|
if (kernel_size < 0) {
|
||||||
|
|
|
@ -190,7 +190,7 @@ ssize_t load_elf(const char *filename,
|
||||||
void load_elf_hdr(const char *filename, void *hdr, bool *is64, Error **errp);
|
void load_elf_hdr(const char *filename, void *hdr, bool *is64, Error **errp);
|
||||||
|
|
||||||
ssize_t load_aout(const char *filename, hwaddr addr, int max_sz,
|
ssize_t load_aout(const char *filename, hwaddr addr, int max_sz,
|
||||||
int bswap_needed, hwaddr target_page_size);
|
bool big_endian, hwaddr target_page_size);
|
||||||
|
|
||||||
#define LOAD_UIMAGE_LOADADDR_INVALID (-1)
|
#define LOAD_UIMAGE_LOADADDR_INVALID (-1)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue