1 /* SPDX--License-Identifier: GPL-2.0 */ 2 3 #ifndef __PLATFORM_EARLY__ 4 #define __PLATFORM_EARLY__ 5 6 #include <linux/types.h> 7 #include <linux/platform_device.h> 8 #include <linux/pm_runtime.h> 9 #include <linux/slab.h> 10 11 struct sh_early_platform_driver { 12 const char *class_str; 13 struct platform_driver *pdrv; 14 struct list_head list; 15 int requested_id; 16 char *buffer; 17 int bufsize; 18 }; 19 20 #define EARLY_PLATFORM_ID_UNSET -2 21 #define EARLY_PLATFORM_ID_ERROR -3 22 23 extern int sh_early_platform_driver_register(struct sh_early_platform_driver *epdrv, 24 char *buf); 25 extern void sh_early_platform_add_devices(struct platform_device **devs, int num); 26 27 static inline int is_sh_early_platform_device(struct platform_device *pdev) 28 { 29 return !pdev->dev.driver; 30 } 31 32 extern void sh_early_platform_driver_register_all(char *class_str); 33 extern int sh_early_platform_driver_probe(char *class_str, 34 int nr_probe, int user_only); 35 36 #define sh_early_platform_init(class_string, platdrv) \ 37 sh_early_platform_init_buffer(class_string, platdrv, NULL, 0) 38 39 #ifndef MODULE 40 #define sh_early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \ 41 static __initdata struct sh_early_platform_driver early_driver = { \ 42 .class_str = class_string, \ 43 .buffer = buf, \ 44 .bufsize = bufsiz, \ 45 .pdrv = platdrv, \ 46 .requested_id = EARLY_PLATFORM_ID_UNSET, \ 47 }; \ 48 static int __init sh_early_platform_driver_setup_func(char *buffer) \ 49 { \ 50 return sh_early_platform_driver_register(&early_driver, buffer); \ 51 } \ 52 early_param(class_string, sh_early_platform_driver_setup_func) 53 #else /* MODULE */ 54 #define sh_early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \ 55 static inline char *sh_early_platform_driver_setup_func(void) \ 56 { \ 57 return bufsiz ? buf : NULL; \ 58 } 59 #endif /* MODULE */ 60 61 #endif /* __PLATFORM_EARLY__ */ 62