ba7cbe760f
These sources are ported from FreeBSD/ia64 code. See individual source files for credits. In addition, code from NetBSD/alpha NetBSD/sparc64, NetBSD/i386 and NetBSD/amd64 were used as templates, along with my own additions.
145 lines
4.1 KiB
C
145 lines
4.1 KiB
C
/* $NetBSD: sal.h,v 1.1 2006/04/07 14:21:18 cherry Exp $ */
|
|
|
|
/*-
|
|
* Copyright (c) 2001 Doug Rabson
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
#ifndef _MACHINE_SAL_H_
|
|
#define _MACHINE_SAL_H_
|
|
|
|
struct sal_system_table {
|
|
char sal_signature[4];
|
|
#define SAL_SIGNATURE "SST_"
|
|
u_int32_t sal_length;
|
|
u_int8_t sal_rev[2];
|
|
u_int16_t sal_entry_count;
|
|
u_int8_t sal_checksum;
|
|
u_int8_t sal_reserved1[7];
|
|
u_int8_t sal_a_version[2];
|
|
u_int8_t sal_b_version[2];
|
|
char sal_oem_id[32];
|
|
char sal_product_id[32];
|
|
u_int8_t sal_reserved2[8];
|
|
};
|
|
|
|
struct sal_entrypoint_descriptor {
|
|
u_int8_t sale_type; /* == 0 */
|
|
u_int8_t sale_reserved1[7];
|
|
u_int64_t sale_pal_proc;
|
|
u_int64_t sale_sal_proc;
|
|
u_int64_t sale_sal_gp;
|
|
u_int8_t sale_reserved2[16];
|
|
};
|
|
|
|
struct sal_memory_descriptor {
|
|
u_int8_t sale_type; /* == 1 */
|
|
u_int8_t sale_need_virtual;
|
|
u_int8_t sale_current_attribute;
|
|
u_int8_t sale_access_rights;
|
|
u_int8_t sale_supported_attributes;
|
|
u_int8_t sale_reserved1;
|
|
u_int8_t sale_memory_type[2];
|
|
u_int64_t sale_physical_address;
|
|
u_int32_t sale_length;
|
|
u_int8_t sale_reserved2[12];
|
|
};
|
|
|
|
struct sal_platform_descriptor {
|
|
u_int8_t sale_type; /* == 2 */
|
|
u_int8_t sale_features;
|
|
u_int8_t sale_reserved[14];
|
|
};
|
|
|
|
struct sal_tr_descriptor {
|
|
u_int8_t sale_type; /* == 3 */
|
|
u_int8_t sale_register_type;
|
|
u_int8_t sale_register_number;
|
|
u_int8_t sale_reserved1[5];
|
|
u_int64_t sale_virtual_address;
|
|
u_int64_t sale_page_size;
|
|
u_int8_t sale_reserved2[8];
|
|
};
|
|
|
|
struct sal_ptc_cache_descriptor {
|
|
u_int8_t sale_type; /* == 4 */
|
|
u_int8_t sale_reserved[3];
|
|
u_int32_t sale_domains;
|
|
u_int64_t sale_address;
|
|
};
|
|
|
|
struct sal_ap_wakeup_descriptor {
|
|
u_int8_t sale_type; /* == 5 */
|
|
u_int8_t sale_mechanism;
|
|
u_int8_t sale_reserved[6];
|
|
u_int64_t sale_vector;
|
|
};
|
|
|
|
/*
|
|
* SAL Procedure numbers.
|
|
*/
|
|
|
|
#define SAL_SET_VECTORS 0x01000000
|
|
#define SAL_GET_STATE_INFO 0x01000001
|
|
#define SAL_GET_STATE_INFO_SIZE 0x01000002
|
|
#define SAL_CLEAR_STATE_INFO 0x01000003
|
|
#define SAL_MC_RENDEZ 0x01000004
|
|
#define SAL_MC_SET_PARAMS 0x01000005
|
|
#define SAL_REGISTER_PHYSICAL_ADDR 0x01000006
|
|
#define SAL_CACHE_FLUSH 0x01000008
|
|
#define SAL_CACHE_INIT 0x01000009
|
|
#define SAL_PCI_CONFIG_READ 0x01000010
|
|
#define SAL_PCI_CONFIG_WRITE 0x01000011
|
|
#define SAL_FREQ_BASE 0x01000012
|
|
#define SAL_UPDATE_PAL 0x01000020
|
|
|
|
/* SAL_SET_VECTORS event handler types */
|
|
#define SAL_OS_MCA 0
|
|
#define SAL_OS_INIT 1
|
|
#define SAL_OS_BOOT_RENDEZ 2
|
|
|
|
/* SAL_GET_STATE_INFO, SAL_GET_STATE_INFO_SIZE types */
|
|
#define SAL_INFO_MCA 0
|
|
#define SAL_INFO_INIT 1
|
|
#define SAL_INFO_CMC 2
|
|
#define SAL_INFO_CPE 3
|
|
#define SAL_INFO_TYPES 4 /* number of types we know about */
|
|
|
|
struct ia64_sal_result {
|
|
int64_t sal_status;
|
|
u_int64_t sal_result[3];
|
|
};
|
|
|
|
typedef struct ia64_sal_result sal_entry_t
|
|
(u_int64_t, u_int64_t, u_int64_t, u_int64_t,
|
|
u_int64_t, u_int64_t, u_int64_t, u_int64_t);
|
|
|
|
extern sal_entry_t *ia64_sal_entry;
|
|
|
|
extern void ia64_sal_init(void);
|
|
|
|
#endif /* _MACHINE_SAL_H_ */
|