NetBSD/sys/dev/arcbios/arcbios.h
2008-04-28 20:22:51 +00:00

468 lines
13 KiB
C

/* $NetBSD: arcbios.h,v 1.12 2008/04/28 20:23:47 martin Exp $ */
/*-
* Copyright (c) 2001 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
* by Jason R. Thorpe.
*
* 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 NETBSD FOUNDATION, INC. 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 FOUNDATION 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.
*/
/*
* The ARC BIOS (which is similar, but not 100% compatible with SGI ARCS)
* specification can be found at:
*
* http://www.microsoft.com/hwdev/download/respec/riscspec.zip
*/
#ifndef _ARCBIOS_H_
#define _ARCBIOS_H_
#define ARCBIOS_STDIN 0
#define ARCBIOS_STDOUT 1
#define ARCBIOS_PAGESIZE 4096
/* ARC BIOS status codes. */
#define ARCBIOS_ESUCCESS 0 /* Success */
#define ARCBIOS_E2BIG 1 /* argument list too long */
#define ARCBIOS_EACCES 2 /* permission denied */
#define ARCBIOS_EAGAIN 3 /* resource temporarily unavailable */
#define ARCBIOS_EBADF 4 /* bad file number */
#define ARCBIOS_EBUSY 5 /* device or resource busy */
#define ARCBIOS_EFAULT 6 /* bad address */
#define ARCBIOS_EINVAL 7 /* invalid argument */
#define ARCBIOS_EIO 8 /* I/O error */
#define ARCBIOS_EISDIR 9 /* is a directory */
#define ARCBIOS_EMFILE 10 /* too many open files */
#define ARCBIOS_EMLINK 11 /* too many links */
#define ARCBIOS_ENAMETOOLONG 12 /* file name too long */
#define ARCBIOS_ENODEV 13 /* no such device */
#define ARCBIOS_ENOENT 14 /* no such file or directory */
#define ARCBIOS_ENOEXEC 15 /* exec format error */
#define ARCBIOS_ENOMEM 16 /* out of memory */
#define ARCBIOS_ENOSPC 17 /* no space left on device */
#define ARCBIOS_ENOTDIR 18 /* not a directory */
#define ARCBIOS_ENOTTY 19 /* not a typewriter */
#define ARCBIOS_ENXIO 20 /* media not loaded */
#define ARCBIOS_EROFS 21 /* read-only file system */
#if defined(sgimips)
#define ARCBIOS_EADDRNOTAVAIL 31 /* address not available */
#define ARCBIOS_ETIMEDOUT 32 /* operation timed out */
#define ARCBIOS_ECONNABORTED 33 /* connection aborted */
#define ARCBIOS_ENOCONNECT 34 /* not connected */
#endif /* sgimips */
/*
* 4.2.2: System Parameter Block
*/
struct arcbios_spb {
u_long SPBSignature;
u_long SPBLength;
uint16_t Version;
uint16_t Revision;
void *RestartBlock;
void *DebugBlock;
void *GEVector;
void *UTLBMissVector;
u_long FirmwareVectorLength;
void *FirmwareVector;
u_long PrivateVectorLength;
void *PrivateVector;
u_long AdapterCount;
u_long AdapterType;
u_long AdapterVectorLength;
void *AdapterVector;
};
#define ARCBIOS_SPB_SIGNATURE 0x53435241 /* A R C S */
#define ARCBIOS_SPB_SIGNATURE_1 0x41524353 /* S C R A */
/*
* 4.2.5: System Configuration Data
*/
struct arcbios_component {
uint32_t Class;
uint32_t Type;
uint32_t Flags;
uint16_t Version;
uint16_t Revision;
u_long Key;
u_long AffinityMask;
u_long ConfigurationDataSize;
u_long IdentifierLength;
char *Identifier;
};
/*
* SGI ARCS likes to be `special', so it moved some of the class/type
* numbers around from the ARC standard definitions.
*/
#if defined(sgimips)
/* Component Class */
#define COMPONENT_CLASS_SystemClass 0
#define COMPONENT_CLASS_ProcessorClass 1
#define COMPONENT_CLASS_CacheClass 2
#define COMPONENT_CLASS_MemoryClass 3
#define COMPONENT_CLASS_AdapterClass 4
#define COMPONENT_CLASS_ControllerClass 5
#define COMPONENT_CLASS_PeripheralClass 6
#else
/* Component Class */
#define COMPONENT_CLASS_SystemClass 0
#define COMPONENT_CLASS_ProcessorClass 1
#define COMPONENT_CLASS_CacheClass 2
#define COMPONENT_CLASS_AdapterClass 3
#define COMPONENT_CLASS_ControllerClass 4
#define COMPONENT_CLASS_PeripheralClass 5
#define COMPONENT_CLASS_MemoryClass 6
#endif
/* Component Types */
#if defined(sgimips)
/* System Class */
#define COMPONENT_TYPE_ARC 0
/* Processor Class */
#define COMPONENT_TYPE_CPU 1
#define COMPONENT_TYPE_FPU 2
/* Cache Class */
#define COMPONENT_TYPE_PrimaryICache 3
#define COMPONENT_TYPE_PrimaryDCache 4
#define COMPONENT_TYPE_SecondaryICache 5
#define COMPONENT_TYPE_SecondaryDCache 6
#define COMPONENT_TYPE_SecondaryCache 7
/* Memory Class */
#define COMPONENT_TYPE_MemoryUnit 8
/* Adapter Class */
#define COMPONENT_TYPE_EISAAdapter 9
#define COMPONENT_TYPE_TCAdapter 10
#define COMPONENT_TYPE_SCSIAdapter 11
#define COMPONENT_TYPE_DTIAdapter 12
#define COMPONENT_TYPE_MultiFunctionAdapter 13
/* Controller Class */
#define COMPONENT_TYPE_DiskController 14
#define COMPONENT_TYPE_TapeController 15
#define COMPONENT_TYPE_CDROMController 16
#define COMPONENT_TYPE_WORMController 17
#define COMPONENT_TYPE_SerialController 18
#define COMPONENT_TYPE_NetworkController 19
#define COMPONENT_TYPE_DisplayController 20
#define COMPONENT_TYPE_ParallelController 21
#define COMPONENT_TYPE_PointerController 22
#define COMPONENT_TYPE_KeyboardController 23
#define COMPONENT_TYPE_AudioController 24
#define COMPONENT_TYPE_OtherController 25
/* Peripheral Class */
#define COMPONENT_TYPE_DiskPeripheral 26
#define COMPONENT_TYPE_FloppyDiskPeripheral 27
#define COMPONENT_TYPE_TapePeripheral 28
#define COMPONENT_TYPE_ModemPeripheral 29
#define COMPONENT_TYPE_MonitorPeripheral 30
#define COMPONENT_TYPE_PrinterPeripheral 31
#define COMPONENT_TYPE_PointerPeripheral 32
#define COMPONENT_TYPE_KeyboardPeripheral 33
#define COMPONENT_TYPE_TerminalPeripheral 34
#define COMPONENT_TYPE_LinePeripheral 35
#define COMPONENT_TYPE_NetworkPeripheral 36
#define COMPONENT_TYPE_OtherPeripheral 37
#else /* not sgimips */
/* System Class */
#define COMPONENT_TYPE_ARC 0
/* Processor Class */
#define COMPONENT_TYPE_CPU 1
#define COMPONENT_TYPE_FPU 2
/* Cache Class */
#define COMPONENT_TYPE_PrimaryICache 3
#define COMPONENT_TYPE_PrimaryDCache 4
#define COMPONENT_TYPE_SecondaryICache 5
#define COMPONENT_TYPE_SecondaryDCache 6
#define COMPONENT_TYPE_SecondaryCache 7
/* Adapter Class */
#define COMPONENT_TYPE_EISAAdapter 8
#define COMPONENT_TYPE_TCAdapter 9
#define COMPONENT_TYPE_SCSIAdapter 10
#define COMPONENT_TYPE_DTIAdapter 11
#define COMPONENT_TYPE_MultiFunctionAdapter 12
/* Controller Class */
#define COMPONENT_TYPE_DiskController 13
#define COMPONENT_TYPE_TapeController 14
#define COMPONENT_TYPE_CDROMController 15
#define COMPONENT_TYPE_WORMController 16
#define COMPONENT_TYPE_SerialController 17
#define COMPONENT_TYPE_NetworkController 18
#define COMPONENT_TYPE_DisplayController 19
#define COMPONENT_TYPE_ParallelController 20
#define COMPONENT_TYPE_PointerController 21
#define COMPONENT_TYPE_KeyboardController 22
#define COMPONENT_TYPE_AudioController 23
#define COMPONENT_TYPE_OtherController 24
/* Peripheral Class */
#define COMPONENT_TYPE_DiskPeripheral 25
#define COMPONENT_TYPE_FloppyDiskPeripheral 26
#define COMPONENT_TYPE_TapePeripheral 27
#define COMPONENT_TYPE_ModemPeripheral 28
#define COMPONENT_TYPE_MonitorPeripheral 29
#define COMPONENT_TYPE_PrinterPeripheral 30
#define COMPONENT_TYPE_PointerPeripheral 31
#define COMPONENT_TYPE_KeyboardPeripheral 32
#define COMPONENT_TYPE_TerminalPeripheral 33
#define COMPONENT_TYPE_OtherPeripheral 34
#define COMPONENT_TYPE_LinePeripheral 35
#define COMPONENT_TYPE_NetworkPeripheral 36
/* Memory Class */
#define COMPONENT_TYPE_MemoryUnit 37
#endif
/* Component flags */
#define COMPONENT_FLAG_Failed 1
#define COMPONENT_FLAG_ReadOnly 2
#define COMPONENT_FLAG_Removable 4
#define COMPONENT_FLAG_ConsoleIn 8
#define COMPONENT_FLAG_ConsoleOut 16
#define COMPONENT_FLAG_Input 32
#define COMPONENT_FLAG_Output 64
/* Key for Cache: */
#define COMPONENT_KEY_Cache_CacheSize(x) \
(ARCBIOS_PAGESIZE << ((x) & 0xffff))
#define COMPONENT_KEY_Cache_LineSize(x) \
(1U << (((x) >> 16) & 0xff))
#define COMPONENT_KEY_Cache_RefillSize(x) \
(((x) >> 24) & 0xff)
/*
* ARC system ID
*/
#define ARCBIOS_SYSID_FIELDLEN 8
struct arcbios_sysid {
char VendorId[ARCBIOS_SYSID_FIELDLEN];
char ProductId[ARCBIOS_SYSID_FIELDLEN];
};
/*
* ARC memory descriptor
*/
struct arcbios_mem {
uint32_t Type;
u_long BasePage;
u_long PageCount;
};
#if defined(sgimips)
#define ARCBIOS_MEM_ExceptionBlock 0
#define ARCBIOS_MEM_SystemParameterBlock 1
#define ARCBIOS_MEM_FreeContiguous 2
#define ARCBIOS_MEM_FreeMemory 3
#define ARCBIOS_MEM_BadMemory 4
#define ARCBIOS_MEM_LoadedProgram 5
#define ARCBIOS_MEM_FirmwareTemporary 6
#define ARCBIOS_MEM_FirmwarePermanent 7
#elif defined(arc)
#define ARCBIOS_MEM_ExceptionBlock 0
#define ARCBIOS_MEM_SystemParameterBlock 1
#define ARCBIOS_MEM_FreeMemory 2
#define ARCBIOS_MEM_BadMemory 3
#define ARCBIOS_MEM_LoadedProgram 4
#define ARCBIOS_MEM_FirmwareTemporary 5
#define ARCBIOS_MEM_FirmwarePermanent 6
#define ARCBIOS_MEM_FreeContiguous 7
#endif
/*
* ARC display status
*/
struct arcbios_dsp_stat {
uint16_t CursorXPosition;
uint16_t CursorYPosition;
uint16_t CursorMaxXPosition;
uint16_t CursorMaxYPosition;
uint8_t ForegroundColor;
uint8_t BackgroundColor;
uint8_t HighIntensity;
uint8_t Underscored;
uint8_t ReverseVideo;
};
/*
* ARC firmware vector
*/
struct arcbios_fv {
long (*Load)(
char *, /* image to load */
u_long, /* top address */
u_long, /* entry address */
u_long *); /* low address */
long (*Invoke)(
u_long, /* entry address */
u_long, /* stack address */
u_long, /* argc */
char **, /* argv */
char **); /* envp */
long (*Execute)(
char *, /* image path */
u_long, /* argc */
char **, /* argv */
char **); /* envp */
void (*Halt)(void)
__dead;
void (*PowerDown)(void)
__dead;
void (*Restart)(void)
__dead;
void (*Reboot)(void)
__dead;
void (*EnterInteractiveMode)(void)
__dead;
#if defined(sgimips)
void *reserved0;
#else
void (*ReturnFromMain)(void)
__dead;
#endif
void *(*GetPeer)(
void *); /* component */
void *(*GetChild)(
void *); /* component */
void *(*GetParent)(
void *); /* component */
long (*GetConfigurationData)(
void *, /* configuration data */
void *); /* component */
void *(*AddChild)(
void *, /* component */
void *); /* new component */
long (*DeleteComponent)(
void *); /* component */
void *(*GetComponent)(
char *); /* path */
long (*SaveConfiguration)(void);
void *(*GetSystemId)(void);
void *(*GetMemoryDescriptor)(
void *); /* memory descriptor */
#if defined(sgimips)
void *reserved1;
#else
void (*Signal)(
u_long, /* signal number */
void *); /* handler */
#endif
void *(*GetTime)(void);
u_long (*GetRelativeTime)(void);
long (*GetDirectoryEntry)(
u_long, /* file ID */
void *, /* directory entry */
u_long, /* length */
u_long *); /* count */
long (*Open)(
char *, /* path */
u_long, /* open mode */
u_long *); /* file ID */
long (*Close)(
u_long); /* file ID */
long (*Read)(
u_long, /* file ID */
void *, /* buffer */
u_long, /* length */
u_long *); /* count */
long (*GetReadStatus)(
u_long); /* file ID */
long (*Write)(
u_long, /* file ID */
void *, /* buffer */
u_long, /* length */
u_long *); /* count */
long (*Seek)(
u_long, /* file ID */
int64_t *, /* offset */
u_long); /* whence */
long (*Mount)(
char *, /* path */
u_long); /* operation */
const char *(*GetEnvironmentVariable)(
const char *); /* variable */
long (*SetEnvironmentVariable)(
const char *, /* variable */
const char *); /* contents */
long (*GetFileInformation)(
u_long, /* file ID */
void *); /* XXX */
long (*SetFileInformation)(
u_long, /* file ID */
u_long, /* XXX */
u_long); /* XXX */
void (*FlushAllCaches)(void);
#if !defined(sgimips)
paddr_t (*TestUnicode)(
u_long, /* file ID */
uint16_t); /* unicode character */
void *(*GetDisplayStatus)(
u_long); /* file ID */
#endif
};
#endif /* _ARCBIOS_H_ */