23f0a6c80d
Every time this macro is used, the caller is passing in "parameters_base", so this bug wasn't spotted. But the actual macro variable name is "base", so use that instead. Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Message-Id: <20220625152318.120849-1-Jason@zx2c4.com> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
60 lines
1.6 KiB
C
60 lines
1.6 KiB
C
/*
|
|
* SPDX-License-Identifier: GPL-2.0 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(as, base, id) \
|
|
do { \
|
|
stw_phys(as, base, id); \
|
|
base += 2; \
|
|
stw_phys(as, base, sizeof(struct bi_record)); \
|
|
base += 2; \
|
|
} while (0)
|
|
|
|
#define BOOTINFO1(as, base, id, value) \
|
|
do { \
|
|
stw_phys(as, base, id); \
|
|
base += 2; \
|
|
stw_phys(as, base, sizeof(struct bi_record) + 4); \
|
|
base += 2; \
|
|
stl_phys(as, base, value); \
|
|
base += 4; \
|
|
} while (0)
|
|
|
|
#define BOOTINFO2(as, base, id, value1, value2) \
|
|
do { \
|
|
stw_phys(as, base, id); \
|
|
base += 2; \
|
|
stw_phys(as, base, sizeof(struct bi_record) + 8); \
|
|
base += 2; \
|
|
stl_phys(as, base, value1); \
|
|
base += 4; \
|
|
stl_phys(as, base, value2); \
|
|
base += 4; \
|
|
} while (0)
|
|
|
|
#define BOOTINFOSTR(as, base, id, string) \
|
|
do { \
|
|
int i; \
|
|
stw_phys(as, base, id); \
|
|
base += 2; \
|
|
stw_phys(as, base, \
|
|
(sizeof(struct bi_record) + strlen(string) + 2) & ~1); \
|
|
base += 2; \
|
|
for (i = 0; string[i]; i++) { \
|
|
stb_phys(as, base++, string[i]); \
|
|
} \
|
|
stb_phys(as, base++, 0); \
|
|
base = (base + 1) & ~1; \
|
|
} while (0)
|
|
#endif
|