hc
2024-08-12 233ab1bd4c5697f5cdec94e60206e8c6ac609b4c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/*
 * Adapted from Linux v2.6.36 kernel: arch/powerpc/kernel/asm-offsets.c
 *
 * This program is used to generate definitions needed by
 * assembly language modules.
 *
 * We use the technique used in the OSF Mach kernel code:
 * generate asm statements containing #defines,
 * compile this file to assembler, and then extract the
 * #defines from the assembly-language output.
 *
 * SPDX-License-Identifier:    GPL-2.0+
 */
 
#include <common.h>
 
#include <linux/kbuild.h>
 
int main(void)
{
   /* Round up to make sure size gives nice stack alignment */
   DEFINE(GENERATED_GBL_DATA_SIZE,
       (sizeof(struct global_data) + 15) & ~15);
 
   DEFINE(GENERATED_BD_INFO_SIZE,
       (sizeof(struct bd_info) + 15) & ~15);
 
   DEFINE(GD_SIZE, sizeof(struct global_data));
 
   DEFINE(GD_BD, offsetof(struct global_data, bd));
#if CONFIG_VAL(SYS_MALLOC_F_LEN)
   DEFINE(GD_MALLOC_BASE, offsetof(struct global_data, malloc_base));
#endif
 
   DEFINE(GD_RELOCADDR, offsetof(struct global_data, relocaddr));
 
   DEFINE(GD_RELOC_OFF, offsetof(struct global_data, reloc_off));
 
   DEFINE(GD_START_ADDR_SP, offsetof(struct global_data, start_addr_sp));
 
   DEFINE(PM_CTX_SIZE, sizeof(struct pm_ctx));
   DEFINE(PM_CTX_PHYS, offsetof(struct global_data, pm_ctx_phys));
 
   DEFINE(GD_NEW_GD, offsetof(struct global_data, new_gd));
 
   return 0;
}