diff options
Diffstat (limited to 'roms/skiboot/include/skiboot.h')
-rw-r--r-- | roms/skiboot/include/skiboot.h | 349 |
1 files changed, 349 insertions, 0 deletions
diff --git a/roms/skiboot/include/skiboot.h b/roms/skiboot/include/skiboot.h new file mode 100644 index 000000000..f3378ec28 --- /dev/null +++ b/roms/skiboot/include/skiboot.h @@ -0,0 +1,349 @@ +// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later +/* Copyright 2013-2019 IBM Corp. */ + +#ifndef __SKIBOOT_H +#define __SKIBOOT_H + +#include <compiler.h> +#include <stdint.h> +#include <stdbool.h> +#include <string.h> +#include <stdlib.h> +#include <stdio.h> +#include <assert.h> +#include <errno.h> +#include <bitutils.h> +#include <types.h> + +#include <ccan/container_of/container_of.h> +#include <ccan/list/list.h> +#include <ccan/short_types/short_types.h> +#include <ccan/build_assert/build_assert.h> +#include <ccan/array_size/array_size.h> +#include <ccan/endian/endian.h> +#include <ccan/str/str.h> + +#include <libflash/blocklevel.h> + +#include <mem-map.h> +#include <op-panel.h> +#include <platform.h> + +/* Special ELF sections */ +#define __force_data __section(".force.data") + +struct mem_region; +extern struct mem_region *mem_region_next(struct mem_region *region); + +/* Misc linker script symbols */ +extern char _start[]; +extern char _head_end[]; +extern char _stext[]; +extern char _etext[]; +extern char __sym_map_end[]; +extern char _romem_end[]; + +#ifndef __TESTING__ +/* Readonly section start and end. */ +extern char __rodata_start[], __rodata_end[]; + +static inline bool is_rodata(const void *p) +{ + return ((const char *)p >= __rodata_start && (const char *)p < __rodata_end); +} +#else +static inline bool is_rodata(const void *p) +{ + return false; +} +#endif + +/* Console logging + * Update console_get_level() if you add here + */ +#define PR_EMERG 0 +#define PR_ALERT 1 +#define PR_CRIT 2 +#define PR_ERR 3 +#define PR_WARNING 4 +#define PR_NOTICE 5 +#define PR_PRINTF PR_NOTICE +#define PR_INFO 6 +#define PR_DEBUG 7 +#define PR_TRACE 8 +#define PR_INSANE 9 + +#ifndef pr_fmt +#define pr_fmt(fmt) fmt +#endif + +void _prlog(int log_level, const char* fmt, ...) __attribute__((format (printf, 2, 3))); +#define prlog(l, f, ...) do { _prlog(l, pr_fmt(f), ##__VA_ARGS__); } while(0) +#define prerror(fmt...) do { prlog(PR_ERR, fmt); } while(0) +#define prlog_once(arg, ...) \ +({ \ + static bool __prlog_once = false; \ + if (!__prlog_once) { \ + __prlog_once = true; \ + prlog(arg, ##__VA_ARGS__); \ + } \ +}) + +/* Location codes -- at most 80 chars with null termination */ +#define LOC_CODE_SIZE 80 + +/* Processor generation */ +enum proc_gen { + proc_gen_unknown, + proc_gen_p8, + proc_gen_p9, + proc_gen_p10, +}; +extern enum proc_gen proc_gen; + +extern unsigned int pcie_max_link_speed; + +/* Convert a 4-bit number to a hex char */ +extern char __attrconst tohex(uint8_t nibble); + +#ifndef __TEST__ +/* Bit position of the most significant 1-bit (LSB=0, MSB=63) */ +static inline int ilog2(unsigned long val) +{ + int left_zeros; + + asm volatile ("cntlzd %0,%1" : "=r" (left_zeros) : "r" (val)); + + return 63 - left_zeros; +} + +static inline bool is_pow2(unsigned long val) +{ + return val == (1ul << ilog2(val)); +} +#endif + +#define lo32(x) ((x) & 0xffffffff) +#define hi32(x) (((x) >> 32) & 0xffffffff) + +/* WARNING: _a *MUST* be a power of two */ +#define ALIGN_UP(_v, _a) (((_v) + (_a) - 1) & ~((_a) - 1)) +#define ALIGN_DOWN(_v, _a) ((_v) & ~((_a) - 1)) + +/* TCE alignment */ +#define TCE_SHIFT 12 +#define TCE_PSIZE (1ul << 12) +#define TCE_MASK (TCE_PSIZE - 1) + +/* Not the greatest variants but will do for now ... */ +#define MIN(a, b) ((a) < (b) ? (a) : (b)) +#define MAX(a, b) ((a) > (b) ? (a) : (b)) + +/* PCI Geographical Addressing */ +#define PCI_BUS_NUM(bdfn) (((bdfn) >> 8) & 0xff) +#define PCI_DEV(bdfn) (((bdfn) >> 3) & 0x1f) +#define PCI_FUNC(bdfn) ((bdfn) & 0x07) + +/* + * To help the FSP to distinguish between physical address and TCE mapped address. + * Also to help hostboot to distinguish physical and relative address. + */ +#define HRMOR_BIT (1ul << 63) + +/* Clean the stray high bit which the FSP inserts: we only have 52 bits real */ +static inline u64 cleanup_addr(u64 addr) +{ + return addr & ((1ULL << 52) - 1); +} + +/* Start the kernel */ +extern void start_kernel(uint64_t entry, void* fdt, + uint64_t mem_top) __noreturn; +extern void start_kernel32(uint64_t entry, void* fdt, + uint64_t mem_top) __noreturn; +extern void start_kernel_secondary(uint64_t entry) __noreturn; + +/* Get description of machine from HDAT and create device-tree */ +extern int parse_hdat(bool is_opal); + +struct dt_node; + +/* Add /cpus/features node for boot environment that passes an fdt */ +extern void dt_add_cpufeatures(struct dt_node *root); + +/* Root of device tree. */ +extern struct dt_node *dt_root; + +/* Full skiboot version number (possibly includes gitid). */ +extern const char version[]; + +/* Debug support */ +extern char __sym_map_start[]; +extern char __sym_map_end[]; +extern size_t snprintf_symbol(char *buf, size_t len, uint64_t addr); + +/* Direct controls */ +extern void direct_controls_init(void); +extern int64_t opal_signal_system_reset(int cpu_nr); + +/* Fast reboot support */ +extern void disable_fast_reboot(const char *reason); +extern void add_fast_reboot_dt_entries(void); +extern void fast_reboot(void); +extern void __noreturn __secondary_cpu_entry(void); +extern void __noreturn load_and_boot_kernel(bool is_reboot); +extern void cleanup_local_tlb(void); +extern void cleanup_global_tlb(void); +extern void init_shared_sprs(void); +extern void init_replicated_sprs(void); +extern bool start_preload_kernel(void); +extern void copy_exception_vectors(void); +extern void copy_sreset_vector(void); +extern void copy_sreset_vector_fast_reboot(void); +extern void patch_traps(bool enable); + +/* Various probe routines, to replace with an initcall system */ +extern void probe_phb3(void); +extern void probe_phb4(void); +extern int preload_capp_ucode(void); +extern void preload_io_vpd(void); +extern void probe_npu(void); +extern void probe_npu2(void); +extern void probe_npu3(void); +extern void uart_init(void); +extern void mbox_init(void); +extern void early_uart_init(void); +extern void homer_init(void); +extern void slw_init(void); +extern void add_cpu_idle_state_properties(void); +extern void lpc_rtc_init(void); + +/* flash support */ +struct flash_chip; +extern int flash_register(struct blocklevel_device *bl); +extern int flash_start_preload_resource(enum resource_id id, uint32_t subid, + void *buf, size_t *len); +extern int flash_resource_loaded(enum resource_id id, uint32_t idx); +extern bool flash_reserve(void); +extern void flash_release(void); +extern bool flash_unregister(void); +#define FLASH_SUBPART_ALIGNMENT 0x1000 +#define FLASH_SUBPART_HEADER_SIZE FLASH_SUBPART_ALIGNMENT +extern int flash_subpart_info(void *part_header, uint32_t header_len, + uint32_t part_size, uint32_t *part_actual, + uint32_t subid, uint32_t *offset, + uint32_t *size); +extern void flash_fw_version_preload(void); +extern void flash_dt_add_fw_version(void); +extern const char *flash_map_resource_name(enum resource_id id); +extern int flash_secboot_info(uint32_t *total_size); +extern int flash_secboot_read(void *dst, uint32_t src, uint32_t len); +extern int flash_secboot_write(uint32_t dst, void *src, uint32_t len); + +/* + * Decompression routines + * + * The below structure members are needed for the xz library routines, + * src: Source address (The compressed binary) + * src_size: Source size + * dst: Destination address (The memory area where the `src` will be + * decompressed) + * dst_size: Destination size + */ +struct xz_decompress { + void *dst; + void *src; + size_t dst_size; + size_t src_size; + /* The status of the decompress process: + - OPAL_PARTIAL: if the job is in progress + - OPAL_SUCCESS: if the job is successful + - OPAL_NO_MEM: memory allocation failure + - OPAL_PARAMETER: If any of the above (src, dst..) are invalid or + if xz decompress fails. In which case the caller should check the + xz_error for failure reason. + */ + int status; + int xz_error; + /* The decompression job, this will be freed if the caller uses + * `wait_xz_decompression` function, in any other case its the + * responsibility of caller to free the allocation job. */ + struct cpu_job *job; +}; + +extern void xz_start_decompress(struct xz_decompress *); +extern void wait_xz_decompress(struct xz_decompress *); + +/* NVRAM support */ +extern void nvram_init(void); +extern void nvram_read_complete(bool success); + +/* UART stuff */ +enum { + UART_CONSOLE_OPAL, + UART_CONSOLE_OS +}; +extern void uart_set_console_policy(int policy); +extern bool uart_enabled(void); + +/* PRD */ +extern void prd_psi_interrupt(uint32_t proc); +extern void prd_tmgt_interrupt(uint32_t proc); +extern void prd_occ_reset(uint32_t proc); +extern void prd_sbe_passthrough(uint32_t proc); +extern void prd_init(void); +extern void prd_register_reserved_memory(void); +extern void prd_fsp_occ_reset(uint32_t proc); +extern void prd_fsp_occ_load_start(u32 proc); +extern void prd_fw_resp_fsp_response(int status); +extern int prd_hbrt_fsp_msg_notify(void *data, u32 dsize); + +/* Flatten device-tree */ +extern void *create_dtb(const struct dt_node *root, bool exclusive); + +/* Track failure in Wakup engine */ +enum wakeup_engine_states { + WAKEUP_ENGINE_NOT_PRESENT, + WAKEUP_ENGINE_PRESENT, + WAKEUP_ENGINE_FAILED +}; +extern enum wakeup_engine_states wakeup_engine_state; +extern bool has_deep_states; +extern void nx_p9_rng_late_init(void); + + + +/* SLW reinit function for switching core settings */ +extern int64_t slw_reinit(uint64_t flags); + +/* Patch SPR in SLW image */ +extern int64_t opal_slw_set_reg(uint64_t cpu_pir, uint64_t sprn, uint64_t val); + +extern void fast_sleep_exit(void); + +/* Fallback fake RTC */ +extern void fake_rtc_init(void); + +/* Exceptions */ +struct stack_frame; +extern void exception_entry(struct stack_frame *stack); +extern void exception_entry_pm_sreset(void); +extern void __noreturn exception_entry_pm_mce(void); + +/* Assembly in head.S */ +extern void disable_machine_check(void); +extern void enable_machine_check(void); +extern unsigned int enter_p8_pm_state(bool winkle); +extern unsigned int enter_p9_pm_state(uint64_t psscr); +extern void enter_p9_pm_lite_state(uint64_t psscr); +extern uint32_t reset_patch_start; +extern uint32_t reset_patch_end; +extern uint32_t reset_fast_reboot_patch_start; +extern uint32_t reset_fast_reboot_patch_end; + +/* Fallback fake NVRAM */ +extern int fake_nvram_info(uint32_t *total_size); +extern int fake_nvram_start_read(void *dst, uint32_t src, uint32_t len); +extern int fake_nvram_write(uint32_t offset, void *src, uint32_t size); + +#endif /* __SKIBOOT_H */ |