/* SPDX-License-Identifier: GPL-2.0 */ #ifndef __PPC_FSL_SOC_H #define __PPC_FSL_SOC_H #ifdef __KERNEL__ #include <asm/mmu.h> struct spi_device; extern phys_addr_t get_immrbase(void); #if defined(CONFIG_CPM) || defined(CONFIG_QUICC_ENGINE) extern u32 get_brgfreq(void); extern u32 get_baudrate(void); #else static inline u32 get_brgfreq(void) { return -1; } static inline u32 get_baudrate(void) { return -1; } #endif extern u32 fsl_get_sys_freq(void); struct spi_board_info; struct device_node; /* The different ports that the DIU can be connected to */ enum fsl_diu_monitor_port { FSL_DIU_PORT_DVI, /* DVI */ FSL_DIU_PORT_LVDS, /* Single-link LVDS */ FSL_DIU_PORT_DLVDS /* Dual-link LVDS */ }; struct platform_diu_data_ops { u32 (*get_pixel_format)(enum fsl_diu_monitor_port port, unsigned int bpp); void (*set_gamma_table)(enum fsl_diu_monitor_port port, char *gamma_table_base); void (*set_monitor_port)(enum fsl_diu_monitor_port port); void (*set_pixel_clock)(unsigned int pixclock); enum fsl_diu_monitor_port (*valid_monitor_port) (enum fsl_diu_monitor_port port); void (*release_bootmem)(void); }; extern struct platform_diu_data_ops diu_ops; void __noreturn fsl_hv_restart(char *cmd); void __noreturn fsl_hv_halt(void); #endif #endif