| /* | 
 |  * Copyright (C) 2012 Synopsys, Inc. (www.synopsys.com) | 
 |  * | 
 |  * based on METAG mach/arch.h (which in turn was based on ARM) | 
 |  * | 
 |  * This program is free software; you can redistribute it and/or modify | 
 |  * it under the terms of the GNU General Public License version 2 as | 
 |  * published by the Free Software Foundation. | 
 |  */ | 
 |  | 
 | #ifndef _ASM_ARC_MACH_DESC_H_ | 
 | #define _ASM_ARC_MACH_DESC_H_ | 
 |  | 
 | /** | 
 |  * struct machine_desc - Board specific callbacks, called from ARC common code | 
 |  *	Provided by each ARC board using MACHINE_START()/MACHINE_END(), so | 
 |  *	a multi-platform kernel builds with array of such descriptors. | 
 |  *	We extend the early DT scan to also match the DT's "compatible" string | 
 |  *	against the @dt_compat of all such descriptors, and one with highest | 
 |  *	"DT score" is selected as global @machine_desc. | 
 |  * | 
 |  * @name:		Board/SoC name | 
 |  * @dt_compat:		Array of device tree 'compatible' strings | 
 |  * 			(XXX: although only 1st entry is looked at) | 
 |  * @init_early:		Very early callback [called from setup_arch()] | 
 |  * @init_irq:		setup external IRQ controllers [called from init_IRQ()] | 
 |  * @init_smp:		for each CPU (e.g. setup IPI) | 
 |  * 			[(M):init_IRQ(), (o):start_kernel_secondary()] | 
 |  * @init_time:		platform specific clocksource/clockevent registration | 
 |  * 			[called from time_init()] | 
 |  * @init_machine:	arch initcall level callback (e.g. populate static | 
 |  * 			platform devices or parse Devicetree) | 
 |  * @init_late:		Late initcall level callback | 
 |  * | 
 |  */ | 
 | struct machine_desc { | 
 | 	const char		*name; | 
 | 	const char		**dt_compat; | 
 |  | 
 | 	void			(*init_early)(void); | 
 | 	void			(*init_irq)(void); | 
 | #ifdef CONFIG_SMP | 
 | 	void			(*init_smp)(unsigned int); | 
 | #endif | 
 | 	void			(*init_time)(void); | 
 | 	void			(*init_machine)(void); | 
 | 	void			(*init_late)(void); | 
 |  | 
 | }; | 
 |  | 
 | /* | 
 |  * Current machine - only accessible during boot. | 
 |  */ | 
 | extern struct machine_desc *machine_desc; | 
 |  | 
 | /* | 
 |  * Machine type table - also only accessible during boot | 
 |  */ | 
 | extern struct machine_desc __arch_info_begin[], __arch_info_end[]; | 
 | #define for_each_machine_desc(p)			\ | 
 | 	for (p = __arch_info_begin; p < __arch_info_end; p++) | 
 |  | 
 | static inline struct machine_desc *default_machine_desc(void) | 
 | { | 
 | 	/* the default machine is the last one linked in */ | 
 | 	if (__arch_info_end - 1 < __arch_info_begin) | 
 | 		return NULL; | 
 | 	return __arch_info_end - 1; | 
 | } | 
 |  | 
 | /* | 
 |  * Set of macros to define architecture features. | 
 |  * This is built into a table by the linker. | 
 |  */ | 
 | #define MACHINE_START(_type, _name)			\ | 
 | static const struct machine_desc __mach_desc_##_type	\ | 
 | __used							\ | 
 | __attribute__((__section__(".arch.info.init"))) = {	\ | 
 | 	.name		= _name, | 
 |  | 
 | #define MACHINE_END				\ | 
 | }; | 
 |  | 
 | extern struct machine_desc *setup_machine_fdt(void *dt); | 
 | extern void __init copy_devtree(void); | 
 |  | 
 | #endif |