77b535cfdd
The M68K architecture uses big endianness. Directly use the big-endian LD/ST API. Mechanical change using: $ end=be; \ for acc in uw w l q tul; do \ sed -i -e "s/ld${acc}_p(/ld${acc}_${end}_p(/" \ -e "s/st${acc}_p(/st${acc}_${end}_p(/" \ $(git grep -wlE '(ld|st)t?u?[wlq]_p' hw/m68k/); \ done Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Thomas Huth <huth@tuxfamily.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-ID: <20241004163042.85922-18-philmd@linaro.org> Signed-off-by: Thomas Huth <thuth@redhat.com>
76 lines
2.1 KiB
C
76 lines
2.1 KiB
C
/*
|
|
* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note
|
|
*
|
|
* Bootinfo tags from linux bootinfo.h and bootinfo-mac.h:
|
|
* This is an easily parsable and extendable structure containing all
|
|
* information to be passed from the bootstrap to the kernel
|
|
*
|
|
* This structure is copied right after the kernel by the bootstrap
|
|
* routine.
|
|
*/
|
|
|
|
#ifndef HW_M68K_BOOTINFO_H
|
|
#define HW_M68K_BOOTINFO_H
|
|
|
|
#define BOOTINFO0(base, id) \
|
|
do { \
|
|
stw_be_p(base, id); \
|
|
base += 2; \
|
|
stw_be_p(base, sizeof(struct bi_record)); \
|
|
base += 2; \
|
|
} while (0)
|
|
|
|
#define BOOTINFO1(base, id, value) \
|
|
do { \
|
|
stw_be_p(base, id); \
|
|
base += 2; \
|
|
stw_be_p(base, sizeof(struct bi_record) + 4); \
|
|
base += 2; \
|
|
stl_be_p(base, value); \
|
|
base += 4; \
|
|
} while (0)
|
|
|
|
#define BOOTINFO2(base, id, value1, value2) \
|
|
do { \
|
|
stw_be_p(base, id); \
|
|
base += 2; \
|
|
stw_be_p(base, sizeof(struct bi_record) + 8); \
|
|
base += 2; \
|
|
stl_be_p(base, value1); \
|
|
base += 4; \
|
|
stl_be_p(base, value2); \
|
|
base += 4; \
|
|
} while (0)
|
|
|
|
#define BOOTINFOSTR(base, id, string) \
|
|
do { \
|
|
stw_be_p(base, id); \
|
|
base += 2; \
|
|
stw_be_p(base, \
|
|
(sizeof(struct bi_record) + strlen(string) + \
|
|
1 /* null termination */ + 3 /* padding */) & ~3); \
|
|
base += 2; \
|
|
for (unsigned i_ = 0; string[i_]; i_++) { \
|
|
stb_p(base++, string[i_]); \
|
|
} \
|
|
stb_p(base++, 0); \
|
|
base = QEMU_ALIGN_PTR_UP(base, 4); \
|
|
} while (0)
|
|
|
|
#define BOOTINFODATA(base, id, data, len) \
|
|
do { \
|
|
stw_be_p(base, id); \
|
|
base += 2; \
|
|
stw_be_p(base, \
|
|
(sizeof(struct bi_record) + len + \
|
|
2 /* length field */ + 3 /* padding */) & ~3); \
|
|
base += 2; \
|
|
stw_be_p(base, len); \
|
|
base += 2; \
|
|
for (unsigned i_ = 0; i_ < len; ++i_) { \
|
|
stb_p(base++, data[i_]); \
|
|
} \
|
|
base = QEMU_ALIGN_PTR_UP(base, 4); \
|
|
} while (0)
|
|
#endif
|