/* SPDX--License-Identifier: GPL-2.0 */ #ifndef __PLATFORM_EARLY__ #define __PLATFORM_EARLY__ #include <linux/types.h> #include <linux/platform_device.h> #include <linux/pm_runtime.h> #include <linux/slab.h> struct sh_early_platform_driver { const char *class_str; struct platform_driver *pdrv; struct list_head list; int requested_id; char *buffer; int bufsize; }; #define EARLY_PLATFORM_ID_UNSET -2 #define EARLY_PLATFORM_ID_ERROR -3 extern int sh_early_platform_driver_register(struct sh_early_platform_driver *epdrv, char *buf); extern void sh_early_platform_add_devices(struct platform_device **devs, int num); static inline int is_sh_early_platform_device(struct platform_device *pdev) { return !pdev->dev.driver; } extern void sh_early_platform_driver_register_all(char *class_str); extern int sh_early_platform_driver_probe(char *class_str, int nr_probe, int user_only); #define sh_early_platform_init(class_string, platdrv) \ sh_early_platform_init_buffer(class_string, platdrv, NULL, 0) #ifndef MODULE #define sh_early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \ static __initdata struct sh_early_platform_driver early_driver = { \ .class_str = class_string, \ .buffer = buf, \ .bufsize = bufsiz, \ .pdrv = platdrv, \ .requested_id = EARLY_PLATFORM_ID_UNSET, \ }; \ static int __init sh_early_platform_driver_setup_func(char *buffer) \ { \ return sh_early_platform_driver_register(&early_driver, buffer); \ } \ early_param(class_string, sh_early_platform_driver_setup_func) #else /* MODULE */ #define sh_early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \ static inline char *sh_early_platform_driver_setup_func(void) \ { \ return bufsiz ? buf : NULL; \ } #endif /* MODULE */ #endif /* __PLATFORM_EARLY__ */