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