2019-05-27 08:55:15 +02:00
/* SPDX-License-Identifier: GPL-2.0-only */
2006-11-23 00:46:51 +01:00
/*
* PS3 platform declarations .
*
* Copyright ( C ) 2006 Sony Computer Entertainment Inc .
* Copyright 2006 Sony Corp .
*/
# if !defined(_PS3_PLATFORM_H)
# define _PS3_PLATFORM_H
# include <linux/rtc.h>
2007-01-30 15:20:27 -08:00
# include <scsi/scsi.h>
# include <asm/ps3.h>
2006-11-23 00:46:51 +01:00
/* htab */
void __init ps3_hpte_init ( unsigned long htab_size ) ;
void __init ps3_map_htab ( void ) ;
/* mm */
void __init ps3_mm_init ( void ) ;
void __init ps3_mm_vas_create ( unsigned long * htab_size ) ;
void ps3_mm_vas_destroy ( void ) ;
void ps3_mm_shutdown ( void ) ;
/* irq */
void ps3_init_IRQ ( void ) ;
2007-06-16 07:19:32 +10:00
void ps3_shutdown_IRQ ( int cpu ) ;
2006-11-23 00:46:51 +01:00
void __init ps3_register_ipi_debug_brk ( unsigned int cpu , unsigned int virq ) ;
2011-11-08 12:37:26 +00:00
void __init ps3_register_ipi_irq ( unsigned int cpu , unsigned int virq ) ;
2006-11-23 00:46:51 +01:00
/* smp */
2021-12-16 17:00:28 -05:00
void __init smp_init_ps3 ( void ) ;
2007-09-12 18:43:15 +10:00
# ifdef CONFIG_SMP
2006-11-23 00:46:51 +01:00
void ps3_smp_cleanup_cpu ( int cpu ) ;
2007-09-12 18:43:15 +10:00
# else
static inline void ps3_smp_cleanup_cpu ( int cpu ) { }
# endif
2006-11-23 00:46:51 +01:00
/* time */
void __init ps3_calibrate_decr ( void ) ;
2018-04-23 10:36:40 +02:00
time64_t __init ps3_get_boot_time ( void ) ;
2006-11-23 00:46:51 +01:00
void ps3_get_rtc_time ( struct rtc_time * time ) ;
int ps3_set_rtc_time ( struct rtc_time * time ) ;
/* os area */
2007-10-07 07:35:44 +10:00
void __init ps3_os_area_save_params ( void ) ;
2007-10-07 07:35:47 +10:00
void __init ps3_os_area_init ( void ) ;
2006-11-23 00:46:51 +01:00
2006-11-23 00:46:59 +01:00
/* spu */
# if defined(CONFIG_SPU_BASE)
void ps3_spu_set_platform ( void ) ;
# else
static inline void ps3_spu_set_platform ( void ) { }
# endif
2007-01-30 15:20:27 -08:00
/* repository bus info */
enum ps3_bus_type {
PS3_BUS_TYPE_SB = 4 ,
PS3_BUS_TYPE_STORAGE = 5 ,
} ;
enum ps3_dev_type {
PS3_DEV_TYPE_STOR_DISK = TYPE_DISK , /* 0 */
PS3_DEV_TYPE_SB_GELIC = 3 ,
PS3_DEV_TYPE_SB_USB = 4 ,
PS3_DEV_TYPE_STOR_ROM = TYPE_ROM , /* 5 */
PS3_DEV_TYPE_SB_GPIO = 6 ,
PS3_DEV_TYPE_STOR_FLASH = TYPE_RBC , /* 14 */
} ;
int ps3_repository_read_bus_str ( unsigned int bus_index , const char * bus_str ,
u64 * value ) ;
2008-01-19 07:30:09 +11:00
int ps3_repository_read_bus_id ( unsigned int bus_index , u64 * bus_id ) ;
2007-01-30 15:20:27 -08:00
int ps3_repository_read_bus_type ( unsigned int bus_index ,
enum ps3_bus_type * bus_type ) ;
int ps3_repository_read_bus_num_dev ( unsigned int bus_index ,
unsigned int * num_dev ) ;
/* repository bus device info */
enum ps3_interrupt_type {
PS3_INTERRUPT_TYPE_EVENT_PORT = 2 ,
PS3_INTERRUPT_TYPE_SB_OHCI = 3 ,
PS3_INTERRUPT_TYPE_SB_EHCI = 4 ,
PS3_INTERRUPT_TYPE_OTHER = 5 ,
} ;
enum ps3_reg_type {
PS3_REG_TYPE_SB_OHCI = 3 ,
PS3_REG_TYPE_SB_EHCI = 4 ,
PS3_REG_TYPE_SB_GPIO = 5 ,
} ;
int ps3_repository_read_dev_str ( unsigned int bus_index ,
unsigned int dev_index , const char * dev_str , u64 * value ) ;
int ps3_repository_read_dev_id ( unsigned int bus_index , unsigned int dev_index ,
2008-01-19 07:30:09 +11:00
u64 * dev_id ) ;
2007-01-30 15:20:27 -08:00
int ps3_repository_read_dev_type ( unsigned int bus_index ,
unsigned int dev_index , enum ps3_dev_type * dev_type ) ;
int ps3_repository_read_dev_intr ( unsigned int bus_index ,
unsigned int dev_index , unsigned int intr_index ,
enum ps3_interrupt_type * intr_type , unsigned int * interrupt_id ) ;
int ps3_repository_read_dev_reg_type ( unsigned int bus_index ,
unsigned int dev_index , unsigned int reg_index ,
enum ps3_reg_type * reg_type ) ;
int ps3_repository_read_dev_reg_addr ( unsigned int bus_index ,
unsigned int dev_index , unsigned int reg_index , u64 * bus_addr ,
u64 * len ) ;
int ps3_repository_read_dev_reg ( unsigned int bus_index ,
unsigned int dev_index , unsigned int reg_index ,
enum ps3_reg_type * reg_type , u64 * bus_addr , u64 * len ) ;
/* repository bus enumerators */
struct ps3_repository_device {
unsigned int bus_index ;
unsigned int dev_index ;
2008-01-19 07:30:09 +11:00
enum ps3_bus_type bus_type ;
enum ps3_dev_type dev_type ;
u64 bus_id ;
u64 dev_id ;
2007-01-30 15:20:27 -08:00
} ;
2007-06-16 07:55:58 +10:00
int ps3_repository_find_device ( struct ps3_repository_device * repo ) ;
2008-01-19 07:30:27 +11:00
int ps3_repository_find_device_by_id ( struct ps3_repository_device * repo ,
u64 bus_id , u64 dev_id ) ;
2021-12-16 17:00:28 -05:00
int __init ps3_repository_find_devices ( enum ps3_bus_type bus_type ,
2007-06-16 07:55:58 +10:00
int ( * callback ) ( const struct ps3_repository_device * repo ) ) ;
2021-12-16 17:00:28 -05:00
int __init ps3_repository_find_bus ( enum ps3_bus_type bus_type , unsigned int from ,
2007-06-16 07:55:58 +10:00
unsigned int * bus_index ) ;
int ps3_repository_find_interrupt ( const struct ps3_repository_device * repo ,
2007-01-30 15:20:27 -08:00
enum ps3_interrupt_type intr_type , unsigned int * interrupt_id ) ;
2007-06-16 07:55:58 +10:00
int ps3_repository_find_reg ( const struct ps3_repository_device * repo ,
2007-01-30 15:20:27 -08:00
enum ps3_reg_type reg_type , u64 * bus_addr , u64 * len ) ;
/* repository block device info */
int ps3_repository_read_stor_dev_port ( unsigned int bus_index ,
unsigned int dev_index , u64 * port ) ;
int ps3_repository_read_stor_dev_blk_size ( unsigned int bus_index ,
unsigned int dev_index , u64 * blk_size ) ;
int ps3_repository_read_stor_dev_num_blocks ( unsigned int bus_index ,
unsigned int dev_index , u64 * num_blocks ) ;
int ps3_repository_read_stor_dev_num_regions ( unsigned int bus_index ,
unsigned int dev_index , unsigned int * num_regions ) ;
int ps3_repository_read_stor_dev_region_id ( unsigned int bus_index ,
unsigned int dev_index , unsigned int region_index ,
unsigned int * region_id ) ;
int ps3_repository_read_stor_dev_region_size ( unsigned int bus_index ,
unsigned int dev_index , unsigned int region_index , u64 * region_size ) ;
int ps3_repository_read_stor_dev_region_start ( unsigned int bus_index ,
unsigned int dev_index , unsigned int region_index , u64 * region_start ) ;
int ps3_repository_read_stor_dev_info ( unsigned int bus_index ,
unsigned int dev_index , u64 * port , u64 * blk_size ,
u64 * num_blocks , unsigned int * num_regions ) ;
int ps3_repository_read_stor_dev_region ( unsigned int bus_index ,
unsigned int dev_index , unsigned int region_index ,
unsigned int * region_id , u64 * region_start , u64 * region_size ) ;
2008-01-19 07:32:31 +11:00
/* repository logical pu and memory info */
2007-01-30 15:20:27 -08:00
2008-01-19 07:32:31 +11:00
int ps3_repository_read_num_pu ( u64 * num_pu ) ;
int ps3_repository_read_pu_id ( unsigned int pu_index , u64 * pu_id ) ;
2007-01-30 15:20:27 -08:00
int ps3_repository_read_rm_base ( unsigned int ppe_id , u64 * rm_base ) ;
int ps3_repository_read_rm_size ( unsigned int ppe_id , u64 * rm_size ) ;
int ps3_repository_read_region_total ( u64 * region_total ) ;
int ps3_repository_read_mm_info ( u64 * rm_base , u64 * rm_size ,
u64 * region_total ) ;
2011-08-11 21:31:06 +02:00
int ps3_repository_read_highmem_region_count ( unsigned int * region_count ) ;
int ps3_repository_read_highmem_base ( unsigned int region_index ,
u64 * highmem_base ) ;
int ps3_repository_read_highmem_size ( unsigned int region_index ,
u64 * highmem_size ) ;
int ps3_repository_read_highmem_info ( unsigned int region_index ,
u64 * highmem_base , u64 * highmem_size ) ;
2007-01-30 15:20:27 -08:00
2015-01-13 01:00:20 +00:00
# if defined (CONFIG_PS3_REPOSITORY_WRITE)
2012-03-31 18:13:36 -07:00
int ps3_repository_write_highmem_region_count ( unsigned int region_count ) ;
int ps3_repository_write_highmem_base ( unsigned int region_index ,
u64 highmem_base ) ;
int ps3_repository_write_highmem_size ( unsigned int region_index ,
u64 highmem_size ) ;
int ps3_repository_write_highmem_info ( unsigned int region_index ,
u64 highmem_base , u64 highmem_size ) ;
int ps3_repository_delete_highmem_info ( unsigned int region_index ) ;
2015-01-13 01:00:20 +00:00
# else
static inline int ps3_repository_write_highmem_region_count (
unsigned int region_count ) { return 0 ; }
static inline int ps3_repository_write_highmem_base ( unsigned int region_index ,
u64 highmem_base ) { return 0 ; }
static inline int ps3_repository_write_highmem_size ( unsigned int region_index ,
u64 highmem_size ) { return 0 ; }
static inline int ps3_repository_write_highmem_info ( unsigned int region_index ,
u64 highmem_base , u64 highmem_size ) { return 0 ; }
static inline int ps3_repository_delete_highmem_info ( unsigned int region_index )
{ return 0 ; }
# endif
2012-03-31 18:13:36 -07:00
2007-01-30 15:20:27 -08:00
/* repository pme info */
int ps3_repository_read_num_be ( unsigned int * num_be ) ;
int ps3_repository_read_be_node_id ( unsigned int be_index , u64 * node_id ) ;
2008-01-19 07:32:31 +11:00
int ps3_repository_read_be_id ( u64 node_id , u64 * be_id ) ;
2021-12-16 17:00:28 -05:00
int __init ps3_repository_read_tb_freq ( u64 node_id , u64 * tb_freq ) ;
int __init ps3_repository_read_be_tb_freq ( unsigned int be_index , u64 * tb_freq ) ;
2007-01-30 15:20:27 -08:00
2008-01-19 07:32:31 +11:00
/* repository performance monitor info */
int ps3_repository_read_lpm_privileges ( unsigned int be_index , u64 * lpar ,
u64 * rights ) ;
2007-01-30 15:20:27 -08:00
/* repository 'Other OS' area */
int ps3_repository_read_boot_dat_addr ( u64 * lpar_addr ) ;
int ps3_repository_read_boot_dat_size ( unsigned int * size ) ;
int ps3_repository_read_boot_dat_info ( u64 * lpar_addr , unsigned int * size ) ;
/* repository spu info */
/**
* enum spu_resource_type - Type of spu resource .
* @ spu_resource_type_shared : Logical spu is shared with other partions .
* @ spu_resource_type_exclusive : Logical spu is not shared with other partions .
*
* Returned by ps3_repository_read_spu_resource_id ( ) .
*/
enum ps3_spu_resource_type {
PS3_SPU_RESOURCE_TYPE_SHARED = 0 ,
PS3_SPU_RESOURCE_TYPE_EXCLUSIVE = 0x8000000000000000UL ,
} ;
int ps3_repository_read_num_spu_reserved ( unsigned int * num_spu_reserved ) ;
int ps3_repository_read_num_spu_resource_id ( unsigned int * num_resource_id ) ;
int ps3_repository_read_spu_resource_id ( unsigned int res_index ,
enum ps3_spu_resource_type * resource_type , unsigned int * resource_id ) ;
2007-06-16 07:55:58 +10:00
/* repository vuart info */
2021-12-16 17:00:28 -05:00
int __init ps3_repository_read_vuart_av_port ( unsigned int * port ) ;
int __init ps3_repository_read_vuart_sysmgr_port ( unsigned int * port ) ;
2007-06-16 07:55:58 +10:00
2006-11-23 00:46:51 +01:00
# endif