162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * arch/arm/include/asm/mach/arch.h 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2000 Russell King 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#include <linux/types.h> 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#ifndef __ASSEMBLY__ 1162306a36Sopenharmony_ci#include <linux/reboot.h> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_cistruct tag; 1462306a36Sopenharmony_cistruct pt_regs; 1562306a36Sopenharmony_cistruct smp_operations; 1662306a36Sopenharmony_ci#ifdef CONFIG_SMP 1762306a36Sopenharmony_ci#define smp_ops(ops) (&(ops)) 1862306a36Sopenharmony_ci#define smp_init_ops(ops) (&(ops)) 1962306a36Sopenharmony_ci#else 2062306a36Sopenharmony_ci#define smp_ops(ops) (struct smp_operations *)NULL 2162306a36Sopenharmony_ci#define smp_init_ops(ops) (bool (*)(void))NULL 2262306a36Sopenharmony_ci#endif 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_cistruct machine_desc { 2562306a36Sopenharmony_ci unsigned int nr; /* architecture number */ 2662306a36Sopenharmony_ci const char *name; /* architecture name */ 2762306a36Sopenharmony_ci unsigned long atag_offset; /* tagged list (relative) */ 2862306a36Sopenharmony_ci const char *const *dt_compat; /* array of device tree 2962306a36Sopenharmony_ci * 'compatible' strings */ 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci unsigned int nr_irqs; /* number of IRQs */ 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci#ifdef CONFIG_ZONE_DMA 3462306a36Sopenharmony_ci phys_addr_t dma_zone_size; /* size of DMA-able area */ 3562306a36Sopenharmony_ci#endif 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci unsigned int video_start; /* start of video RAM */ 3862306a36Sopenharmony_ci unsigned int video_end; /* end of video RAM */ 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci unsigned char reserve_lp0 :1; /* never has lp0 */ 4162306a36Sopenharmony_ci unsigned char reserve_lp1 :1; /* never has lp1 */ 4262306a36Sopenharmony_ci unsigned char reserve_lp2 :1; /* never has lp2 */ 4362306a36Sopenharmony_ci enum reboot_mode reboot_mode; /* default restart mode */ 4462306a36Sopenharmony_ci unsigned l2c_aux_val; /* L2 cache aux value */ 4562306a36Sopenharmony_ci unsigned l2c_aux_mask; /* L2 cache aux mask */ 4662306a36Sopenharmony_ci void (*l2c_write_sec)(unsigned long, unsigned); 4762306a36Sopenharmony_ci const struct smp_operations *smp; /* SMP operations */ 4862306a36Sopenharmony_ci bool (*smp_init)(void); 4962306a36Sopenharmony_ci void (*fixup)(struct tag *, char **); 5062306a36Sopenharmony_ci void (*dt_fixup)(void); 5162306a36Sopenharmony_ci long long (*pv_fixup)(void); 5262306a36Sopenharmony_ci void (*reserve)(void);/* reserve mem blocks */ 5362306a36Sopenharmony_ci void (*map_io)(void);/* IO mapping function */ 5462306a36Sopenharmony_ci void (*init_early)(void); 5562306a36Sopenharmony_ci void (*init_irq)(void); 5662306a36Sopenharmony_ci void (*init_time)(void); 5762306a36Sopenharmony_ci void (*init_machine)(void); 5862306a36Sopenharmony_ci void (*init_late)(void); 5962306a36Sopenharmony_ci void (*restart)(enum reboot_mode, const char *); 6062306a36Sopenharmony_ci}; 6162306a36Sopenharmony_ci 6262306a36Sopenharmony_ci/* 6362306a36Sopenharmony_ci * Current machine - only accessible during boot. 6462306a36Sopenharmony_ci */ 6562306a36Sopenharmony_ciextern const struct machine_desc *machine_desc; 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_ci/* 6862306a36Sopenharmony_ci * Machine type table - also only accessible during boot 6962306a36Sopenharmony_ci */ 7062306a36Sopenharmony_ciextern const struct machine_desc __arch_info_begin[], __arch_info_end[]; 7162306a36Sopenharmony_ci#define for_each_machine_desc(p) \ 7262306a36Sopenharmony_ci for (p = __arch_info_begin; p < __arch_info_end; p++) 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci/* 7562306a36Sopenharmony_ci * Set of macros to define architecture features. This is built into 7662306a36Sopenharmony_ci * a table by the linker. 7762306a36Sopenharmony_ci */ 7862306a36Sopenharmony_ci#define MACHINE_START(_type,_name) \ 7962306a36Sopenharmony_cistatic const struct machine_desc __mach_desc_##_type \ 8062306a36Sopenharmony_ci __used \ 8162306a36Sopenharmony_ci __section(".arch.info.init") = { \ 8262306a36Sopenharmony_ci .nr = MACH_TYPE_##_type, \ 8362306a36Sopenharmony_ci .name = _name, 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci#define MACHINE_END \ 8662306a36Sopenharmony_ci}; 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_ci#define DT_MACHINE_START(_name, _namestr) \ 8962306a36Sopenharmony_cistatic const struct machine_desc __mach_desc_##_name \ 9062306a36Sopenharmony_ci __used \ 9162306a36Sopenharmony_ci __section(".arch.info.init") = { \ 9262306a36Sopenharmony_ci .nr = ~0, \ 9362306a36Sopenharmony_ci .name = _namestr, 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci#endif 96