| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _PARISC_PDC_H | 
|  | 2 | #define _PARISC_PDC_H | 
|  | 3 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 4 |  | 
|  | 5 | /* | 
|  | 6 | *	PDC return values ... | 
|  | 7 | *	All PDC calls return a subset of these errors. | 
|  | 8 | */ | 
|  | 9 |  | 
|  | 10 | #define PDC_WARN		  3	/* Call completed with a warning */ | 
|  | 11 | #define PDC_REQ_ERR_1		  2	/* See above			 */ | 
|  | 12 | #define PDC_REQ_ERR_0		  1	/* Call would generate a requestor error */ | 
|  | 13 | #define PDC_OK			  0	/* Call completed successfully	*/ | 
|  | 14 | #define PDC_BAD_PROC		 -1	/* Called non-existent procedure*/ | 
|  | 15 | #define PDC_BAD_OPTION		 -2	/* Called with non-existent option */ | 
|  | 16 | #define PDC_ERROR		 -3	/* Call could not complete without an error */ | 
|  | 17 | #define PDC_NE_MOD		 -5	/* Module not found		*/ | 
|  | 18 | #define PDC_NE_CELL_MOD		 -7	/* Cell module not found	*/ | 
|  | 19 | #define PDC_INVALID_ARG		-10	/* Called with an invalid argument */ | 
|  | 20 | #define PDC_BUS_POW_WARN	-12	/* Call could not complete in allowed power budget */ | 
|  | 21 | #define PDC_NOT_NARROW		-17	/* Narrow mode not supported	*/ | 
|  | 22 |  | 
|  | 23 |  | 
|  | 24 | /* | 
|  | 25 | *	PDC entry points... | 
|  | 26 | */ | 
|  | 27 |  | 
|  | 28 | #define PDC_POW_FAIL	1		/* perform a power-fail		*/ | 
|  | 29 | #define PDC_POW_FAIL_PREPARE	0	/* prepare for powerfail	*/ | 
|  | 30 |  | 
|  | 31 | #define PDC_CHASSIS	2		/* PDC-chassis functions	*/ | 
|  | 32 | #define PDC_CHASSIS_DISP	0	/* update chassis display	*/ | 
|  | 33 | #define PDC_CHASSIS_WARN	1	/* return chassis warnings	*/ | 
|  | 34 | #define PDC_CHASSIS_DISPWARN	2	/* update&return chassis status */ | 
|  | 35 | #define PDC_RETURN_CHASSIS_INFO 128	/* HVERSION dependent: return chassis LED/LCD info  */ | 
|  | 36 |  | 
|  | 37 | #define PDC_PIM         3               /* Get PIM data                 */ | 
|  | 38 | #define PDC_PIM_HPMC            0       /* Transfer HPMC data           */ | 
|  | 39 | #define PDC_PIM_RETURN_SIZE     1       /* Get Max buffer needed for PIM*/ | 
|  | 40 | #define PDC_PIM_LPMC            2       /* Transfer HPMC data           */ | 
|  | 41 | #define PDC_PIM_SOFT_BOOT       3       /* Transfer Soft Boot data      */ | 
|  | 42 | #define PDC_PIM_TOC             4       /* Transfer TOC data            */ | 
|  | 43 |  | 
|  | 44 | #define PDC_MODEL	4		/* PDC model information call	*/ | 
|  | 45 | #define PDC_MODEL_INFO		0	/* returns information 		*/ | 
|  | 46 | #define PDC_MODEL_BOOTID	1	/* set the BOOT_ID		*/ | 
|  | 47 | #define PDC_MODEL_VERSIONS	2	/* returns cpu-internal versions*/ | 
|  | 48 | #define PDC_MODEL_SYSMODEL	3	/* return system model info	*/ | 
|  | 49 | #define PDC_MODEL_ENSPEC	4	/* enable specific option	*/ | 
|  | 50 | #define PDC_MODEL_DISPEC	5	/* disable specific option	*/ | 
|  | 51 | #define PDC_MODEL_CPU_ID	6	/* returns cpu-id (only newer machines!) */ | 
|  | 52 | #define PDC_MODEL_CAPABILITIES	7	/* returns OS32/OS64-flags	*/ | 
|  | 53 | #define PDC_MODEL_GET_BOOT__OP	8	/* returns boot test options	*/ | 
|  | 54 | #define PDC_MODEL_SET_BOOT__OP	9	/* set boot test options	*/ | 
|  | 55 |  | 
|  | 56 | #define PA89_INSTRUCTION_SET	0x4	/* capatibilies returned	*/ | 
|  | 57 | #define PA90_INSTRUCTION_SET	0x8 | 
|  | 58 |  | 
|  | 59 | #define PDC_CACHE	5		/* return/set cache (& TLB) info*/ | 
|  | 60 | #define PDC_CACHE_INFO		0	/* returns information 		*/ | 
|  | 61 | #define PDC_CACHE_SET_COH	1	/* set coherence state		*/ | 
|  | 62 | #define PDC_CACHE_RET_SPID	2	/* returns space-ID bits	*/ | 
|  | 63 |  | 
|  | 64 | #define PDC_HPA		6		/* return HPA of processor	*/ | 
|  | 65 | #define PDC_HPA_PROCESSOR	0 | 
|  | 66 | #define PDC_HPA_MODULES		1 | 
|  | 67 |  | 
|  | 68 | #define PDC_COPROC	7		/* Co-Processor (usually FP unit(s)) */ | 
|  | 69 | #define PDC_COPROC_CFG		0	/* Co-Processor Cfg (FP unit(s) enabled?) */ | 
|  | 70 |  | 
|  | 71 | #define PDC_IODC	8		/* talk to IODC			*/ | 
|  | 72 | #define PDC_IODC_READ		0	/* read IODC entry point	*/ | 
|  | 73 | /*      PDC_IODC_RI_			 * INDEX parameter of PDC_IODC_READ */ | 
|  | 74 | #define PDC_IODC_RI_DATA_BYTES	0	/* IODC Data Bytes		*/ | 
|  | 75 | /*				1, 2	   obsolete - HVERSION dependent*/ | 
|  | 76 | #define PDC_IODC_RI_INIT	3	/* Initialize module		*/ | 
|  | 77 | #define PDC_IODC_RI_IO		4	/* Module input/output		*/ | 
|  | 78 | #define PDC_IODC_RI_SPA		5	/* Module input/output		*/ | 
|  | 79 | #define PDC_IODC_RI_CONFIG	6	/* Module input/output		*/ | 
|  | 80 | /*				7	  obsolete - HVERSION dependent */ | 
|  | 81 | #define PDC_IODC_RI_TEST	8	/* Module input/output		*/ | 
|  | 82 | #define PDC_IODC_RI_TLB		9	/* Module input/output		*/ | 
|  | 83 | #define PDC_IODC_NINIT		2	/* non-destructive init		*/ | 
|  | 84 | #define PDC_IODC_DINIT		3	/* destructive init		*/ | 
|  | 85 | #define PDC_IODC_MEMERR		4	/* check for memory errors	*/ | 
|  | 86 | #define PDC_IODC_INDEX_DATA	0	/* get first 16 bytes from mod IODC */ | 
|  | 87 | #define PDC_IODC_BUS_ERROR	-4	/* bus error return value	*/ | 
|  | 88 | #define PDC_IODC_INVALID_INDEX	-5	/* invalid index return value	*/ | 
|  | 89 | #define PDC_IODC_COUNT		-6	/* count is too small		*/ | 
|  | 90 |  | 
|  | 91 | #define PDC_TOD		9		/* time-of-day clock (TOD)	*/ | 
|  | 92 | #define PDC_TOD_READ		0	/* read TOD			*/ | 
|  | 93 | #define PDC_TOD_WRITE		1	/* write TOD			*/ | 
|  | 94 | #define PDC_TOD_ITIMER		2	/* calibrate Interval Timer (CR16) */ | 
|  | 95 |  | 
|  | 96 | #define PDC_STABLE	10		/* stable storage (sprockets)	*/ | 
|  | 97 | #define PDC_STABLE_READ		0 | 
|  | 98 | #define PDC_STABLE_WRITE	1 | 
|  | 99 | #define PDC_STABLE_RETURN_SIZE	2 | 
|  | 100 | #define PDC_STABLE_VERIFY_CONTENTS 3 | 
|  | 101 | #define PDC_STABLE_INITIALIZE	4 | 
|  | 102 |  | 
|  | 103 | #define PDC_NVOLATILE	11		/* often not implemented	*/ | 
|  | 104 |  | 
|  | 105 | #define PDC_ADD_VALID	12		/* Memory validation PDC call	*/ | 
|  | 106 | #define PDC_ADD_VALID_VERIFY	0	/* Make PDC_ADD_VALID verify region */ | 
|  | 107 |  | 
|  | 108 | #define PDC_INSTR	15		/* get instr to invoke PDCE_CHECK() */ | 
|  | 109 |  | 
|  | 110 | #define PDC_PROC	16		/* (sprockets)			*/ | 
|  | 111 |  | 
|  | 112 | #define PDC_CONFIG	16		/* (sprockets)			*/ | 
|  | 113 | #define PDC_CONFIG_DECONFIG	0 | 
|  | 114 | #define PDC_CONFIG_DRECONFIG	1 | 
|  | 115 | #define PDC_CONFIG_DRETURN_CONFIG 2 | 
|  | 116 |  | 
|  | 117 | #define PDC_BLOCK_TLB	18		/* manage hardware block-TLB	*/ | 
|  | 118 | #define PDC_BTLB_INFO		0	/* returns parameter 		*/ | 
|  | 119 | #define PDC_BTLB_INSERT		1	/* insert BTLB entry		*/ | 
|  | 120 | #define PDC_BTLB_PURGE		2	/* purge BTLB entries 		*/ | 
|  | 121 | #define PDC_BTLB_PURGE_ALL	3	/* purge all BTLB entries 	*/ | 
|  | 122 |  | 
|  | 123 | #define PDC_TLB		19		/* manage hardware TLB miss handling */ | 
|  | 124 | #define PDC_TLB_INFO		0	/* returns parameter 		*/ | 
|  | 125 | #define PDC_TLB_SETUP		1	/* set up miss handling 	*/ | 
|  | 126 |  | 
|  | 127 | #define PDC_MEM		20		/* Manage memory		*/ | 
|  | 128 | #define PDC_MEM_MEMINFO		0 | 
|  | 129 | #define PDC_MEM_ADD_PAGE	1 | 
|  | 130 | #define PDC_MEM_CLEAR_PDT	2 | 
|  | 131 | #define PDC_MEM_READ_PDT	3 | 
|  | 132 | #define PDC_MEM_RESET_CLEAR	4 | 
|  | 133 | #define PDC_MEM_GOODMEM		5 | 
|  | 134 | #define PDC_MEM_TABLE		128	/* Non contig mem map (sprockets) */ | 
|  | 135 | #define PDC_MEM_RETURN_ADDRESS_TABLE	PDC_MEM_TABLE | 
|  | 136 | #define PDC_MEM_GET_MEMORY_SYSTEM_TABLES_SIZE	131 | 
|  | 137 | #define PDC_MEM_GET_MEMORY_SYSTEM_TABLES	132 | 
|  | 138 | #define PDC_MEM_GET_PHYSICAL_LOCATION_FROM_MEMORY_ADDRESS 133 | 
|  | 139 |  | 
|  | 140 | #define PDC_MEM_RET_SBE_REPLACED	5	/* PDC_MEM return values */ | 
|  | 141 | #define PDC_MEM_RET_DUPLICATE_ENTRY	4 | 
|  | 142 | #define PDC_MEM_RET_BUF_SIZE_SMALL	1 | 
|  | 143 | #define PDC_MEM_RET_PDT_FULL		-11 | 
|  | 144 | #define PDC_MEM_RET_INVALID_PHYSICAL_LOCATION ~0ULL | 
|  | 145 |  | 
|  | 146 | #ifndef __ASSEMBLY__ | 
|  | 147 | typedef struct { | 
|  | 148 | unsigned long long	baseAddr; | 
|  | 149 | unsigned int	pages; | 
|  | 150 | unsigned int	reserved; | 
|  | 151 | } MemAddrTable_t; | 
|  | 152 | #endif | 
|  | 153 |  | 
|  | 154 |  | 
|  | 155 | #define PDC_PSW		21		/* Get/Set default System Mask  */ | 
|  | 156 | #define PDC_PSW_MASK		0	/* Return mask                  */ | 
|  | 157 | #define PDC_PSW_GET_DEFAULTS	1	/* Return defaults              */ | 
|  | 158 | #define PDC_PSW_SET_DEFAULTS	2	/* Set default                  */ | 
|  | 159 | #define PDC_PSW_ENDIAN_BIT	1	/* set for big endian           */ | 
|  | 160 | #define PDC_PSW_WIDE_BIT	2	/* set for wide mode            */ | 
|  | 161 |  | 
|  | 162 | #define PDC_SYSTEM_MAP	22		/* find system modules		*/ | 
|  | 163 | #define PDC_FIND_MODULE 	0 | 
|  | 164 | #define PDC_FIND_ADDRESS	1 | 
|  | 165 | #define PDC_TRANSLATE_PATH	2 | 
|  | 166 |  | 
|  | 167 | #define PDC_SOFT_POWER	23		/* soft power switch		*/ | 
|  | 168 | #define PDC_SOFT_POWER_INFO	0	/* return info about the soft power switch */ | 
|  | 169 | #define PDC_SOFT_POWER_ENABLE	1	/* enable/disable soft power switch */ | 
|  | 170 |  | 
|  | 171 |  | 
|  | 172 | /* HVERSION dependent */ | 
|  | 173 |  | 
|  | 174 | /* The PDC_MEM_MAP calls */ | 
|  | 175 | #define PDC_MEM_MAP	128		/* on s700: return page info	*/ | 
|  | 176 | #define PDC_MEM_MAP_HPA		0	/* returns hpa of a module	*/ | 
|  | 177 |  | 
|  | 178 | #define PDC_EEPROM	129		/* EEPROM access		*/ | 
|  | 179 | #define PDC_EEPROM_READ_WORD	0 | 
|  | 180 | #define PDC_EEPROM_WRITE_WORD	1 | 
|  | 181 | #define PDC_EEPROM_READ_BYTE	2 | 
|  | 182 | #define PDC_EEPROM_WRITE_BYTE	3 | 
|  | 183 | #define PDC_EEPROM_EEPROM_PASSWORD -1000 | 
|  | 184 |  | 
|  | 185 | #define PDC_NVM		130		/* NVM (non-volatile memory) access */ | 
|  | 186 | #define PDC_NVM_READ_WORD	0 | 
|  | 187 | #define PDC_NVM_WRITE_WORD	1 | 
|  | 188 | #define PDC_NVM_READ_BYTE	2 | 
|  | 189 | #define PDC_NVM_WRITE_BYTE	3 | 
|  | 190 |  | 
|  | 191 | #define PDC_SEED_ERROR	132		/* (sprockets)			*/ | 
|  | 192 |  | 
|  | 193 | #define PDC_IO		135		/* log error info, reset IO system */ | 
|  | 194 | #define PDC_IO_READ_AND_CLEAR_ERRORS	0 | 
|  | 195 | #define PDC_IO_RESET			1 | 
|  | 196 | #define PDC_IO_RESET_DEVICES		2 | 
|  | 197 | /* sets bits 6&7 (little endian) of the HcControl Register */ | 
|  | 198 | #define PDC_IO_USB_SUSPEND	0xC000000000000000 | 
|  | 199 | #define PDC_IO_EEPROM_IO_ERR_TABLE_FULL	-5	/* return value */ | 
|  | 200 | #define PDC_IO_NO_SUSPEND		-6	/* return value */ | 
|  | 201 |  | 
|  | 202 | #define PDC_BROADCAST_RESET 136		/* reset all processors		*/ | 
|  | 203 | #define PDC_DO_RESET		0	/* option: perform a broadcast reset */ | 
|  | 204 | #define PDC_DO_FIRM_TEST_RESET	1	/* Do broadcast reset with bitmap */ | 
|  | 205 | #define PDC_BR_RECONFIGURATION	2	/* reset w/reconfiguration	*/ | 
|  | 206 | #define PDC_FIRM_TEST_MAGIC	0xab9ec36fUL    /* for this reboot only	*/ | 
|  | 207 |  | 
|  | 208 | #define PDC_LAN_STATION_ID 138		/* Hversion dependent mechanism for */ | 
|  | 209 | #define PDC_LAN_STATION_ID_READ	0	/* getting the lan station address  */ | 
|  | 210 |  | 
|  | 211 | #define	PDC_LAN_STATION_ID_SIZE	6 | 
|  | 212 |  | 
|  | 213 | #define PDC_CHECK_RANGES 139		/* (sprockets)			*/ | 
|  | 214 |  | 
|  | 215 | #define PDC_NV_SECTIONS	141		/* (sprockets)			*/ | 
|  | 216 |  | 
|  | 217 | #define PDC_PERFORMANCE	142		/* performance monitoring	*/ | 
|  | 218 |  | 
|  | 219 | #define PDC_SYSTEM_INFO	143		/* system information		*/ | 
|  | 220 | #define PDC_SYSINFO_RETURN_INFO_SIZE	0 | 
|  | 221 | #define PDC_SYSINFO_RRETURN_SYS_INFO	1 | 
|  | 222 | #define PDC_SYSINFO_RRETURN_ERRORS	2 | 
|  | 223 | #define PDC_SYSINFO_RRETURN_WARNINGS	3 | 
|  | 224 | #define PDC_SYSINFO_RETURN_REVISIONS	4 | 
|  | 225 | #define PDC_SYSINFO_RRETURN_DIAGNOSE	5 | 
|  | 226 | #define PDC_SYSINFO_RRETURN_HV_DIAGNOSE	1005 | 
|  | 227 |  | 
|  | 228 | #define PDC_RDR		144		/* (sprockets)			*/ | 
|  | 229 | #define PDC_RDR_READ_BUFFER	0 | 
|  | 230 | #define PDC_RDR_READ_SINGLE	1 | 
|  | 231 | #define PDC_RDR_WRITE_SINGLE	2 | 
|  | 232 |  | 
|  | 233 | #define PDC_INTRIGUE	145 		/* (sprockets)			*/ | 
|  | 234 | #define PDC_INTRIGUE_WRITE_BUFFER 	 0 | 
|  | 235 | #define PDC_INTRIGUE_GET_SCRATCH_BUFSIZE 1 | 
|  | 236 | #define PDC_INTRIGUE_START_CPU_COUNTERS	 2 | 
|  | 237 | #define PDC_INTRIGUE_STOP_CPU_COUNTERS	 3 | 
|  | 238 |  | 
|  | 239 | #define PDC_STI		146 		/* STI access			*/ | 
|  | 240 | /* same as PDC_PCI_XXX values (see below) */ | 
|  | 241 |  | 
|  | 242 | /* Legacy PDC definitions for same stuff */ | 
|  | 243 | #define PDC_PCI_INDEX	147 | 
|  | 244 | #define PDC_PCI_INTERFACE_INFO		0 | 
|  | 245 | #define PDC_PCI_SLOT_INFO		1 | 
|  | 246 | #define PDC_PCI_INFLIGHT_BYTES		2 | 
|  | 247 | #define PDC_PCI_READ_CONFIG		3 | 
|  | 248 | #define PDC_PCI_WRITE_CONFIG		4 | 
|  | 249 | #define PDC_PCI_READ_PCI_IO		5 | 
|  | 250 | #define PDC_PCI_WRITE_PCI_IO		6 | 
|  | 251 | #define PDC_PCI_READ_CONFIG_DELAY	7 | 
|  | 252 | #define PDC_PCI_UPDATE_CONFIG_DELAY	8 | 
|  | 253 | #define PDC_PCI_PCI_PATH_TO_PCI_HPA	9 | 
|  | 254 | #define PDC_PCI_PCI_HPA_TO_PCI_PATH	10 | 
|  | 255 | #define PDC_PCI_PCI_PATH_TO_PCI_BUS	11 | 
|  | 256 | #define PDC_PCI_PCI_RESERVED		12 | 
|  | 257 | #define PDC_PCI_PCI_INT_ROUTE_SIZE	13 | 
|  | 258 | #define PDC_PCI_GET_INT_TBL_SIZE	PDC_PCI_PCI_INT_ROUTE_SIZE | 
|  | 259 | #define PDC_PCI_PCI_INT_ROUTE		14 | 
|  | 260 | #define PDC_PCI_GET_INT_TBL		PDC_PCI_PCI_INT_ROUTE | 
|  | 261 | #define PDC_PCI_READ_MON_TYPE		15 | 
|  | 262 | #define PDC_PCI_WRITE_MON_TYPE		16 | 
|  | 263 |  | 
|  | 264 |  | 
|  | 265 | /* Get SCSI Interface Card info:  SDTR, SCSI ID, mode (SE vs LVD) */ | 
|  | 266 | #define PDC_INITIATOR	163 | 
|  | 267 | #define PDC_GET_INITIATOR	0 | 
|  | 268 | #define PDC_SET_INITIATOR	1 | 
|  | 269 | #define PDC_DELETE_INITIATOR	2 | 
|  | 270 | #define PDC_RETURN_TABLE_SIZE	3 | 
|  | 271 | #define PDC_RETURN_TABLE	4 | 
|  | 272 |  | 
|  | 273 | #define PDC_LINK	165 		/* (sprockets)			*/ | 
|  | 274 | #define PDC_LINK_PCI_ENTRY_POINTS	0  /* list (Arg1) = 0 */ | 
|  | 275 | #define PDC_LINK_USB_ENTRY_POINTS	1  /* list (Arg1) = 1 */ | 
|  | 276 |  | 
|  | 277 |  | 
|  | 278 | /* constants for OS (NVM...) */ | 
|  | 279 | #define OS_ID_NONE		0	/* Undefined OS ID	*/ | 
|  | 280 | #define OS_ID_HPUX		1	/* HP-UX OS		*/ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 281 | #define OS_ID_MPEXL		2	/* MPE XL OS		*/ | 
|  | 282 | #define OS_ID_OSF		3	/* OSF OS		*/ | 
|  | 283 | #define OS_ID_HPRT		4	/* HP-RT OS		*/ | 
|  | 284 | #define OS_ID_NOVEL		5	/* NOVELL OS		*/ | 
| Kyle McMartin | ec1fdc2 | 2006-06-21 19:27:29 +0000 | [diff] [blame] | 285 | #define OS_ID_LINUX		6	/* Linux		*/ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 286 |  | 
|  | 287 |  | 
|  | 288 | /* constants for PDC_CHASSIS */ | 
|  | 289 | #define OSTAT_OFF		0 | 
|  | 290 | #define OSTAT_FLT		1 | 
|  | 291 | #define OSTAT_TEST		2 | 
|  | 292 | #define OSTAT_INIT		3 | 
|  | 293 | #define OSTAT_SHUT		4 | 
|  | 294 | #define OSTAT_WARN		5 | 
|  | 295 | #define OSTAT_RUN		6 | 
|  | 296 | #define OSTAT_ON		7 | 
|  | 297 |  | 
|  | 298 | #ifndef __ASSEMBLY__ | 
|  | 299 |  | 
|  | 300 | #include <linux/types.h> | 
|  | 301 |  | 
|  | 302 | extern int pdc_type; | 
|  | 303 |  | 
|  | 304 | /* Values for pdc_type */ | 
|  | 305 | #define PDC_TYPE_ILLEGAL	-1 | 
|  | 306 | #define PDC_TYPE_PAT		 0 /* 64-bit PAT-PDC */ | 
|  | 307 | #define PDC_TYPE_SYSTEM_MAP	 1 /* 32-bit, but supports PDC_SYSTEM_MAP */ | 
|  | 308 | #define PDC_TYPE_SNAKE		 2 /* Doesn't support SYSTEM_MAP */ | 
|  | 309 |  | 
|  | 310 | struct pdc_chassis_info {       /* for PDC_CHASSIS_INFO */ | 
|  | 311 | unsigned long actcnt;   /* actual number of bytes returned */ | 
|  | 312 | unsigned long maxcnt;   /* maximum number of bytes that could be returned */ | 
|  | 313 | }; | 
|  | 314 |  | 
|  | 315 | struct pdc_coproc_cfg {         /* for PDC_COPROC_CFG */ | 
|  | 316 | unsigned long ccr_functional; | 
|  | 317 | unsigned long ccr_present; | 
|  | 318 | unsigned long revision; | 
|  | 319 | unsigned long model; | 
|  | 320 | }; | 
|  | 321 |  | 
|  | 322 | struct pdc_model {		/* for PDC_MODEL */ | 
|  | 323 | unsigned long hversion; | 
|  | 324 | unsigned long sversion; | 
|  | 325 | unsigned long hw_id; | 
|  | 326 | unsigned long boot_id; | 
|  | 327 | unsigned long sw_id; | 
|  | 328 | unsigned long sw_cap; | 
|  | 329 | unsigned long arch_rev; | 
|  | 330 | unsigned long pot_key; | 
|  | 331 | unsigned long curr_key; | 
|  | 332 | }; | 
|  | 333 |  | 
| Alexey Dobriyan | 7f927fc | 2006-03-28 01:56:53 -0800 | [diff] [blame] | 334 | /* Values for PDC_MODEL_CAPABILITIES non-equivalent virtual aliasing support */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 335 |  | 
|  | 336 | #define PDC_MODEL_IOPDIR_FDC            (1 << 2)        /* see sba_iommu.c */ | 
|  | 337 | #define PDC_MODEL_NVA_MASK		(3 << 4) | 
|  | 338 | #define PDC_MODEL_NVA_SUPPORTED		(0 << 4) | 
|  | 339 | #define PDC_MODEL_NVA_SLOW		(1 << 4) | 
|  | 340 | #define PDC_MODEL_NVA_UNSUPPORTED	(3 << 4) | 
|  | 341 |  | 
|  | 342 | struct pdc_cache_cf {		/* for PDC_CACHE  (I/D-caches) */ | 
|  | 343 | unsigned long | 
|  | 344 | #ifdef __LP64__ | 
|  | 345 | cc_padW:32, | 
|  | 346 | #endif | 
|  | 347 | cc_alias: 4,	/* alias boundaries for virtual addresses   */ | 
|  | 348 | cc_block: 4,	/* to determine most efficient stride */ | 
|  | 349 | cc_line	: 3,	/* maximum amount written back as a result of store (multiple of 16 bytes) */ | 
|  | 350 | cc_shift: 2,	/* how much to shift cc_block left */ | 
|  | 351 | cc_wt	: 1,	/* 0 = WT-Dcache, 1 = WB-Dcache */ | 
|  | 352 | cc_sh	: 2,	/* 0 = separate I/D-cache, else shared I/D-cache */ | 
|  | 353 | cc_cst  : 3,	/* 0 = incoherent D-cache, 1=coherent D-cache */ | 
| Kyle McMartin | e5a2e7f | 2006-06-14 20:26:25 +0000 | [diff] [blame] | 354 | cc_pad1 : 10,	/* reserved */ | 
|  | 355 | cc_hv   : 3;	/* hversion dependent */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 356 | }; | 
|  | 357 |  | 
|  | 358 | struct pdc_tlb_cf {		/* for PDC_CACHE (I/D-TLB's) */ | 
|  | 359 | unsigned long tc_pad0:12,	/* reserved */ | 
|  | 360 | #ifdef __LP64__ | 
|  | 361 | tc_padW:32, | 
|  | 362 | #endif | 
|  | 363 | tc_sh	: 2,	/* 0 = separate I/D-TLB, else shared I/D-TLB */ | 
|  | 364 | tc_hv   : 1,	/* HV */ | 
|  | 365 | tc_page : 1,	/* 0 = 2K page-size-machine, 1 = 4k page size */ | 
|  | 366 | tc_cst  : 3,	/* 0 = incoherent operations, else coherent operations */ | 
|  | 367 | tc_aid  : 5,	/* ITLB: width of access ids of processor (encoded!) */ | 
|  | 368 | tc_pad1 : 8;	/* ITLB: width of space-registers (encoded) */ | 
|  | 369 | }; | 
|  | 370 |  | 
|  | 371 | struct pdc_cache_info {		/* main-PDC_CACHE-structure (caches & TLB's) */ | 
|  | 372 | /* I-cache */ | 
|  | 373 | unsigned long	ic_size;	/* size in bytes */ | 
|  | 374 | struct pdc_cache_cf ic_conf;	/* configuration */ | 
|  | 375 | unsigned long	ic_base;	/* base-addr */ | 
|  | 376 | unsigned long	ic_stride; | 
|  | 377 | unsigned long	ic_count; | 
|  | 378 | unsigned long	ic_loop; | 
|  | 379 | /* D-cache */ | 
|  | 380 | unsigned long	dc_size;	/* size in bytes */ | 
|  | 381 | struct pdc_cache_cf dc_conf;	/* configuration */ | 
|  | 382 | unsigned long	dc_base;	/* base-addr */ | 
|  | 383 | unsigned long	dc_stride; | 
|  | 384 | unsigned long	dc_count; | 
|  | 385 | unsigned long	dc_loop; | 
|  | 386 | /* Instruction-TLB */ | 
|  | 387 | unsigned long	it_size;	/* number of entries in I-TLB */ | 
|  | 388 | struct pdc_tlb_cf it_conf;	/* I-TLB-configuration */ | 
|  | 389 | unsigned long	it_sp_base; | 
|  | 390 | unsigned long	it_sp_stride; | 
|  | 391 | unsigned long	it_sp_count; | 
|  | 392 | unsigned long	it_off_base; | 
|  | 393 | unsigned long	it_off_stride; | 
|  | 394 | unsigned long	it_off_count; | 
|  | 395 | unsigned long	it_loop; | 
|  | 396 | /* data-TLB */ | 
|  | 397 | unsigned long	dt_size;	/* number of entries in D-TLB */ | 
|  | 398 | struct pdc_tlb_cf dt_conf;	/* D-TLB-configuration */ | 
|  | 399 | unsigned long	dt_sp_base; | 
|  | 400 | unsigned long	dt_sp_stride; | 
|  | 401 | unsigned long	dt_sp_count; | 
|  | 402 | unsigned long	dt_off_base; | 
|  | 403 | unsigned long	dt_off_stride; | 
|  | 404 | unsigned long	dt_off_count; | 
|  | 405 | unsigned long	dt_loop; | 
|  | 406 | }; | 
|  | 407 |  | 
|  | 408 | #if 0 | 
|  | 409 | /* If you start using the next struct, you'll have to adjust it to | 
|  | 410 | * work with 64-bit firmware I think -PB | 
|  | 411 | */ | 
|  | 412 | struct pdc_iodc {     /* PDC_IODC */ | 
|  | 413 | unsigned char   hversion_model; | 
|  | 414 | unsigned char 	hversion; | 
|  | 415 | unsigned char 	spa; | 
|  | 416 | unsigned char 	type; | 
|  | 417 | unsigned int	sversion_rev:4; | 
|  | 418 | unsigned int	sversion_model:19; | 
|  | 419 | unsigned int	sversion_opt:8; | 
|  | 420 | unsigned char	rev; | 
|  | 421 | unsigned char	dep; | 
|  | 422 | unsigned char	features; | 
|  | 423 | unsigned char	pad1; | 
|  | 424 | unsigned int	checksum:16; | 
|  | 425 | unsigned int	length:16; | 
|  | 426 | unsigned int    pad[15]; | 
|  | 427 | } __attribute__((aligned(8))) ; | 
|  | 428 | #endif | 
|  | 429 |  | 
|  | 430 | #ifndef CONFIG_PA20 | 
|  | 431 | /* no BLTBs in pa2.0 processors */ | 
|  | 432 | struct pdc_btlb_info_range { | 
|  | 433 | __u8 res00; | 
|  | 434 | __u8 num_i; | 
|  | 435 | __u8 num_d; | 
|  | 436 | __u8 num_comb; | 
|  | 437 | }; | 
|  | 438 |  | 
|  | 439 | struct pdc_btlb_info {	/* PDC_BLOCK_TLB, return of PDC_BTLB_INFO */ | 
|  | 440 | unsigned int min_size;	/* minimum size of BTLB in pages */ | 
|  | 441 | unsigned int max_size;	/* maximum size of BTLB in pages */ | 
|  | 442 | struct pdc_btlb_info_range fixed_range_info; | 
|  | 443 | struct pdc_btlb_info_range variable_range_info; | 
|  | 444 | }; | 
|  | 445 |  | 
|  | 446 | #endif /* !CONFIG_PA20 */ | 
|  | 447 |  | 
|  | 448 | #ifdef __LP64__ | 
|  | 449 | struct pdc_memory_table_raddr { /* PDC_MEM/PDC_MEM_TABLE (return info) */ | 
|  | 450 | unsigned long entries_returned; | 
|  | 451 | unsigned long entries_total; | 
|  | 452 | }; | 
|  | 453 |  | 
|  | 454 | struct pdc_memory_table {       /* PDC_MEM/PDC_MEM_TABLE (arguments) */ | 
|  | 455 | unsigned long paddr; | 
|  | 456 | unsigned int  pages; | 
|  | 457 | unsigned int  reserved; | 
|  | 458 | }; | 
|  | 459 | #endif /* __LP64__ */ | 
|  | 460 |  | 
|  | 461 | struct pdc_system_map_mod_info { /* PDC_SYSTEM_MAP/FIND_MODULE */ | 
|  | 462 | unsigned long mod_addr; | 
|  | 463 | unsigned long mod_pgs; | 
|  | 464 | unsigned long add_addrs; | 
|  | 465 | }; | 
|  | 466 |  | 
|  | 467 | struct pdc_system_map_addr_info { /* PDC_SYSTEM_MAP/FIND_ADDRESS */ | 
|  | 468 | unsigned long mod_addr; | 
|  | 469 | unsigned long mod_pgs; | 
|  | 470 | }; | 
|  | 471 |  | 
|  | 472 | struct pdc_initiator { /* PDC_INITIATOR */ | 
|  | 473 | int host_id; | 
|  | 474 | int factor; | 
|  | 475 | int width; | 
|  | 476 | int mode; | 
|  | 477 | }; | 
|  | 478 |  | 
|  | 479 | struct hardware_path { | 
|  | 480 | char  flags;	/* see bit definitions below */ | 
|  | 481 | char  bc[6];	/* Bus Converter routing info to a specific */ | 
|  | 482 | /* I/O adaptor (< 0 means none, > 63 resvd) */ | 
|  | 483 | char  mod;	/* fixed field of specified module */ | 
|  | 484 | }; | 
|  | 485 |  | 
|  | 486 | /* | 
|  | 487 | * Device path specifications used by PDC. | 
|  | 488 | */ | 
|  | 489 | struct pdc_module_path { | 
|  | 490 | struct hardware_path path; | 
|  | 491 | unsigned int layers[6]; /* device-specific info (ctlr #, unit # ...) */ | 
|  | 492 | }; | 
|  | 493 |  | 
|  | 494 | #ifndef CONFIG_PA20 | 
|  | 495 | /* Only used on some pre-PA2.0 boxes */ | 
|  | 496 | struct pdc_memory_map {		/* PDC_MEMORY_MAP */ | 
|  | 497 | unsigned long hpa;	/* mod's register set address */ | 
|  | 498 | unsigned long more_pgs;	/* number of additional I/O pgs */ | 
|  | 499 | }; | 
|  | 500 | #endif | 
|  | 501 |  | 
|  | 502 | struct pdc_tod { | 
|  | 503 | unsigned long tod_sec; | 
|  | 504 | unsigned long tod_usec; | 
|  | 505 | }; | 
|  | 506 |  | 
|  | 507 | /* architected results from PDC_PIM/transfer hpmc on a PA1.1 machine */ | 
|  | 508 |  | 
|  | 509 | struct pdc_hpmc_pim_11 { /* PDC_PIM */ | 
|  | 510 | __u32 gr[32]; | 
|  | 511 | __u32 cr[32]; | 
|  | 512 | __u32 sr[8]; | 
|  | 513 | __u32 iasq_back; | 
|  | 514 | __u32 iaoq_back; | 
|  | 515 | __u32 check_type; | 
|  | 516 | __u32 cpu_state; | 
|  | 517 | __u32 rsvd1; | 
|  | 518 | __u32 cache_check; | 
|  | 519 | __u32 tlb_check; | 
|  | 520 | __u32 bus_check; | 
|  | 521 | __u32 assists_check; | 
|  | 522 | __u32 rsvd2; | 
|  | 523 | __u32 assist_state; | 
|  | 524 | __u32 responder_addr; | 
|  | 525 | __u32 requestor_addr; | 
|  | 526 | __u32 path_info; | 
|  | 527 | __u64 fr[32]; | 
|  | 528 | }; | 
|  | 529 |  | 
|  | 530 | /* | 
|  | 531 | * architected results from PDC_PIM/transfer hpmc on a PA2.0 machine | 
|  | 532 | * | 
|  | 533 | * Note that PDC_PIM doesn't care whether or not wide mode was enabled | 
|  | 534 | * so the results are different on  PA1.1 vs. PA2.0 when in narrow mode. | 
|  | 535 | * | 
|  | 536 | * Note also that there are unarchitected results available, which | 
|  | 537 | * are hversion dependent. Do a "ser pim 0 hpmc" after rebooting, since | 
|  | 538 | * the firmware is probably the best way of printing hversion dependent | 
|  | 539 | * data. | 
|  | 540 | */ | 
|  | 541 |  | 
|  | 542 | struct pdc_hpmc_pim_20 { /* PDC_PIM */ | 
|  | 543 | __u64 gr[32]; | 
|  | 544 | __u64 cr[32]; | 
|  | 545 | __u64 sr[8]; | 
|  | 546 | __u64 iasq_back; | 
|  | 547 | __u64 iaoq_back; | 
|  | 548 | __u32 check_type; | 
|  | 549 | __u32 cpu_state; | 
|  | 550 | __u32 cache_check; | 
|  | 551 | __u32 tlb_check; | 
|  | 552 | __u32 bus_check; | 
|  | 553 | __u32 assists_check; | 
|  | 554 | __u32 assist_state; | 
|  | 555 | __u32 path_info; | 
|  | 556 | __u64 responder_addr; | 
|  | 557 | __u64 requestor_addr; | 
|  | 558 | __u64 fr[32]; | 
|  | 559 | }; | 
|  | 560 |  | 
|  | 561 | #endif /* __ASSEMBLY__ */ | 
|  | 562 |  | 
|  | 563 | /* flags of the device_path (see below) */ | 
|  | 564 | #define	PF_AUTOBOOT	0x80 | 
|  | 565 | #define	PF_AUTOSEARCH	0x40 | 
|  | 566 | #define	PF_TIMER	0x0F | 
|  | 567 |  | 
|  | 568 | #ifndef __ASSEMBLY__ | 
|  | 569 |  | 
|  | 570 | struct device_path {		/* page 1-69 */ | 
|  | 571 | unsigned char flags;	/* flags see above! */ | 
|  | 572 | unsigned char bc[6];	/* bus converter routing info */ | 
|  | 573 | unsigned char mod; | 
|  | 574 | unsigned int  layers[6];/* device-specific layer-info */ | 
|  | 575 | } __attribute__((aligned(8))) ; | 
|  | 576 |  | 
|  | 577 | struct pz_device { | 
|  | 578 | struct	device_path dp;	/* see above */ | 
|  | 579 | /* struct	iomod *hpa; */ | 
|  | 580 | unsigned int hpa;	/* HPA base address */ | 
|  | 581 | /* char	*spa; */ | 
|  | 582 | unsigned int spa;	/* SPA base address */ | 
|  | 583 | /* int	(*iodc_io)(struct iomod*, ...); */ | 
|  | 584 | unsigned int iodc_io;	/* device entry point */ | 
|  | 585 | short	pad;		/* reserved */ | 
|  | 586 | unsigned short cl_class;/* see below */ | 
|  | 587 | } __attribute__((aligned(8))) ; | 
|  | 588 |  | 
|  | 589 | #endif /* __ASSEMBLY__ */ | 
|  | 590 |  | 
|  | 591 | /* cl_class | 
|  | 592 | * page 3-33 of IO-Firmware ARS | 
|  | 593 | * IODC ENTRY_INIT(Search first) RET[1] | 
|  | 594 | */ | 
|  | 595 | #define	CL_NULL		0	/* invalid */ | 
|  | 596 | #define	CL_RANDOM	1	/* random access (as disk) */ | 
|  | 597 | #define	CL_SEQU		2	/* sequential access (as tape) */ | 
|  | 598 | #define	CL_DUPLEX	7	/* full-duplex point-to-point (RS-232, Net) */ | 
|  | 599 | #define	CL_KEYBD	8	/* half-duplex console (HIL Keyboard) */ | 
|  | 600 | #define	CL_DISPL	9	/* half-duplex console (display) */ | 
|  | 601 | #define	CL_FC		10	/* FiberChannel access media */ | 
|  | 602 |  | 
|  | 603 | #if 0 | 
|  | 604 | /* FIXME: DEVCLASS_* duplicates CL_* (above).  Delete DEVCLASS_*? */ | 
|  | 605 | #define DEVCLASS_RANDOM		1 | 
|  | 606 | #define DEVCLASS_SEQU		2 | 
|  | 607 | #define DEVCLASS_DUPLEX		7 | 
|  | 608 | #define DEVCLASS_KEYBD		8 | 
|  | 609 | #define DEVCLASS_DISP		9 | 
|  | 610 | #endif | 
|  | 611 |  | 
|  | 612 | /* IODC ENTRY_INIT() */ | 
|  | 613 | #define ENTRY_INIT_SRCH_FRST	2 | 
|  | 614 | #define ENTRY_INIT_SRCH_NEXT	3 | 
|  | 615 | #define ENTRY_INIT_MOD_DEV	4 | 
|  | 616 | #define ENTRY_INIT_DEV		5 | 
|  | 617 | #define ENTRY_INIT_MOD		6 | 
|  | 618 | #define ENTRY_INIT_MSG		9 | 
|  | 619 |  | 
|  | 620 | /* IODC ENTRY_IO() */ | 
|  | 621 | #define ENTRY_IO_BOOTIN		0 | 
|  | 622 | #define ENTRY_IO_BOOTOUT	1 | 
|  | 623 | #define ENTRY_IO_CIN		2 | 
|  | 624 | #define ENTRY_IO_COUT		3 | 
|  | 625 | #define ENTRY_IO_CLOSE		4 | 
|  | 626 | #define ENTRY_IO_GETMSG		9 | 
|  | 627 | #define ENTRY_IO_BBLOCK_IN	16 | 
|  | 628 | #define ENTRY_IO_BBLOCK_OUT	17 | 
|  | 629 |  | 
|  | 630 | /* IODC ENTRY_SPA() */ | 
|  | 631 |  | 
|  | 632 | /* IODC ENTRY_CONFIG() */ | 
|  | 633 |  | 
|  | 634 | /* IODC ENTRY_TEST() */ | 
|  | 635 |  | 
|  | 636 | /* IODC ENTRY_TLB() */ | 
|  | 637 |  | 
|  | 638 |  | 
|  | 639 | /* DEFINITION OF THE ZERO-PAGE (PAG0) */ | 
|  | 640 | /* based on work by Jason Eckhardt (jason@equator.com) */ | 
|  | 641 |  | 
|  | 642 | #ifndef __ASSEMBLY__ | 
|  | 643 |  | 
|  | 644 | #define PAGE0   ((struct zeropage *)__PAGE_OFFSET) | 
|  | 645 |  | 
|  | 646 | struct zeropage { | 
|  | 647 | /* [0x000] initialize vectors (VEC) */ | 
|  | 648 | unsigned int	vec_special;		/* must be zero */ | 
|  | 649 | /* int	(*vec_pow_fail)(void);*/ | 
|  | 650 | unsigned int	vec_pow_fail; /* power failure handler */ | 
|  | 651 | /* int	(*vec_toc)(void); */ | 
|  | 652 | unsigned int	vec_toc; | 
|  | 653 | unsigned int	vec_toclen; | 
|  | 654 | /* int	(*vec_rendz)(void); */ | 
|  | 655 | unsigned int vec_rendz; | 
|  | 656 | int	vec_pow_fail_flen; | 
|  | 657 | int	vec_pad[10]; | 
|  | 658 |  | 
|  | 659 | /* [0x040] reserved processor dependent */ | 
|  | 660 | int	pad0[112]; | 
|  | 661 |  | 
|  | 662 | /* [0x200] reserved */ | 
|  | 663 | int	pad1[84]; | 
|  | 664 |  | 
|  | 665 | /* [0x350] memory configuration (MC) */ | 
|  | 666 | int	memc_cont;		/* contiguous mem size (bytes) */ | 
|  | 667 | int	memc_phsize;		/* physical memory size */ | 
|  | 668 | int	memc_adsize;		/* additional mem size, bytes of SPA space used by PDC */ | 
|  | 669 | unsigned int mem_pdc_hi;	/* used for 64-bit */ | 
|  | 670 |  | 
|  | 671 | /* [0x360] various parameters for the boot-CPU */ | 
|  | 672 | /* unsigned int *mem_booterr[8]; */ | 
|  | 673 | unsigned int mem_booterr[8];	/* ptr to boot errors */ | 
|  | 674 | unsigned int mem_free;		/* first location, where OS can be loaded */ | 
|  | 675 | /* struct iomod *mem_hpa; */ | 
|  | 676 | unsigned int mem_hpa;		/* HPA of the boot-CPU */ | 
|  | 677 | /* int (*mem_pdc)(int, ...); */ | 
|  | 678 | unsigned int mem_pdc;		/* PDC entry point */ | 
|  | 679 | unsigned int mem_10msec;	/* number of clock ticks in 10msec */ | 
|  | 680 |  | 
|  | 681 | /* [0x390] initial memory module (IMM) */ | 
|  | 682 | /* struct iomod *imm_hpa; */ | 
|  | 683 | unsigned int imm_hpa;		/* HPA of the IMM */ | 
|  | 684 | int	imm_soft_boot;		/* 0 = was hard boot, 1 = was soft boot */ | 
|  | 685 | unsigned int	imm_spa_size;		/* SPA size of the IMM in bytes */ | 
|  | 686 | unsigned int	imm_max_mem;		/* bytes of mem in IMM */ | 
|  | 687 |  | 
|  | 688 | /* [0x3A0] boot console, display device and keyboard */ | 
|  | 689 | struct pz_device mem_cons;	/* description of console device */ | 
|  | 690 | struct pz_device mem_boot;	/* description of boot device */ | 
|  | 691 | struct pz_device mem_kbd;	/* description of keyboard device */ | 
|  | 692 |  | 
|  | 693 | /* [0x430] reserved */ | 
|  | 694 | int	pad430[116]; | 
|  | 695 |  | 
|  | 696 | /* [0x600] processor dependent */ | 
|  | 697 | __u32	pad600[1]; | 
|  | 698 | __u32	proc_sti;		/* pointer to STI ROM */ | 
|  | 699 | __u32	pad608[126]; | 
|  | 700 | }; | 
|  | 701 |  | 
|  | 702 | #endif /* __ASSEMBLY__ */ | 
|  | 703 |  | 
|  | 704 | /* Page Zero constant offsets used by the HPMC handler */ | 
|  | 705 |  | 
|  | 706 | #define BOOT_CONSOLE_HPA_OFFSET  0x3c0 | 
|  | 707 | #define BOOT_CONSOLE_SPA_OFFSET  0x3c4 | 
|  | 708 | #define BOOT_CONSOLE_PATH_OFFSET 0x3a8 | 
|  | 709 |  | 
|  | 710 | #ifndef __ASSEMBLY__ | 
|  | 711 | void pdc_console_init(void);	/* in pdc_console.c */ | 
|  | 712 | void pdc_console_restart(void); | 
|  | 713 |  | 
|  | 714 | void setup_pdc(void);		/* in inventory.c */ | 
|  | 715 |  | 
|  | 716 | /* wrapper-functions from pdc.c */ | 
|  | 717 |  | 
|  | 718 | int pdc_add_valid(unsigned long address); | 
|  | 719 | int pdc_chassis_info(struct pdc_chassis_info *chassis_info, void *led_info, unsigned long len); | 
|  | 720 | int pdc_chassis_disp(unsigned long disp); | 
| Thibaut Varene | 8ffaeaf | 2006-05-03 17:27:35 -0600 | [diff] [blame] | 721 | int pdc_chassis_warn(unsigned long *warn); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 722 | int pdc_coproc_cfg(struct pdc_coproc_cfg *pdc_coproc_info); | 
|  | 723 | int pdc_iodc_read(unsigned long *actcnt, unsigned long hpa, unsigned int index, | 
|  | 724 | void *iodc_data, unsigned int iodc_data_size); | 
|  | 725 | int pdc_system_map_find_mods(struct pdc_system_map_mod_info *pdc_mod_info, | 
|  | 726 | struct pdc_module_path *mod_path, long mod_index); | 
|  | 727 | int pdc_system_map_find_addrs(struct pdc_system_map_addr_info *pdc_addr_info, | 
|  | 728 | long mod_index, long addr_index); | 
|  | 729 | int pdc_model_info(struct pdc_model *model); | 
|  | 730 | int pdc_model_sysmodel(char *name); | 
|  | 731 | int pdc_model_cpuid(unsigned long *cpu_id); | 
|  | 732 | int pdc_model_versions(unsigned long *versions, int id); | 
|  | 733 | int pdc_model_capabilities(unsigned long *capabilities); | 
|  | 734 | int pdc_cache_info(struct pdc_cache_info *cache); | 
| Kyle McMartin | a9d2d38 | 2006-06-16 18:20:00 -0400 | [diff] [blame] | 735 | int pdc_spaceid_bits(unsigned long *space_bits); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 736 | #ifndef CONFIG_PA20 | 
|  | 737 | int pdc_btlb_info(struct pdc_btlb_info *btlb); | 
|  | 738 | int pdc_mem_map_hpa(struct pdc_memory_map *r_addr, struct pdc_module_path *mod_path); | 
|  | 739 | #endif /* !CONFIG_PA20 */ | 
|  | 740 | int pdc_lan_station_id(char *lan_addr, unsigned long net_hpa); | 
|  | 741 |  | 
|  | 742 | int pdc_stable_read(unsigned long staddr, void *memaddr, unsigned long count); | 
|  | 743 | int pdc_stable_write(unsigned long staddr, void *memaddr, unsigned long count); | 
|  | 744 | int pdc_stable_get_size(unsigned long *size); | 
|  | 745 | int pdc_stable_verify_contents(void); | 
|  | 746 | int pdc_stable_initialize(void); | 
|  | 747 |  | 
|  | 748 | int pdc_pci_irt_size(unsigned long *num_entries, unsigned long hpa); | 
|  | 749 | int pdc_pci_irt(unsigned long num_entries, unsigned long hpa, void *tbl); | 
|  | 750 |  | 
|  | 751 | int pdc_get_initiator(struct hardware_path *, struct pdc_initiator *); | 
|  | 752 | int pdc_tod_read(struct pdc_tod *tod); | 
|  | 753 | int pdc_tod_set(unsigned long sec, unsigned long usec); | 
|  | 754 |  | 
|  | 755 | #ifdef __LP64__ | 
|  | 756 | int pdc_mem_mem_table(struct pdc_memory_table_raddr *r_addr, | 
|  | 757 | struct pdc_memory_table *tbl, unsigned long entries); | 
|  | 758 | #endif | 
|  | 759 |  | 
|  | 760 | void set_firmware_width(void); | 
|  | 761 | int pdc_do_firm_test_reset(unsigned long ftc_bitmap); | 
|  | 762 | int pdc_do_reset(void); | 
|  | 763 | int pdc_soft_power_info(unsigned long *power_reg); | 
|  | 764 | int pdc_soft_power_button(int sw_control); | 
|  | 765 | void pdc_io_reset(void); | 
|  | 766 | void pdc_io_reset_devices(void); | 
|  | 767 | int pdc_iodc_getc(void); | 
|  | 768 | void pdc_iodc_putc(unsigned char c); | 
|  | 769 | void pdc_iodc_outc(unsigned char c); | 
|  | 770 | void pdc_printf(const char *fmt, ...); | 
|  | 771 |  | 
|  | 772 | void pdc_emergency_unlock(void); | 
|  | 773 | int pdc_sti_call(unsigned long func, unsigned long flags, | 
|  | 774 | unsigned long inptr, unsigned long outputr, | 
|  | 775 | unsigned long glob_cfg); | 
|  | 776 |  | 
| Kyle McMartin | c1a7a755 | 2006-06-26 11:28:09 -0400 | [diff] [blame] | 777 | static inline char * os_id_to_string(u16 os_id) { | 
|  | 778 | switch(os_id) { | 
|  | 779 | case OS_ID_NONE:	return "No OS"; | 
|  | 780 | case OS_ID_HPUX:	return "HP-UX"; | 
|  | 781 | case OS_ID_MPEXL:	return "MPE-iX"; | 
|  | 782 | case OS_ID_OSF:		return "OSF"; | 
|  | 783 | case OS_ID_HPRT:	return "HP-RT"; | 
|  | 784 | case OS_ID_NOVEL:	return "Novell Netware"; | 
|  | 785 | case OS_ID_LINUX:	return "Linux"; | 
|  | 786 | default:	return "Unknown"; | 
|  | 787 | } | 
|  | 788 | } | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 789 | #endif /* __ASSEMBLY__ */ | 
|  | 790 |  | 
|  | 791 | #endif /* _PARISC_PDC_H */ |