| /* 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__ */ |