diff options
author | Visa Hankala <visa@cvs.openbsd.org> | 2021-05-01 16:11:18 +0000 |
---|---|---|
committer | Visa Hankala <visa@cvs.openbsd.org> | 2021-05-01 16:11:18 +0000 |
commit | 58b3d2ba77817cf3ac54cf921bf87b95844589c4 (patch) | |
tree | 8d0e4f6d500b406f61850688259f6ae7ae3c77c9 /sys/arch | |
parent | 2c481e94e93c02c0c859d4f32d311d2e71b82054 (diff) |
Retire OpenBSD/sgi.
OK deraadt@
Diffstat (limited to 'sys/arch')
274 files changed, 28 insertions, 60059 deletions
diff --git a/sys/arch/mips64/conf/files.mips64 b/sys/arch/mips64/conf/files.mips64 index 8460a512a28..3744519e0dc 100644 --- a/sys/arch/mips64/conf/files.mips64 +++ b/sys/arch/mips64/conf/files.mips64 @@ -1,6 +1,5 @@ -# $OpenBSD: files.mips64,v 1.29 2018/01/25 15:06:29 mpi Exp $ +# $OpenBSD: files.mips64,v 1.30 2021/05/01 16:11:10 visa Exp $ -file arch/mips64/mips64/arcbios.c arcbios file arch/mips64/mips64/clock.c clock file arch/mips64/mips64/cpu.c file arch/mips64/mips64/interrupt.c @@ -18,22 +17,14 @@ file arch/mips64/mips64/cache_loongson2.c cpu_loongson2 file arch/mips64/mips64/cache_loongson3.c cpu_loongson3 file arch/mips64/mips64/cache_mips64r2.c cpu_mips64r2 file arch/mips64/mips64/cache_octeon.c cpu_octeon -file arch/mips64/mips64/cache_r4k.c cpu_r4000 -file arch/mips64/mips64/cache_r5k.c cpu_r5000 | cpu_rm7000 -file arch/mips64/mips64/cache_r10k.c cpu_r10000 -file arch/mips64/mips64/cache_tfp.c cpu_r8000 -file arch/mips64/mips64/cache_tfp_subr.S cpu_r8000 file arch/mips64/mips64/context.S file arch/mips64/mips64/cp0access.S -file arch/mips64/mips64/exception.S !cpu_r8000 -file arch/mips64/mips64/exception_tfp.S cpu_r8000 +file arch/mips64/mips64/exception.S file arch/mips64/mips64/fp_emulate.c file arch/mips64/mips64/lcore_access.S file arch/mips64/mips64/lcore_float.S file arch/mips64/mips64/mips64r2.S cpu_mips64r2 -file arch/mips64/mips64/r4000_errata.c cpu_r4000 -file arch/mips64/mips64/tlbhandler.S !cpu_r8000 -file arch/mips64/mips64/tlb_tfp.S cpu_r8000 +file arch/mips64/mips64/tlbhandler.S file arch/mips64/mips64/db_disasm.c ddb file arch/mips64/mips64/db_machdep.c ddb diff --git a/sys/arch/mips64/include/arcbios.h b/sys/arch/mips64/include/arcbios.h deleted file mode 100644 index e97b67564f2..00000000000 --- a/sys/arch/mips64/include/arcbios.h +++ /dev/null @@ -1,488 +0,0 @@ -/* $OpenBSD: arcbios.h,v 1.25 2015/02/06 22:11:49 miod Exp $ */ -/*- - * Copyright (c) 1996 M. Warner Losh. 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. - * 3. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - */ - -#include <sys/types.h> - -typedef struct arc_sid -{ - char vendor[8]; - char prodid[8]; -} arc_sid_t; - -typedef enum arc_config_class -{ - arc_SystemClass, - arc_ProcessorClass, - arc_CacheClass, -#ifdef __sgi__ - arc_MemoryClass, -#endif - arc_AdapterClass, - arc_ControllerClass, - arc_PeripheralClass, -#ifdef __arc__ - arc_MemoryClass -#endif -} arc_config_class_t; - -typedef enum arc_config_type -{ - arc_System, - - arc_CentralProcessor, - arc_FloatingPointProcessor, - - arc_PrimaryIcache, - arc_PrimaryDcache, - arc_SecondaryIcache, - arc_SecondaryDcache, - arc_SecondaryCache, - -#ifdef __sgi__ - arc_SystemMemory, -#endif - - arc_EisaAdapter, /* Eisa adapter */ - arc_TcAdapter, /* Turbochannel adapter */ - arc_ScsiAdapter, /* SCSI adapter */ - arc_DtiAdapter, /* AccessBus adapter */ - arc_MultiFunctionAdapter, - - arc_DiskController, - arc_TapeController, - arc_CdromController, - arc_WormController, - arc_SerialController, - arc_NetworkController, - arc_DisplayController, - arc_ParallelController, - arc_PointerController, - arc_KeyboardController, - arc_AudioController, - arc_OtherController, /* denotes a controller not otherwise defined */ - - arc_DiskPeripheral, - arc_FloppyDiskPeripheral, - arc_TapePeripheral, - arc_ModemPeripheral, - arc_MonitorPeripheral, - arc_PrinterPeripheral, - arc_PointerPeripheral, - arc_KeyboardPeripheral, - arc_TerminalPeripheral, -#ifdef __arc__ - arc_OtherPeripheral, /* denotes a peripheral not otherwise defined */ -#endif - arc_LinePeripheral, - arc_NetworkPeripheral, -#ifdef __arc__ - arc_SystemMemory, -#endif -#ifdef __sgi__ - arc_OtherPeripheral, /* denotes a peripheral not otherwise defined */ -#endif -} arc_config_type_t; - -typedef u_int32_t arc_dev_flags_t; - -#define ARCBIOS_DEVFLAGS_FAILED 0x01 -#define ARCBIOS_DEVFLAGS_READONLY 0x02 -#define ARCBIOS_DEVFLAGS_REMOVABLE 0x04 -#define ARCBIOS_DEVFLAGS_CONSOLE_INPUT 0x08 -#define ARCBIOS_DEVFLAGS_CONSOLE_OUTPUT 0x10 -#define ARCBIOS_DEVFLAGS_INPUT 0x20 -#define ARCBIOS_DEVFLAGS_OUTPUT 0x40 - -typedef struct arc_config -{ - arc_config_class_t class; - arc_config_type_t type; - arc_dev_flags_t flags; - u_int16_t version; - u_int16_t revision; - u_int32_t key; - u_int32_t affinity_mask; - u_int32_t config_data_len; - u_int32_t id_len; - int32_t id; -} arc_config_t; - -typedef struct arc_config64 -{ - arc_config_class_t class; - arc_config_type_t type; - arc_dev_flags_t flags; - u_int16_t version; - u_int16_t revision; - u_int64_t key; - u_int64_t affinity_mask; - u_int64_t config_data_len; - u_int64_t id_len; - int64_t id; -} arc_config64_t; - -typedef enum arc_status -{ - arc_ESUCCESS, /* Success */ - arc_E2BIG, /* Arg list too long */ - arc_EACCES, /* No such file or directory */ - arc_EAGAIN, /* Try again */ - arc_EBADF, /* Bad file number */ - arc_EBUSY, /* Device or resource busy */ - arc_EFAULT, /* Bad address */ - arc_EINVAL, /* Invalid argument */ - arc_EIO, /* I/O error */ - arc_EISDIR, /* Is a directory */ - arc_EMFILE, /* Too many open files */ - arc_EMLINK, /* Too many links */ - arc_ENAMETOOLONG, /* File name too long */ - arc_ENODEV, /* No such device */ - arc_ENOENT, /* No such file or directory */ - arc_ENOEXEC, /* Exec format error */ - arc_ENOMEM, /* Out of memory */ - arc_ENOSPC, /* No space left on device */ - arc_ENOTDIR, /* Not a directory */ - arc_ENOTTY, /* Not a typewriter */ - arc_ENXIO, /* No such device or address */ - arc_EROFS, /* Read-only file system */ -} arc_status_t; - -/* - * Oops! Arc systems and SGI's have different order of types. - */ -#ifdef __arc__ -typedef enum { - ExceptionBlock, SystemParameterBlock, FreeMemory, - BadMemory, LoadedProgram, FirmwareTemporary, - FirmwarePermanent, FreeContigous -} MEMORYTYPE; -#endif - -#ifdef __sgi__ -typedef enum { - ExceptionBlock, SystemParameterBlock, FreeContigous, - FreeMemory, BadMemory, LoadedProgram, - FirmwareTemporary, FirmwarePermanent, -} MEMORYTYPE; -#endif - -typedef struct arc_mem { - MEMORYTYPE Type; /* Memory chunk type */ - u_int32_t BasePage; /* Page no, first page */ - u_int32_t PageCount; /* Number of pages */ -} arc_mem_t; - -typedef struct arc_mem64 { - MEMORYTYPE Type; /* Memory chunk type */ - u_int64_t BasePage; /* Page no, first page */ - u_int64_t PageCount; /* Number of pages */ -} arc_mem64_t; - -typedef struct arc_time { - u_int16_t Year; - u_int16_t Month; - u_int16_t Day; - u_int16_t Hour; - u_int16_t Minutes; - u_int16_t Seconds; - u_int16_t Milliseconds; -} arc_time_t; - -typedef struct arc_dsp_stat { - u_int16_t CursorXPosition; - u_int16_t CursorYPosition; - u_int16_t CursorMaxXPosition; - u_int16_t CursorMaxYPosition; - u_char ForegroundColor; - u_char BackgroundColor; - u_char HighIntensity; - u_char Underscored; - u_char ReverseVideo; -} arc_dsp_stat_t; - -typedef caddr_t arc_dirent_t; /* XXX */ -typedef u_int32_t arc_open_mode_t; /* XXX */ -typedef u_int32_t arc_seek_mode_t; /* XXX */ -typedef u_int32_t arc_mount_t; /* XXX */ - -typedef struct arc_quad { -#ifdef __MIPSEB__ - long hi; - u_long lo; -#else - u_long lo; - long hi; -#endif -} arc_quad_t; - -typedef struct arc_calls -{ - arc_status_t (*load)( /* Load 1 */ - char *, /* Image to load */ - u_long, /* top address */ - u_long *, /* Entry address */ - u_long *); /* Low address */ - - arc_status_t (*invoke)( /* Invoke 2 */ - u_long, /* Entry Address */ - u_long, /* Stack Address */ - u_long, /* Argc */ - char **, /* argv */ - char **); /* envp */ - - arc_status_t (*execute)( /* Execute 3 */ - char *, /* Image path */ - u_long, /* Argc */ - char **, /* argv */ - char **); /* envp */ - - __dead void (*halt)(void); /* Halt 4 */ - - __dead void (*power_down)(void); /* PowerDown 5 */ - - __dead void (*restart)(void); /* Restart 6 */ - - __dead void (*reboot)(void); /* Reboot 7 */ - - __dead void (*enter_interactive_mode)(void); /* EnterInteractiveMode 8 */ - - __dead void (*return_from_main)(void); /* ReturnFromMain 9 */ - - arc_config_t *(*get_peer)( /* GetPeer 10 */ - arc_config_t *); /* Component */ - - arc_config_t *(*get_child)( /* GetChild 11 */ - arc_config_t *); /* Component */ - - arc_config_t *(*get_parent)( /* GetParent 12 */ - arc_config_t *); /* Component */ - - arc_status_t (*get_config_data)( /* GetConfigurationData 13 */ - caddr_t, /* Configuration Data */ - arc_config_t *); /* Component */ - - arc_config_t *(*add_child)( /* AddChild 14 */ - arc_config_t *, /* Component */ - arc_config_t *); /* New Component */ - - arc_status_t (*delete_component)( /* DeleteComponent 15 */ - arc_config_t *); /* Component */ - - arc_config_t *(*get_component)( /* GetComponent 16 */ - char *); /* Path */ - - arc_status_t (*save_config)(void); /* SaveConfiguration 17 */ - - arc_sid_t *(*get_system_id)(void); /* GetSystemId 18 */ - - arc_mem_t *(*get_memory_descriptor)( /* GetMemoryDescriptor 19 */ - arc_mem_t *); /* MemoryDescriptor */ - -#ifdef __arc__ - void (*signal)( /* Signal 20 */ - u_int32_t, /* Signal number */ -/**/ caddr_t); /* Handler */ -#else - void *unused; -#endif - - arc_time_t *(*get_time)(void); /* GetTime 21 */ - - u_long (*get_relative_time)(void); /* GetRelativeTime 22 */ - - arc_status_t (*get_dir_entry)( /* GetDirectoryEntry 23 */ - u_long, /* FileId */ - arc_dirent_t *, /* Directory entry */ - u_long, /* Length */ - u_long *); /* Count */ - - arc_status_t (*open)( /* Open 24 */ - char *, /* Path */ - arc_open_mode_t, /* Open mode */ - u_long *); /* FileId */ - - arc_status_t (*close)( /* Close 25 */ - u_long); /* FileId */ - - arc_status_t (*read)( /* Read 26 */ - u_long, /* FileId */ - caddr_t, /* Buffer */ - u_long, /* Length */ - u_long *); /* Count */ - - arc_status_t (*get_read_status)( /* GetReadStatus 27 */ - u_long); /* FileId */ - - arc_status_t (*write)( /* Write 28 */ - u_long, /* FileId */ - caddr_t, /* Buffer */ - u_long, /* Length */ - u_long *); /* Count */ - - arc_status_t (*seek)( /* Seek 29 */ - u_long, /* FileId */ - arc_quad_t *, /* Offset */ - arc_seek_mode_t); /* Mode */ - - arc_status_t (*mount)( /* Mount 30 */ - char *, /* Path */ - arc_mount_t); /* Operation */ - - char *(*getenv)( /* GetEnvironmentVariable 31 */ - char *); /* Variable */ - - arc_status_t (*putenv)( /* SetEnvironmentVariable 32 */ - char *, /* Variable */ - char *); /* Value */ - - arc_status_t (*get_file_info)(void); /* GetFileInformation 33 */ - - arc_status_t (*set_file_info)(void); /* SetFileInformation 34 */ - - void (*flush_all_caches)(void); /* FlushAllCaches 35 */ - -#ifdef __arc__ - arc_status_t (*test_unicode)( /* TestUnicodeCharacter 36 */ - u_int32_t, /* FileId */ - u_int16_t); /* UnicodeCharacter */ - - arc_dsp_stat_t *(*get_display_status)( /* GetDisplayStatus 37 */ - u_int32_t); /* FileId */ -#endif -} arc_calls_t; - -#define ARC_PARAM_BLK_MAGIC 0x53435241 -#define ARC_PARAM_BLK_MAGIC_BUG 0x41524353 /* This is wrong... but req */ - -typedef struct arc_param_blk_32 -{ - u_int32_t magic; /* Magic Number */ - u_int32_t length; /* Length of parameter block */ - u_int16_t version; /* ?? */ - u_int16_t revision; /* ?? */ - int32_t restart_block; /* ?? */ - int32_t debug_block; /* Debugging info -- unused */ - int32_t general_exp_vect; /* ?? */ - int32_t tlb_miss_exp_vect; /* ?? */ - u_int32_t firmware_length; /* Size of Firmware jumptable in bytes */ - int32_t firmware_vect; /* Firmware jumptable */ - int32_t vendor_length; /* Size of Vendor specific jumptable */ - u_int32_t vendor_vect; /* Vendor specific jumptable */ - u_int32_t adapter_count; /* ?? */ - u_int32_t adapter0_type; /* ?? */ - u_int32_t adapter0_length; /* ?? */ - int32_t adapter0_vect; /* ?? */ -} arc_param_blk_32_t; - -typedef struct arc_param_blk_64 -{ - u_int64_t magic; /* Magic Number */ - u_int64_t length; /* Length of parameter block */ - u_int16_t version; /* ?? */ - u_int16_t revision; /* ?? */ - int64_t restart_block; /* ?? */ - int64_t debug_block; /* Debugging info -- unused */ - int64_t general_exp_vect; /* ?? */ - int64_t tlb_miss_exp_vect; /* ?? */ - u_int64_t firmware_length; /* Size of Firmware jumptable in bytes */ - int64_t firmware_vect; /* Firmware jumptable */ - u_int64_t vendor_length; /* Size of Vendor specific jumptable */ - int64_t vendor_vect; /* Vendor specific jumptable */ - u_int64_t adapter_count; /* ?? */ - u_int64_t adapter0_type; /* ?? */ - u_int64_t adapter0_length; /* ?? */ - int64_t adapter0_vect; /* ?? */ -} arc_param_blk_64_t; - -#define ARCBIOS_BASE 0x0000001000 /* physical */ -extern void *bios_base; -#define ArcBiosBase32 ((arc_param_blk_32_t *)bios_base) -#define ArcBiosBase64 ((arc_param_blk_64_t *)bios_base) - -#define ARCBIOS_PAGE_SIZE 4096 - -extern int bios_is_32bit; -extern int bios_consrate; -extern char bios_enaddr[20]; -extern char bios_console[30]; -extern char bios_graphics[6]; -extern char bios_keyboard[6]; - -extern void (*bios_halt)(void); -extern void (*bios_powerdown)(void); -extern void (*bios_restart)(void); -extern void (*bios_reboot)(void); -extern void (*bios_eim)(void); - -int bios_getchar(void); -void bios_putchar(char); -void bios_putstring(char *); -void bios_printf(const char *, ...) - __attribute__((__format__(__kprintf__,1,2))); -void bios_ident(void); -void bios_display_info(int *, int *, int *, int *); - -/* - * Direct ARC-BIOS calls. - */ -long Bios_Load(char *, u_long, u_long, u_long *); -long Bios_Invoke(u_long, u_long, u_long, char **, char **); -long Bios_Execute(char *, u_long, char **, char **); -void Bios_Halt(void); -void Bios_PowerDown(void); -void Bios_Restart(void); -void Bios_Reboot(void); -void Bios_EnterInteractiveMode(void); -long Bios_GetPeer(void *); -arc_config_t *Bios_GetChild(void *); -long Bios_GetParent(void *); -long Bios_GetConfigurationData(void *, void *); -long Bios_AddChild(void *, void *); -long Bios_DeleteComponent(void *); -long Bios_GetComponent(char *); -long Bios_SaveConfiguration(void); -arc_sid_t *Bios_GetSystemId(void); -arc_mem_t *Bios_GetMemoryDescriptor(void *); -arc_time_t *Bios_GetTime(void); -long Bios_GetRelativeTime(void); -long Bios_GetDirectoryEntry(u_long, void *, u_long, u_long *); -long Bios_Open(char *, int, long *); -long Bios_Close(long); -long Bios_Read(long, char *, long, long *); -long Bios_GetReadStatus(u_long); -long Bios_Write(long, char *, long, long *); -long Bios_Seek(long, arc_quad_t *, int); -long Bios_Mount(char *, void *); -char *Bios_GetEnvironmentVariable(const char *); -long Bios_SetEnvironmentVariable(char *, char *); -long Bios_GetFileInformation(u_long, u_long, u_long); -long Bios_SetFileInformation(u_long, u_long, u_long); -void Bios_FlushAllCaches(void); -long Bios_TestUnicodeCharacter(u_long, u_int16_t); -arc_dsp_stat_t *Bios_GetDisplayStatus(u_long); diff --git a/sys/arch/mips64/include/asm.h b/sys/arch/mips64/include/asm.h index 1c06f645a4b..b3c86e4b2d1 100644 --- a/sys/arch/mips64/include/asm.h +++ b/sys/arch/mips64/include/asm.h @@ -1,4 +1,4 @@ -/* $OpenBSD: asm.h,v 1.26 2021/03/11 11:16:59 jsg Exp $ */ +/* $OpenBSD: asm.h,v 1.27 2021/05/01 16:11:10 visa Exp $ */ /* * Copyright (c) 2001-2002 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -178,29 +178,12 @@ #define PTR_VAL .dword #endif -/* - * The following macros are here to benefit the R8000 processor: - * - all coprocessor 0 control registers are 64-bit - * - the regular nop (sll zero, zero, 0) has the drawback of using the - * shifter, potentially breaking instruction dispatch if occurring after - * another instruction using the shifter. - */ -#ifdef CPU_R8000 -#define SSNOP sll zero, zero, 1 /* ``ssnop'' */ -#define NOP PTR_ADDU zero, zero, zero /* real nop for R8000 */ -#define DMFC0 SSNOP; dmfc0 -#define DMTC0 SSNOP; dmtc0 -#define MFC0 SSNOP; dmfc0 -#define MTC0 SSNOP; dmtc0 -#define ERET eret; mul k0, k0; mflo k0 -#else #define NOP nop #define DMFC0 dmfc0 #define DMTC0 dmtc0 #define MFC0 mfc0 #define MTC0 mtc0 #define ERET sync; eret -#endif /* * Define -pg profile entry code. @@ -347,36 +330,6 @@ x: ; \ #define TLB_HAZARD /* nothing */ #endif -#ifdef CPU_RM7000 -/* - * Due to a flaw in RM7000 1.x processors a pipeline 'drain' is - * required after some mtc0 instructions. - * Ten nops in sequence does the trick. - */ -#define MTC0_HAZARD NOP;NOP;NOP;NOP;NOP;NOP;NOP;NOP;NOP;NOP -#define MTC0_SR_IE_HAZARD MTC0_HAZARD -/* - * The RM7000 needs twice as much nops around tlb* instructions. - */ -#define TLB_HAZARD NOP; NOP; NOP; NOP -#endif - -#ifdef CPU_R8000 -/* - * The R8000 needs a lot of care inserting proper superscalar dispatch breaks - * to prevent unwanted side-effects or avoid collisions on the internal MiscBus - * and the E and W stages of the pipelines. - * - * The following settings are a bit pessimistic, but better run safely than - * not at all. - */ -#define PRE_MFC0_ADDR_HAZARD .align 5; SSNOP -#define MFC0_HAZARD SSNOP -#define MTC0_HAZARD SSNOP; SSNOP; SSNOP; SSNOP -#define MTC0_SR_IE_HAZARD MTC0_HAZARD -#define MTC0_SR_CU_HAZARD MTC0_HAZARD -#endif - /* Hazard between {d,}mfc0 of COP_0_VADDR */ #ifndef PRE_MFC0_ADDR_HAZARD #define PRE_MFC0_ADDR_HAZARD /* nothing */ diff --git a/sys/arch/mips64/include/cpu.h b/sys/arch/mips64/include/cpu.h index c1ab42880e1..ef06ab024fd 100644 --- a/sys/arch/mips64/include/cpu.h +++ b/sys/arch/mips64/include/cpu.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.h,v 1.130 2020/07/11 15:18:08 visa Exp $ */ +/* $OpenBSD: cpu.h,v 1.131 2021/05/01 16:11:10 visa Exp $ */ /*- * Copyright (c) 1992, 1993 @@ -89,28 +89,14 @@ #define CCA_CACHED CCA_NONCOHERENT #endif -/* - * Uncached spaces. - * R1x000 processors use bits 58:57 of uncached virtual addresses (CCA_NC) - * to select different spaces. Unfortunately, other processors need these - * bits to be zero, so uncached address have to be decided at runtime. - */ -#define SP_HUB 0UL /* Hub space */ -#define SP_IO 1UL /* I/O space */ -#define SP_SPECIAL 2UL /* Memory Special space */ -#define SP_NC 3UL /* Memory Uncached space */ - #define XKSSSEG_BASE 0x4000000000000000UL #define XKPHYS_BASE 0x8000000000000000UL #define XKSSEG_BASE 0xc000000000000000UL #define XKPHYS_TO_PHYS(x) ((paddr_t)(x) & 0x0000000fffffffffUL) #define PHYS_TO_XKPHYS(x,c) ((paddr_t)(x) | XKPHYS_BASE | ((c) << 59)) -#define PHYS_TO_XKPHYS_UNCACHED(x,s) \ - (PHYS_TO_XKPHYS(x, CCA_NC) | ((s) << 57)) #define IS_XKPHYS(va) (((va) >> 62) == 2) #define XKPHYS_TO_CCA(x) (((x) >> 59) & 0x07) -#define XKPHYS_TO_SP(x) (((x) >> 57) & 0x03) #endif /* _LOCORE */ @@ -320,12 +306,7 @@ void signotify(struct proc *); #define aston(p) ((p)->p_md.md_astpending = 1) -#ifdef CPU_R8000 -#define mips_sync() __asm__ volatile ("lw $0, 0(%0)" :: \ - "r" (PHYS_TO_XKPHYS(0, CCA_NC)) : "memory") -#else #define mips_sync() __asm__ volatile ("sync" ::: "memory") -#endif #endif /* _KERNEL && !_LOCORE */ @@ -465,17 +446,6 @@ int classify_insn(uint32_t); #define INSNCLASS_BRANCH 2 /* - * R4000 end-of-page errata workaround routines - */ - -extern int r4000_errata; -u_int eop_page_check(paddr_t); -void eop_tlb_flush_addr(struct pmap *, vaddr_t, u_long); -int eop_tlb_miss_handler(struct trapframe *, struct cpu_info *, - struct proc *); -void eop_cleanup(struct trapframe *, struct proc *); - -/* * Low level access routines to CPU registers */ diff --git a/sys/arch/mips64/include/mips_cpu.h b/sys/arch/mips64/include/mips_cpu.h index f0e49d6e9f9..9e3522b38f6 100644 --- a/sys/arch/mips64/include/mips_cpu.h +++ b/sys/arch/mips64/include/mips_cpu.h @@ -1,4 +1,4 @@ -/* $OpenBSD: mips_cpu.h,v 1.9 2020/07/18 08:37:43 visa Exp $ */ +/* $OpenBSD: mips_cpu.h,v 1.10 2021/05/01 16:11:11 visa Exp $ */ /*- * Copyright (c) 1992, 1993 @@ -81,70 +81,26 @@ #define SR_INT_MASK_4 0x00004000 #define SR_INT_MASK_5 0x00008000 -/* R8000-specific bits */ -#define SR_SERIALIZE_FPU 0x0000010000000000 -#define SR_KPGSZ_SHIFT 36 -#define SR_UPGSZ_SHIFT 32 -#define SR_PGSZ_4K 0 -#define SR_PGSZ_8K 1 -#define SR_PGSZ_16K 2 -#define SR_PGSZ_64K 3 -#define SR_PGSZ_1M 4 -#define SR_PGSZ_4M 5 -#define SR_PGSZ_16M 6 -#define SR_PGSZ_MASK 0x0f - -#define SR_INT_MASK_6 0x00010000 -#define SR_INT_MASK_7 0x00020000 -#define SR_INT_MASK_8 0x00040000 - -#ifdef CPU_R8000 -#define SR_XX 0x00000040 -#define SR_KSU_MASK 0x00000010 -#define SR_KSU_KERNEL 0x00000000 -#define SR_INT_MASK 0x0007ff00 -#else #define SR_XX 0x80000000 #define SR_KSU_MASK 0x00000018 #define SR_KSU_SUPER 0x00000008 #define SR_KSU_KERNEL 0x00000000 #define SR_INT_MASK 0x0000ff00 -#endif /* SR_KSU_USER is in <mips64/cpu.h> for CLKF_USERMODE() */ #ifndef SR_KSU_USER #define SR_KSU_USER 0x00000010 #endif -/* - * Interrupt control register in RM7000. Expansion of interrupts. - */ - -#define IC_INT_MASK 0x00003f00 /* Two msb reserved */ -#define IC_INT_MASK_6 0x00000100 -#define IC_INT_MASK_7 0x00000200 -#define IC_INT_MASK_8 0x00000400 -#define IC_INT_MASK_9 0x00000800 -#define IC_INT_TIMR 0x00001000 /* 12 Timer */ -#define IC_INT_PERF 0x00002000 /* 13 Performance counter */ -#define IC_INT_TE 0x00000080 /* Timer on INT11 */ - #define SOFT_INT_MASK (SOFT_INT_MASK_0 | SOFT_INT_MASK_1) /* * Cause register. */ -#ifdef CPU_R8000 -#define CR_BR_DELAY 0x8000000000000000 -#define CR_EXC_CODE 0x000000f8 -#define CR_EXC_CODE_SHIFT 3 -#define CR_COP_ERR 0x10000000 -#else #define CR_BR_DELAY 0x80000000 #define CR_EXC_CODE 0x0000007c #define CR_EXC_CODE_SHIFT 2 #define CR_COP_ERR 0x30000000 -#endif #define CR_COP1_ERR 0x10000000 #define CR_COP2_ERR 0x20000000 #define CR_COP3_ERR 0x20000000 @@ -156,26 +112,8 @@ #define CR_INT_3 0x00002000 #define CR_INT_4 0x00004000 #define CR_INT_5 0x00008000 -/* Following on RM7000 and R8000 */ -#define CR_INT_6 0x00010000 -#define CR_INT_7 0x00020000 -#define CR_INT_8 0x00040000 -/* Following on RM7000 */ -#define CR_INT_9 0x00080000 -#define CR_INT_HARD 0x000ffc00 -#define CR_INT_TIMR 0x00100000 /* 12 Timer */ -#define CR_INT_PERF 0x00200000 /* 13 Performance counter */ -/* R8000 specific */ -#define CR_FPE 0x01000000 -#define CR_VCE 0x02000000 -#define CR_BERR 0x04000000 -#define CR_NMI 0x08000000 -#ifdef CPU_R8000 -#define CR_INT_MASK 0x0007ff00 -#else #define CR_INT_MASK 0x003fff00 -#endif /* * Config register. @@ -190,20 +128,11 @@ * Location of exception vectors. */ -#ifdef CPU_R8000 -#define RESET_EXC_VEC PHYS_TO_XKPHYS(0x1fc00000, CCA_NC) -/* all the others are relative to COP_0_TRAPBASE */ -/* #define UTLB_MISS_EXC_VEC 0x00000000 */ -/* #define KV1TLB_MISS_EXC_VEC 0x00000400 */ -/* #define KV0TLB_MISS_EXC_VEC 0x00000800 */ -/* #define GEN_EXC_VEC 0x00000c00 */ -#else #define RESET_EXC_VEC (CKSEG1_BASE + 0x1fc00000) #define TLB_MISS_EXC_VEC (CKSEG1_BASE + 0x00000000) #define XTLB_MISS_EXC_VEC (CKSEG1_BASE + 0x00000080) #define CACHE_ERR_EXC_VEC (CKSEG1_BASE + 0x00000100) #define GEN_EXC_VEC (CKSEG1_BASE + 0x00000180) -#endif /* * Coprocessor 0 registers @@ -243,34 +172,6 @@ #define COP_0_TAG_HI $29 #define COP_0_ERROR_PC $30 -/* R8000 specific */ -#define COP_0_TLB_SET $0 -#define COP_0_TLB_LO $2 -#define COP_0_UBASE $4 -#define COP_0_SHIFTAMT $5 -#define COP_0_TRAPBASE $6 -#define COP_0_BAD_PADDR $7 -#define COP_0_VADDR $8 -#define COP_0_WORK0 $18 -#define COP_0_WORK1 $19 -#define COP_0_PBASE $20 -#define COP_0_GBASE $21 -#define COP_0_TFP_TLB_WIRED $24 -#define COP_0_DCACHE $28 -#define COP_0_ICACHE $29 - -/* RM7000 specific */ -#define COP_0_WATCH_1 $18 -#define COP_0_WATCH_2 $19 -#define COP_0_WATCH_M $24 -#define COP_0_PC_COUNT $25 -#define COP_0_PC_CTRL $22 - -#define COP_0_ICR $20 /* Use cfc0/ctc0 to access */ - -/* R10000 specific */ -#define COP_0_TLB_FR_MASK $21 - /* Loongson-2 specific */ #define COP_0_DIAG $22 @@ -281,7 +182,7 @@ /* * COP_0_COUNT speed divider. */ -#if defined(CPU_OCTEON) || defined(CPU_R8000) +#if defined(CPU_OCTEON) #define CP0_CYCLE_DIVIDER 1 #else #define CP0_CYCLE_DIVIDER 2 diff --git a/sys/arch/mips64/include/pmap.h b/sys/arch/mips64/include/pmap.h index b38f09aa01f..c58fa74542e 100644 --- a/sys/arch/mips64/include/pmap.h +++ b/sys/arch/mips64/include/pmap.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pmap.h,v 1.48 2019/08/21 16:14:34 visa Exp $ */ +/* $OpenBSD: pmap.h,v 1.49 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 1987 Carnegie-Mellon University @@ -137,8 +137,6 @@ typedef struct pmap { #define PGF_CACHED PG_PMAP1 /* Page is currently cached */ #define PGF_ATTR_MOD PG_PMAP2 #define PGF_ATTR_REF PG_PMAP3 -#define PGF_EOP_CHECKED PG_PMAP4 -#define PGF_EOP_VULN PG_PMAP5 #define PGF_PRESERVE (PGF_ATTR_MOD | PGF_ATTR_REF) #define PMAP_NOCACHE PMAP_MD0 @@ -168,21 +166,9 @@ void pmap_page_cache(vm_page_t, u_int); #define pmap_unuse_final(p) do { /* nothing yet */ } while (0) #define pmap_remove_holes(vm) do { /* nothing */ } while (0) -/* - * Most R5000 processors (and related families) have a silicon bug preventing - * the ll/sc (and lld/scd) instructions from honouring the caching mode - * when accessing XKPHYS addresses. - * - * Since pool memory is allocated with pmap_map_direct() if __HAVE_PMAP_DIRECT, - * and many structures containing fields which will be used with - * <machine/atomic.h> routines are allocated from pools, __HAVE_PMAP_DIRECT can - * not be defined on systems which may use flawed processors. - */ -#if !defined(CPU_R5000) && !defined(CPU_RM7000) #define __HAVE_PMAP_DIRECT vaddr_t pmap_map_direct(vm_page_t); vm_page_t pmap_unmap_direct(vaddr_t); -#endif /* * MD flags to pmap_enter: diff --git a/sys/arch/mips64/include/pte.h b/sys/arch/mips64/include/pte.h index 0be9f1fe31c..d12cb2cc621 100644 --- a/sys/arch/mips64/include/pte.h +++ b/sys/arch/mips64/include/pte.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pte.h,v 1.22 2019/04/26 16:27:36 visa Exp $ */ +/* $OpenBSD: pte.h,v 1.23 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 1988 University of Utah. @@ -96,30 +96,17 @@ typedef u_int32_t pt_entry_t; /* entryhi values */ -#ifndef CPU_R8000 #define PG_HVPN (-2 * PAGE_SIZE) /* Hardware page number mask */ #define PG_ODDPG PAGE_SIZE -#endif /* !R8000 */ /* Address space ID */ -#ifdef CPU_R8000 -#define PG_ASID_MASK 0x0000000000000ff0 -#define PG_ASID_SHIFT 4 -#define ICACHE_ASID_SHIFT 40 -#define MIN_USER_ASID 0 -#else #define PG_ASID_MASK 0x00000000000000ff #define PG_ASID_SHIFT 0 #define MIN_USER_ASID 1 -#endif #define PG_ASID_COUNT 256 /* Number of available ASID */ /* entrylo values */ -#ifdef CPU_R8000 -#define PG_FRAME 0xfffff000 -#define PG_SHIFT 0 -#else #ifdef MIPS_PTE64 #define PG_FRAMEBITS 61 #else @@ -127,21 +114,11 @@ typedef u_int32_t pt_entry_t; #endif #define PG_FRAME ((1ULL << PG_FRAMEBITS) - (1ULL << PG_SHIFT)) #define PG_SHIFT 6 -#endif /* software pte bits - not put in entrylo */ -#if defined(CPU_R8000) -#define PG_WIRED 0x00000010 -#define PG_RO 0x00000020 -#elif defined(CPU_R4000) -#define PG_WIRED (1ULL << (PG_FRAMEBITS + 2)) -#define PG_RO (1ULL << (PG_FRAMEBITS + 1)) -#define PG_SP (1ULL << (PG_FRAMEBITS + 0)) /* ``special'' bit */ -#else #define PG_WIRED (1ULL << (PG_FRAMEBITS + 2)) /* 1ULL << (PG_FRAMEBITS + 1) is PG_XI. */ #define PG_RO (1ULL << (PG_FRAMEBITS + 0)) -#endif #ifdef CPU_MIPS64R2 #define PG_XI (1ULL << (PTE_BITS - 2)) @@ -150,18 +127,10 @@ typedef u_int32_t pt_entry_t; #endif #define PG_NV 0x00000000 -#ifdef CPU_R8000 -#define PG_G 0x00000000 /* no such concept for R8000 */ -#define PG_V 0x00000080 -#define PG_M 0x00000100 -#define PG_CCA_SHIFT 9 -#else #define PG_G 0x00000001 #define PG_V 0x00000002 #define PG_M 0x00000004 #define PG_CCA_SHIFT 3 -#endif -#define PG_NV 0x00000000 #define PG_UNCACHED (CCA_NC << PG_CCA_SHIFT) #define PG_CACHED_NC (CCA_NONCOHERENT << PG_CCA_SHIFT) @@ -179,7 +148,6 @@ typedef u_int32_t pt_entry_t; #define pfn_to_pad(pa) ((((paddr_t)pa) & PG_FRAME) << PG_SHIFT) #define vad_to_pfn(va) (((va) >> PG_SHIFT) & PG_FRAME) -#ifndef CPU_R8000 #define PG_SIZE_4K 0x00000000 #define PG_SIZE_16K 0x00006000 #define PG_SIZE_64K 0x0001e000 @@ -192,6 +160,5 @@ typedef u_int32_t pt_entry_t; #elif PAGE_SHIFT == 14 #define TLB_PAGE_MASK PG_SIZE_16K #endif -#endif /* !R8000 */ #endif /* !_MIPS64_PTE_H_ */ diff --git a/sys/arch/mips64/mips64/arcbios.c b/sys/arch/mips64/mips64/arcbios.c deleted file mode 100644 index 6da3610d281..00000000000 --- a/sys/arch/mips64/mips64/arcbios.c +++ /dev/null @@ -1,576 +0,0 @@ -/* $OpenBSD: arcbios.c,v 1.36 2019/06/30 07:41:50 visa Exp $ */ -/*- - * Copyright (c) 1996 M. Warner Losh. All rights reserved. - * Copyright (c) 1996-2004 Opsycon AB. 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 REGENTS 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 REGENTS 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/proc.h> - -#include <machine/autoconf.h> -#include <machine/cpu.h> -#include <machine/memconf.h> -#include <machine/vmparam.h> - -#include <mips64/arcbios.h> -#include <mips64/archtype.h> - -#include <uvm/uvm_extern.h> - -#ifdef TGT_ORIGIN -#include <machine/mnode.h> -#endif - -int bios_is_32bit; -void *bios_base; - -/* - * If we cannot get the onboard Ethernet address to override this bogus - * value, ether_ifattach() will pick a valid address. - */ -char bios_enaddr[20] = "ff:ff:ff:ff:ff:ff"; - -int bios_consrate; /* Serial console speed. */ -char bios_console[30]; /* Primary console. */ -char bios_graphics[6]; /* Graphics state. */ -char bios_keyboard[6]; /* Keyboard layout. */ - -void (*bios_halt)(void); -void (*bios_powerdown)(void); -void (*bios_restart)(void); -void (*bios_reboot)(void); -void (*bios_eim)(void); - -extern int physmem; /* Total physical memory size */ -extern int rsvdmem; /* Total reserved memory size */ - -void bios_configure_memory(void); -int bios_get_system_type(void); - -arc_dsp_stat_t displayinfo; /* Save area for display status info. */ - -static struct systypes { - char *sys_vend; /* Vendor ID if name is ambiguous */ - char *sys_name; /* May be left NULL if name is sufficient */ - int sys_type; -} sys_types[] = { -#if 0 - { NULL, "PICA-61", ACER_PICA_61 }, - { NULL, "NEC-R94", ACER_PICA_61 }, - { NULL, "DESKTECH-TYNE", DESKSTATION_TYNE }, - { NULL, "DESKTECH-ARCStation I", DESKSTATION_RPC44 }, - { NULL, "Microsoft-Jazz", MAGNUM }, - { NULL, "RM200PCI", SNI_RM200 }, -#endif - { NULL, "SGI-IP17", SGI_IP17 }, - { NULL, "SGI-IP19", SGI_IP19 }, - { NULL, "SGI-IP20", SGI_IP20 }, - { NULL, "SGI-IP21", SGI_IP21 }, - { NULL, "SGI-IP22", SGI_IP22 }, - { NULL, "SGI-IP25", SGI_IP25 }, - { NULL, "SGI-IP26", SGI_IP26 }, - { NULL, "SGI-IP28", SGI_IP28 }, - { NULL, "SGI-IP30", SGI_OCTANE }, - { NULL, "SGI-IP32", SGI_O2 } -}; - -#define KNOWNSYSTEMS (sizeof(sys_types) / sizeof(struct systypes)) - -/* - * ARC Bios trampoline code. - */ - -#define ARC_Call(Name,Offset) \ -__asm__("\n" \ -" .text\n" \ -" .ent " #Name "\n" \ -" .align 3\n" \ -" .set noreorder\n" \ -" .globl " #Name "\n" \ -#Name":\n" \ -" lw $3, bios_is_32bit\n"\ -" ld $2, bios_base\n"\ -" beqz $3, 1f\n" \ -" nop\n" \ -" lw $3, 0x20($2)\n" \ -" lw $2," #Offset "($3)\n"\ -" jr $2\n" \ -" nop\n" \ -"1:\n" \ -" ld $3, 2*0x20($2)\n"\ -" ld $2, 2*" #Offset "($3)\n"\ -" jr $2\n" \ -" nop\n" \ -" .end " #Name "\n" ); - -/* - * Invoke an ARC routine through a function pointer (set up in bios_ident()), - * also forcing the stack to be in CKSEG0 (actually, whatever area proc0 stack - * was allocated in) if this is a 32-bit ARCBios; used by restart functions, - * which aren't supposed to return anyway. - */ -#define ARC_Call_Via_Pointer(Name,fnptr) \ -__asm__("\n" \ -" .text\n" \ -" .ent " #Name "\n" \ -" .align 3\n" \ -" .set noreorder\n" \ -" .globl " #Name "\n" \ -#Name":\n" \ -" lw $3, bios_is_32bit\n"\ -" beqz $3, 1f\n" \ -" nop\n" \ -" ld $3, proc0paddr\n" \ -" addi $29, $3, 16384 - 64\n" /* assumes USPACE >= 16384 */ \ -"1:\n" \ -" ld $2, " #fnptr "\n"\ -" jr $2\n" \ -" nop\n" \ -" .end " #Name "\n"); - -#if 0 -ARC_Call(Bios_Load, 0x00); -ARC_Call(Bios_Invoke, 0x04); -ARC_Call(Bios_Execute, 0x08); -#endif -ARC_Call_Via_Pointer(Bios_Halt, bios_halt); -ARC_Call_Via_Pointer(Bios_PowerDown, bios_powerdown); -ARC_Call_Via_Pointer(Bios_Restart, bios_restart); -ARC_Call_Via_Pointer(Bios_Reboot, bios_reboot); -ARC_Call_Via_Pointer(Bios_EnterInteractiveMode, bios_eim); -#if 0 -ARC_Call(Bios_Unused1, 0x20); -#endif -ARC_Call(Bios_GetPeer, 0x24); -ARC_Call(Bios_GetChild, 0x28); -#if 0 -ARC_Call(Bios_GetParent, 0x2c); -#endif -#if 0 -ARC_Call(Bios_GetConfigurationData, 0x30); -#endif -#if 0 -ARC_Call(Bios_AddChild, 0x34); -ARC_Call(Bios_DeleteComponent, 0x38); -#endif -#if 0 -ARC_Call(Bios_GetComponent, 0x3c); -ARC_Call(Bios_SaveConfiguration, 0x40); -#endif -ARC_Call(Bios_GetSystemId, 0x44); -ARC_Call(Bios_GetMemoryDescriptor, 0x48); -#if 0 -ARC_Call(Bios_Unused2, 0x4c); -#endif -ARC_Call(Bios_GetTime, 0x50); -#if 0 -ARC_Call(Bios_GetRelativeTime, 0x54); -ARC_Call(Bios_GetDirectoryEntry, 0x58); -ARC_Call(Bios_Open, 0x5c); -ARC_Call(Bios_Close, 0x60); -ARC_Call(Bios_Read, 0x64); -ARC_Call(Bios_GetReadStatus, 0x68); -#endif -ARC_Call(Bios_Write, 0x6c); -#if 0 -ARC_Call(Bios_Seek, 0x70); -ARC_Call(Bios_Mount, 0x74); -#endif -ARC_Call(Bios_GetEnvironmentVariable, 0x78); -#if 0 -ARC_Call(Bios_SetEnvironmentVariable, 0x7c); -ARC_Call(Bios_GetFileInformation, 0x80); -ARC_Call(Bios_SetFileInformation, 0x84); -#endif -ARC_Call(Bios_FlushAllCaches, 0x88); -#if 0 -ARC_Call(Bios_TestUnicodeCharacter, 0x8c); -ARC_Call(Bios_GetDisplayStatus, 0x90); -#endif - -/* - * Simple getchar/putchar interface. - */ - -#if 0 -int -bios_getchar() -{ - char buf[4]; - long cnt; - - if (Bios_Read(0, &buf[0], 1, &cnt) != 0) - return(-1); - return(buf[0] & 255); -} -#endif - -void -bios_putchar(char c) -{ - char buf[4]; - long cnt; - - if (c == '\n') { - buf[0] = '\r'; - buf[1] = c; - cnt = 2; -#ifdef __arc__ - if (displayinfo.CursorYPosition < displayinfo.CursorMaxYPosition) - displayinfo.CursorYPosition++; -#endif - } - else { - buf[0] = c; - cnt = 1; - } - Bios_Write(1, &buf[0], cnt, &cnt); -} - -void -bios_putstring(char *s) -{ - while (*s) { - bios_putchar(*s++); - } -} - -void -bios_printf(const char *fmt, ...) -{ - va_list ap; - char buf[1024]; - - va_start(ap, fmt); - vsnprintf(buf, sizeof(buf), fmt, ap); - bios_putstring(buf); - va_end(ap); -} - -/* - * Get memory descriptor for the memory configuration and - * create a layout database used by pmap init to set up - * the memory system. - * - * Concatenate obvious adjacent segments. - */ -void -bios_configure_memory() -{ - arc_mem_t *descr = NULL; - uint64_t start, count, prevend = 0; - MEMORYTYPE type, prevtype = BadMemory; - uint64_t seg_start, seg_end; -#ifdef TGT_ORIGIN - int seen_free = 0; -#endif -#ifdef ARCBIOS_DEBUG - int i; -#endif - - descr = (arc_mem_t *)Bios_GetMemoryDescriptor(descr); - while (descr != NULL) { - if (bios_is_32bit) { - start = descr->BasePage; - count = descr->PageCount; - type = descr->Type; - } else { - start = ((arc_mem64_t *)descr)->BasePage; - count = ((arc_mem64_t *)descr)->PageCount; - type = descr->Type; - -#ifdef TGT_OCTANE - /* - * Memory above 1GB physical (address 1.5GB) - * gets reported as reserved on Octane, while - * it isn't. - * Abort scan at this point, platform dependent - * code will add the remaining memory, if any. - */ - if (sys_config.system_type == SGI_OCTANE && - type == FirmwarePermanent && - start >= 0x60000) - break; -#endif - -#ifdef TGT_ORIGIN - if (sys_config.system_type == SGI_IP27) { - /* - * For the lack of a better way to tell - * IP27 apart from IP35, look at the - * start of the first chunk of free - * memory. On IP27, it starts under - * 0x20000 (which allows us to link - * kernels at 0xa800000000020000). - * On IP35, it starts at 0x40000. - */ - if (type == FreeMemory && seen_free == 0) { - seen_free = 1; - if (start >= 0x20) /* IP35 */ - sys_config.system_type = - SGI_IP35; - } - - /* - * On IP27 and IP35 systems, data after the - * first FirmwarePermanent entry is not - * reliable (entries conflict with each other), - * and memory after 32MB (or 64MB on IP35) is - * not listed anyway. - * So, break from the loop as soon as a - * FirmwarePermanent entry is found, after - * making it span the end of the first 32MB - * (64MB on IP35). - * - * The rest of the memory will be gathered - * from the node structures. This loses some - * of the first few MB (well... all of them - * but the kernel image), but at least we're - * safe to use ARCBios after going virtual. - */ - if (type == FirmwarePermanent) { - descr = NULL; /* abort loop */ - count = ((sys_config.system_type == - SGI_IP27 ? 32 : 64) << (20 - 12)) - - start; - } - } -#endif /* O200 || O300 */ - } - - switch (type) { - case BadMemory: /* have no use for these */ - break; - case LoadedProgram: - /* - * LoadedProgram areas are either the boot loader, - * if the kernel has not been directly loaded by - * ARCBios, or the kernel image itself. - * Since we will move the kernel image out of the - * memory segments later anyway, it makes sense to - * claim this memory as free. - */ - /* FALLTHROUGH */ - case FreeMemory: - case FreeContigous: - /* - * Convert from ARCBios page size to kernel page size. - * As this can yield a smaller range due to possible - * different page size, we try to force coalescing - * with the previous range if this is safe. - */ - seg_start = atop(round_page(start * ARCBIOS_PAGE_SIZE)); - seg_end = atop(trunc_page((start + count) * - ARCBIOS_PAGE_SIZE)); - if (start == prevend) - switch (prevtype) { - case LoadedProgram: - case FreeMemory: - case FreeContigous: - seg_start = atop(trunc_page(start * - ARCBIOS_PAGE_SIZE)); - break; - default: - break; - } - if (seg_start < seg_end) - memrange_register(seg_start, seg_end, 0); - break; - case ExceptionBlock: - case SystemParameterBlock: - case FirmwareTemporary: - case FirmwarePermanent: - rsvdmem += count; - break; - default: /* Unknown type, leave it alone... */ - break; - } - prevtype = type; - prevend = start + count; -#ifdef TGT_ORIGIN - if (descr == NULL) - break; -#endif - descr = (arc_mem_t *)Bios_GetMemoryDescriptor(descr); - } - - /* convert rsvdmem to kernel pages, and count it in physmem */ - rsvdmem = atop(round_page(rsvdmem * ARCBIOS_PAGE_SIZE)); - physmem += rsvdmem; - -#ifdef ARCBIOS_DEBUG - for (i = 0; i < MAXMEMSEGS; i++) { - if (mem_layout[i].mem_last_page) { - bios_printf("MEM %d, %p to %p\n", i, - ptoa(mem_layout[i].mem_first_page), - ptoa(mem_layout[i].mem_last_page)); - } - } -#endif -} - -/* - * Find out system type. - */ -int -bios_get_system_type() -{ - arc_config_t *cf; - arc_sid_t *sid; - register_t prid; - char *sysid; - int sysid_len; - int i; - - /* - * Figure out where ARCBios can be addressed. On R8000, we can not - * use compatibility space, but on IP27/IP35, we can not blindly - * use XKPHYS due to subspacing, while compatibility space works. - * Fortunately we can get the processor ID to tell these apart, even - * though 32-bit coprocessor 0 instructions are not supposed to be - * supported on the R8000 (they probably misbehave somehow if the - * register has bits sets in the upper 32 bits, which is not the - * case of the R8000 PrId register). - */ - __asm__ volatile ("mfc0 %0, $15" /* COP_0_PRID */ : "=r" (prid)); - if ((prid & 0xff00) == (MIPS_R8000 << 8)) - bios_base = (void *)PHYS_TO_XKPHYS(ARCBIOS_BASE, CCA_CACHED); - else - bios_base = (void *)PHYS_TO_CKSEG0(ARCBIOS_BASE); - - /* - * Figure out if this is an ARCBios machine and if it is, see if we're - * dealing with a 32 or 64 bit version. - */ - if ((ArcBiosBase32->magic == ARC_PARAM_BLK_MAGIC) || - (ArcBiosBase32->magic == ARC_PARAM_BLK_MAGIC_BUG)) { - bios_is_32bit = 1; - bios_printf("ARCS32 Firmware Version %d.%d\n", - ArcBiosBase32->version, ArcBiosBase32->revision); - } else if ((ArcBiosBase64->magic == ARC_PARAM_BLK_MAGIC) || - (ArcBiosBase64->magic == ARC_PARAM_BLK_MAGIC_BUG)) { - bios_is_32bit = 0; - bios_printf("ARCS64 Firmware\n"); - } else { - return -1; /* Today is not your lucky day */ - } - - sid = (arc_sid_t *)Bios_GetSystemId(); - - cf = (arc_config_t *)Bios_GetChild(NULL); - if (cf != NULL) { - if (bios_is_32bit) { - sysid = (char *)(long)cf->id; - sysid_len = cf->id_len; - } else { - sysid = (char *)((arc_config64_t *)cf)->id; - sysid_len = ((arc_config64_t *)cf)->id_len; - } - - if (sysid_len > 0 && sysid != NULL) { - sysid_len--; - for (i = 0; i < KNOWNSYSTEMS; i++) { - if (strlen(sys_types[i].sys_name) !=sysid_len) - continue; - if (strncmp(sys_types[i].sys_name, sysid, - sysid_len) != 0) - continue; - if (sys_types[i].sys_vend && - strncmp(sys_types[i].sys_vend, sid->vendor, - 8) != 0) - continue; - return (sys_types[i].sys_type); /* Found it. */ - } - } - } else { -#ifdef TGT_ORIGIN - if (IP27_KLD_KLCONFIG(0)->magic == IP27_KLDIR_MAGIC) { - /* - * If we find a kldir assume IP27 for now. - * We'll decide whether this is IP27 or IP35 later. - */ - return SGI_IP27; - } -#endif - } - - bios_printf("UNRECOGNIZED SYSTEM '%s' VENDOR '%8.8s' PRODUCT '%8.8s'\n", - cf == NULL ? "??" : sysid, sid->vendor, sid->prodid); - bios_printf("Halting system!\n"); - Bios_Halt(); - bios_printf("Halting failed, use manual reset!\n"); - while(1); -} - -/* - * Incomplete version of bios_ident - */ -void -bios_ident() -{ - sys_config.system_type = bios_get_system_type(); - - if (bios_is_32bit) { -#define bios_fnptr(slot) \ - (int64_t)*(int32_t *)((int64_t)ArcBiosBase32->firmware_vect + (slot) * 4) - bios_halt = (void (*)(void))bios_fnptr(3); - bios_powerdown = (void (*)(void))bios_fnptr(4); - bios_restart = (void (*)(void))bios_fnptr(5); - bios_reboot = (void (*)(void))bios_fnptr(6); - bios_eim = (void (*)(void))bios_fnptr(7); -#undef bios_fnptr - } else { -#define bios_fnptr(slot) \ - *(int64_t *)(ArcBiosBase64->firmware_vect + (slot) * 8) - bios_halt = (void (*)(void))bios_fnptr(3); - bios_powerdown = (void (*)(void))bios_fnptr(4); - bios_restart = (void (*)(void))bios_fnptr(5); - bios_reboot = (void (*)(void))bios_fnptr(6); - bios_eim = (void (*)(void))bios_fnptr(7); -#undef bios_fnptr - } - - bios_configure_memory(); -#ifdef __arc__ - displayinfo = *(arc_dsp_stat_t *)Bios_GetDisplayStatus(1); -#endif -} - -#if 0 -/* - * Return geometry of the display. Used by pccons.c to set up the - * display configuration. - */ -void -bios_display_info(int *xpos, int *ypos, int *xsize, int *ysize) -{ -#ifdef __arc__ - *xpos = displayinfo.CursorXPosition; - *ypos = displayinfo.CursorYPosition; - *xsize = displayinfo.CursorMaxXPosition; - *ysize = displayinfo.CursorMaxYPosition; -#endif -} -#endif diff --git a/sys/arch/mips64/mips64/cache_r10k.c b/sys/arch/mips64/mips64/cache_r10k.c deleted file mode 100644 index 75105e2af7d..00000000000 --- a/sys/arch/mips64/mips64/cache_r10k.c +++ /dev/null @@ -1,418 +0,0 @@ -/* $OpenBSD: cache_r10k.c,v 1.7 2016/01/05 05:27:54 visa Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Cache handling code for R10000 processor family (R10000, R12000, - * R14000, R16000). - * - * R10000 caches are : - * - L1 I$ is 2-way, VIPT, 64 bytes/line, 32KB total - * - L1 D$ is 2-way, VIPT, write-back, 32 bytes/line, 32KB total - * - L2 is 2-way, PIPT, write-back, 64 or 128 bytes/line, 512KB up to 16MB - */ - -#include <sys/param.h> -#include <sys/systm.h> - -#include <mips64/cache.h> -#include <machine/cpu.h> - -#include <uvm/uvm_extern.h> - -#define IndexInvalidate_I 0x00 -#define IndexWBInvalidate_D 0x01 -#define IndexWBInvalidate_S 0x03 - -#define HitInvalidate_D 0x11 -#define HitInvalidate_S 0x13 - -#define CacheBarrier 0x14 - -#define HitWBInvalidate_D 0x15 -#define HitWBInvalidate_S 0x17 - -#define cache(op,set,addr) \ - __asm__ volatile \ - ("cache %0, %1(%2)" :: "i"(op), "i"(set), "r"(addr) : "memory") - -static __inline__ void mips10k_hitinv_primary(vaddr_t, vsize_t); -static __inline__ void mips10k_hitinv_secondary(vaddr_t, vsize_t, vsize_t); -static __inline__ void mips10k_hitwbinv_primary(vaddr_t, vsize_t); -static __inline__ void mips10k_hitwbinv_secondary(vaddr_t, vsize_t, vsize_t); - -#define R10K_L1I_LINE 64UL -#define R10K_L1D_LINE 32UL - -void -Mips10k_ConfigCache(struct cpu_info *ci) -{ - uint32_t cfg, valias_mask; - - cfg = cp0_get_config(); - - ci->ci_l1inst.size = (1 << 12) << ((cfg >> 29) & 0x07); /* IC */ - ci->ci_l1inst.linesize = R10K_L1I_LINE; - ci->ci_l1inst.setsize = ci->ci_l1inst.size / 2; - ci->ci_l1inst.sets = 2; - - ci->ci_l1data.size = (1 << 12) << ((cfg >> 26) & 0x07); /* DC */ - ci->ci_l1data.linesize = R10K_L1D_LINE; - ci->ci_l1data.setsize = ci->ci_l1data.size / 2; - ci->ci_l1data.sets = 2; - - ci->ci_l2.size = (1 << 19) << ((cfg >> 16) & 0x07); - ci->ci_l2.linesize = (cfg & (1 << 13)) ? 128 : 64; - ci->ci_l2.setsize = ci->ci_l2.size / 2; - ci->ci_l2.sets = 2; - - memset(&ci->ci_l3, 0, sizeof(struct cache_info)); - - valias_mask = (max(ci->ci_l1inst.setsize, ci->ci_l1data.setsize) - 1) & - ~PAGE_MASK; - - if (valias_mask != 0) { - valias_mask |= PAGE_MASK; -#ifdef MULTIPROCESSOR - if (valias_mask > cache_valias_mask) { -#endif - cache_valias_mask = valias_mask; - pmap_prefer_mask = valias_mask; -#ifdef MULTIPROCESSOR - } -#endif - } - - ci->ci_SyncCache = Mips10k_SyncCache; - ci->ci_InvalidateICache = Mips10k_InvalidateICache; - ci->ci_InvalidateICachePage = Mips10k_InvalidateICachePage; - ci->ci_SyncICache = Mips10k_SyncICache; - ci->ci_SyncDCachePage = Mips10k_SyncDCachePage; - ci->ci_HitSyncDCachePage = Mips10k_HitSyncDCachePage; - ci->ci_HitSyncDCache = Mips10k_HitSyncDCache; - ci->ci_HitInvalidateDCache = Mips10k_HitInvalidateDCache; - ci->ci_IOSyncDCache = Mips10k_IOSyncDCache; -} - -static __inline__ void -mips10k_hitwbinv_primary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWBInvalidate_D, 0, va); - va += R10K_L1D_LINE; - } -} - -static __inline__ void -mips10k_hitwbinv_secondary(vaddr_t va, vsize_t sz, vsize_t line) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWBInvalidate_S, 0, va); - va += line; - } -} - -static __inline__ void -mips10k_hitinv_primary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitInvalidate_D, 0, va); - va += R10K_L1D_LINE; - } -} - -static __inline__ void -mips10k_hitinv_secondary(vaddr_t va, vsize_t sz, vsize_t line) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitInvalidate_S, 0, va); - va += line; - } -} - -/* - * Writeback and invalidate all caches. - */ -void -Mips10k_SyncCache(struct cpu_info *ci) -{ - vaddr_t sva, eva; - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l1inst.setsize; - while (sva != eva) { - cache(IndexInvalidate_I, 0, sva); - cache(IndexInvalidate_I, 1, sva); - sva += R10K_L1I_LINE; - } - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l1data.setsize; - while (sva != eva) { - cache(IndexWBInvalidate_D, 0, sva); - cache(IndexWBInvalidate_D, 1, sva); - sva += R10K_L1D_LINE; - } - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l2.setsize; - while (sva != eva) { - cache(IndexWBInvalidate_S, 0, sva); - cache(IndexWBInvalidate_S, 1, sva); - sva += ci->ci_l2.linesize; - } -} - -/* - * Invalidate I$ for the given range. - */ -void -Mips10k_InvalidateICache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va, sva, eva; - vsize_t sz; - - /* extend the range to integral cache lines */ - va = _va & ~(R10K_L1I_LINE - 1); - sz = ((_va + _sz + R10K_L1I_LINE - 1) & ~(R10K_L1I_LINE - 1)) - va; - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - /* keep only the index bits */ - sva |= va & ((1UL << 14) - 1); - eva = sva + sz; - while (sva != eva) { - cache(IndexInvalidate_I, 0, sva); - cache(IndexInvalidate_I, 1, sva); - sva += R10K_L1I_LINE; - } -} - -/* - * Register a given page for I$ invalidation. - */ -void -Mips10k_InvalidateICachePage(struct cpu_info *ci, vaddr_t va) -{ -#if PAGE_SHIFT < 14 - /* - * Mark the particular page index bits as needing to be flushed. - */ - ci->ci_cachepending_l1i |= - 1ULL << ((va & ((1UL << 14) - 1)) >> PAGE_SHIFT); -#else - /* - * Since the page size matches the I$ set size, all we need to do - * here is remember there are postponed flushes. - */ - ci->ci_cachepending_l1i = 1; -#endif -} - -/* - * Perform postponed I$ invalidation. - */ -void -Mips10k_SyncICache(struct cpu_info *ci) -{ - vaddr_t sva, eva; - - if (ci->ci_cachepending_l1i != 0) { -#if PAGE_SHIFT < 14 - /* - * Iterate on all pending page index bits. - */ - uint64_t idx; - - for (idx = 0; ci->ci_cachepending_l1i != 0; idx++) { - if ((ci->ci_cachepending_l1i & (1ULL << idx)) == 0) - continue; - - sva = PHYS_TO_XKPHYS(idx << PAGE_SHIFT, CCA_CACHED); - eva = sva + PAGE_SIZE; - while (sva != eva) { - cache(IndexInvalidate_I, 0, sva); - cache(IndexInvalidate_I, 1, sva); - sva += R10K_L1I_LINE; - } - - ci->ci_cachepending_l1i &= ~(1ULL << idx); - } -#else - /* inline Mips10k_InvalidateICache(ci, 0, PAGE_SIZE); */ - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + PAGE_SIZE; - while (sva != eva) { - cache(IndexInvalidate_I, 0, sva); - cache(IndexInvalidate_I, 1, sva); - sva += R10K_L1I_LINE; - } - ci->ci_cachepending_l1i = 0; -#endif - } -} - -/* - * Writeback D$ for the given page. - */ -void -Mips10k_SyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ -#if PAGE_SHIFT < 14 - vaddr_t sva, eva; - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - /* keep only the index bits */ - sva += va & ((1UL << 14) - 1); - eva = sva + PAGE_SIZE; - while (sva != eva) { - cache(IndexWBInvalidate_D, 0 + 0 * R10K_L1D_LINE, sva); - cache(IndexWBInvalidate_D, 0 + 1 * R10K_L1D_LINE, sva); - cache(IndexWBInvalidate_D, 0 + 2 * R10K_L1D_LINE, sva); - cache(IndexWBInvalidate_D, 0 + 3 * R10K_L1D_LINE, sva); - cache(IndexWBInvalidate_D, 1 + 0 * R10K_L1D_LINE, sva); - cache(IndexWBInvalidate_D, 1 + 1 * R10K_L1D_LINE, sva); - cache(IndexWBInvalidate_D, 1 + 2 * R10K_L1D_LINE, sva); - cache(IndexWBInvalidate_D, 1 + 3 * R10K_L1D_LINE, sva); - sva += 4 * R10K_L1D_LINE; - } -#else - /* - * Since the page size is not smaller than the L1 virtual index space, - * it is cheaper to use Hit operations to make sure we do not affect - * innocent cache lines. - */ - mips10k_hitwbinv_primary(PHYS_TO_XKPHYS(pa, CCA_CACHED), PAGE_SIZE); -#endif -} - -/* - * Writeback D$ for the given page, which is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -void -Mips10k_HitSyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ - mips10k_hitwbinv_primary(va, PAGE_SIZE); -} - -/* - * Writeback D$ for the given range. Range is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -void -Mips10k_HitSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - - /* extend the range to integral cache lines */ - va = _va & ~(R10K_L1D_LINE - 1); - sz = ((_va + _sz + R10K_L1D_LINE - 1) & ~(R10K_L1D_LINE - 1)) - va; - mips10k_hitwbinv_primary(va, sz); -} - -/* - * Invalidate D$ for the given range. Range is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -void -Mips10k_HitInvalidateDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - - /* extend the range to integral cache lines */ - va = _va & ~(R10K_L1D_LINE - 1); - sz = ((_va + _sz + R10K_L1D_LINE - 1) & ~(R10K_L1D_LINE - 1)) - va; - mips10k_hitinv_primary(va, sz); -} - -/* - * Backend for bus_dmamap_sync(). Enforce coherency of the given range - * by performing the necessary cache writeback and/or invalidate - * operations. - */ -void -Mips10k_IOSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz, int how) -{ - vaddr_t va; - vsize_t sz; - vsize_t line; - int partial_start, partial_end; - - line = ci->ci_l2.linesize; - /* extend the range to integral cache lines */ - if (line == 64) { - va = _va & ~(64UL - 1); - sz = ((_va + _sz + 64UL - 1) & ~(64UL - 1)) - va; - } else { - va = _va & ~(128UL - 1); - sz = ((_va + _sz + 128UL - 1) & ~(128UL - 1)) - va; - } - - switch (how) { - case CACHE_SYNC_R: - /* writeback partial cachelines */ - if (((_va | _sz) & (line - 1)) != 0) { - partial_start = va != _va; - partial_end = va + sz != _va + _sz; - } else { - partial_start = partial_end = 0; - } - if (partial_start) { - cache(HitWBInvalidate_S, 0, va); - va += line; - sz -= line; - } - if (sz != 0 && partial_end) { - cache(HitWBInvalidate_S, 0, va + sz - line); - sz -= line; - } - if (sz != 0) { - if (line == 64) - mips10k_hitinv_secondary(va, sz, 64UL); - else - mips10k_hitinv_secondary(va, sz, 128UL); - } - break; - case CACHE_SYNC_X: - case CACHE_SYNC_W: - if (line == 64) - mips10k_hitwbinv_secondary(va, sz, 64UL); - else - mips10k_hitwbinv_secondary(va, sz, 128UL); - break; - } -} diff --git a/sys/arch/mips64/mips64/cache_r4k.c b/sys/arch/mips64/mips64/cache_r4k.c deleted file mode 100644 index 255cf99372d..00000000000 --- a/sys/arch/mips64/mips64/cache_r4k.c +++ /dev/null @@ -1,523 +0,0 @@ -/* $OpenBSD: cache_r4k.c,v 1.15 2016/01/05 05:27:54 visa Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <sys/param.h> -#include <sys/systm.h> - -#include <mips64/cache.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> - -#include <uvm/uvm_extern.h> - -#define IndexInvalidate_I 0x00 -#define IndexWBInvalidate_D 0x01 -#define IndexWBInvalidate_S 0x03 - -#define HitInvalidate_D 0x11 -#define HitInvalidate_S 0x13 - -#define HitWBInvalidate_D 0x15 -#define HitWBInvalidate_S 0x17 - -#define cache(op,addr) \ - __asm__ volatile ("cache %0, 0(%1)" :: "i"(op), "r"(addr) : "memory") - -static __inline__ void mips4k_hitinv_primary(vaddr_t, vsize_t, vsize_t); -static __inline__ void mips4k_hitinv_secondary(vaddr_t, vsize_t, vsize_t); -static __inline__ void mips4k_hitwbinv_primary(vaddr_t, vsize_t, vsize_t); -static __inline__ void mips4k_hitwbinv_secondary(vaddr_t, vsize_t, vsize_t); - -/* - * Invoke a simple routine from uncached space (either CKSEG1 or uncached - * XKPHYS). - */ - -static void -run_uncached(void (*fn)(register_t), register_t arg) -{ - vaddr_t va; - paddr_t pa; - - va = (vaddr_t)fn; - if (IS_XKPHYS(va)) { - pa = XKPHYS_TO_PHYS(va); - va = PHYS_TO_XKPHYS(pa, CCA_NC); - } else { - pa = CKSEG0_TO_PHYS(va); - va = PHYS_TO_CKSEG1(pa); - } - fn = (void (*)(register_t))va; - - (*fn)(arg); -} - - -void -Mips4k_ConfigCache(struct cpu_info *ci) -{ - register_t cfg, ncfg; - - cfg = cp0_get_config(); - - ci->ci_l1inst.size = (1 << 12) << ((cfg >> 9) & 0x07); /* IC */ - if (cfg & (1 << 5)) /* IB */ - ci->ci_l1inst.linesize = 32; - else - ci->ci_l1inst.linesize = 16; - - ci->ci_l1data.size = (1 << 12) << ((cfg >> 6) & 0x07); /* DC */ - if (cfg & (1 << 4)) /* DB */ - ci->ci_l1data.linesize = 32; - else - ci->ci_l1data.linesize = 16; - - /* R4000 and R4400 L1 caches are direct */ - ci->ci_l1inst.setsize = ci->ci_l1inst.size; - ci->ci_l1inst.sets = 1; - ci->ci_l1data.setsize = ci->ci_l1data.size; - ci->ci_l1data.sets = 1; - - cache_valias_mask = - (max(ci->ci_l1inst.size, ci->ci_l1data.size) - 1) & - ~PAGE_MASK; - - if ((cfg & (1 << 17)) == 0) { /* SC */ - /* - * We expect the setup code to have set up ci->ci_l2 for us. - * Unfortunately we aren't allowed to panic() there if it - * didn't, because the console is not available. - */ - - /* fixed 32KB aliasing to avoid VCE */ - pmap_prefer_mask = ((1 << 15) - 1); - } else { - memset(&ci->ci_l2, 0, sizeof(struct cache_info)); - } - memset(&ci->ci_l3, 0, sizeof(struct cache_info)); - - if (cache_valias_mask != 0) { - cache_valias_mask |= PAGE_MASK; - pmap_prefer_mask |= cache_valias_mask; - } - - ci->ci_SyncCache = Mips4k_SyncCache; - ci->ci_InvalidateICache = Mips4k_InvalidateICache; - ci->ci_InvalidateICachePage = Mips4k_InvalidateICachePage; - ci->ci_SyncICache = Mips4k_SyncICache; - ci->ci_SyncDCachePage = Mips4k_SyncDCachePage; - ci->ci_HitSyncDCachePage = Mips4k_HitSyncDCachePage; - ci->ci_HitSyncDCache = Mips4k_HitSyncDCache; - ci->ci_HitInvalidateDCache = Mips4k_HitInvalidateDCache; - ci->ci_IOSyncDCache = Mips4k_IOSyncDCache; - - ncfg = (cfg & ~CFGR_CCA_MASK) | CCA_CACHED; - ncfg &= ~CFGR_CU; - if (cfg != ncfg) - run_uncached(cp0_set_config, ncfg); -} - -/* - * Writeback and invalidate all caches. - */ -void -Mips4k_SyncCache(struct cpu_info *ci) -{ - vaddr_t sva, eva; - vsize_t line; - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l1inst.size; - line = ci->ci_l1inst.linesize; - while (sva != eva) { - cache(IndexInvalidate_I, sva); - sva += line; - } - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l1data.size; - line = ci->ci_l1data.linesize; - while (sva != eva) { - cache(IndexWBInvalidate_D, sva); - sva += line; - } - - if (ci->ci_l2.size != 0) { - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l2.size; - line = ci->ci_l2.linesize; - while (sva != eva) { - cache(IndexWBInvalidate_S, sva); - sva += line; - } - } - - mips_sync(); -} - -/* - * Invalidate I$ for the given range. - */ -void -Mips4k_InvalidateICache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va, sva, eva; - vsize_t sz; - vsize_t line; - - line = ci->ci_l1inst.linesize; - /* extend the range to integral cache lines */ - if (line == 16) { - va = _va & ~(16UL - 1); - sz = ((_va + _sz + 16 - 1) & ~(16UL - 1)) - va; - } else { - va = _va & ~(32UL - 1); - sz = ((_va + _sz + 32 - 1) & ~(32UL - 1)) - va; - } - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - /* keep only the index bits */ - sva += va & ((1UL << 15) - 1); - if (sz > ci->ci_l1inst.size) - sz = ci->ci_l1inst.size; - eva = sva + sz; - while (sva != eva) { - cache(IndexInvalidate_I, sva); - sva += line; - } - - mips_sync(); -} - -/* - * Register a given page for I$ invalidation. - */ -void -Mips4k_InvalidateICachePage(struct cpu_info *ci, vaddr_t va) -{ - /* - * Mark the particular page index bits as needing to be flushed. - */ - ci->ci_cachepending_l1i |= - 1ULL << ((va & ((1UL << 15) - 1)) >> PAGE_SHIFT); -} - -/* - * Perform postponed I$ invalidation. - */ -void -Mips4k_SyncICache(struct cpu_info *ci) -{ - vaddr_t sva, eva; - vsize_t line; - uint64_t idx; - - if (ci->ci_cachepending_l1i != 0) { - line = ci->ci_l1inst.linesize; - - if (ci->ci_l1inst.size <= PAGE_SIZE) { - ci->ci_cachepending_l1i = 0; - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l1inst.size; - while (sva != eva) { - cache(IndexInvalidate_I, sva); - sva += line; - } - return; - } - - /* - * Iterate on all pending page index bits. - */ - for (idx = 0; ci->ci_cachepending_l1i != 0; idx++) { - if ((ci->ci_cachepending_l1i & (1ULL << idx)) == 0) - continue; - - sva = PHYS_TO_XKPHYS(idx << PAGE_SHIFT, CCA_CACHED); - eva = sva + PAGE_SIZE; - while (sva != eva) { - cache(IndexInvalidate_I, sva); - sva += line; - } - - ci->ci_cachepending_l1i &= ~(1ULL << idx); - } - } -} - -/* - * Writeback D$ for the given page. - */ -void -Mips4k_SyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ - vaddr_t sva, eva; - vsize_t line; - - line = ci->ci_l1data.linesize; - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - /* keep only the index bits */ - sva += va & ((1UL << 15) - 1); - if (PAGE_SIZE > ci->ci_l1data.size) - eva = sva + ci->ci_l1data.size; - else - eva = sva + PAGE_SIZE; - while (sva != eva) { - cache(IndexWBInvalidate_D, sva); - sva += line; - } - - if (ci->ci_l2.size != 0) { - line = ci->ci_l2.linesize; - sva = PHYS_TO_XKPHYS(pa, CCA_CACHED); - eva = sva + PAGE_SIZE; - while (sva != eva) { - cache(IndexWBInvalidate_S, sva); - sva += line; - } - } - - mips_sync(); -} - -static __inline__ void -mips4k_hitwbinv_primary(vaddr_t va, vsize_t sz, vsize_t line) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWBInvalidate_D, va); - va += line; - } -} - -static __inline__ void -mips4k_hitwbinv_secondary(vaddr_t va, vsize_t sz, vsize_t line) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWBInvalidate_S, va); - va += line; - } -} - -/* - * Writeback D$ for the given page, which is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -void -Mips4k_HitSyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ - mips4k_hitwbinv_primary(va, PAGE_SIZE, ci->ci_l1data.linesize); - if (ci->ci_l2.size != 0) - mips4k_hitwbinv_secondary(va, PAGE_SIZE, ci->ci_l2.linesize); - - mips_sync(); -} - -/* - * Writeback D$ for the given range. Range is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -void -Mips4k_HitSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - vsize_t line; - - line = ci->ci_l1data.linesize; - /* extend the range to integral cache lines */ - if (line == 16) { - va = _va & ~(16UL - 1); - sz = ((_va + _sz + 16 - 1) & ~(16UL - 1)) - va; - } else { - va = _va & ~(32UL - 1); - sz = ((_va + _sz + 32 - 1) & ~(32UL - 1)) - va; - } - mips4k_hitwbinv_primary(va, sz, line); - - if (ci->ci_l2.size != 0) { - line = ci->ci_l2.linesize; - /* extend the range to integral cache lines */ - va = _va & ~(line - 1); - sz = ((_va + _sz + line - 1) & ~(line - 1)) - va; - mips4k_hitwbinv_secondary(va, sz, line); - } - - mips_sync(); -} - -/* - * Invalidate D$ for the given range. Range is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -static __inline__ void -mips4k_hitinv_primary(vaddr_t va, vsize_t sz, vsize_t line) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitInvalidate_D, va); - va += line; - } -} - -static __inline__ void -mips4k_hitinv_secondary(vaddr_t va, vsize_t sz, vsize_t line) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitInvalidate_S, va); - va += line; - } -} - -void -Mips4k_HitInvalidateDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - vsize_t line; - - line = ci->ci_l1data.linesize; - /* extend the range to integral cache lines */ - if (line == 16) { - va = _va & ~(16UL - 1); - sz = ((_va + _sz + 16 - 1) & ~(16UL - 1)) - va; - } else { - va = _va & ~(32UL - 1); - sz = ((_va + _sz + 32 - 1) & ~(32UL - 1)) - va; - } - mips4k_hitinv_primary(va, sz, line); - - if (ci->ci_l2.size != 0) { - line = ci->ci_l2.linesize; - /* extend the range to integral cache lines */ - va = _va & ~(line - 1); - sz = ((_va + _sz + line - 1) & ~(line - 1)) - va; - mips4k_hitinv_secondary(va, sz, line); - } - - mips_sync(); -} - -/* - * Backend for bus_dmamap_sync(). Enforce coherency of the given range - * by performing the necessary cache writeback and/or invalidate - * operations. - */ -void -Mips4k_IOSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz, int how) -{ - vaddr_t va; - vsize_t sz; - vsize_t line; - int partial_start, partial_end; - - /* - * L1 - */ - - line = ci->ci_l1data.linesize; - /* extend the range to integral cache lines */ - if (line == 16) { - va = _va & ~(16UL - 1); - sz = ((_va + _sz + 16 - 1) & ~(16UL - 1)) - va; - } else { - va = _va & ~(32UL - 1); - sz = ((_va + _sz + 32 - 1) & ~(32UL - 1)) - va; - } - - switch (how) { - case CACHE_SYNC_R: - /* writeback partial cachelines */ - if (((_va | _sz) & (line - 1)) != 0) { - partial_start = va != _va; - partial_end = va + sz != _va + _sz; - } else { - partial_start = partial_end = 0; - } - if (partial_start) { - cache(HitWBInvalidate_D, va); - va += line; - sz -= line; - } - if (sz != 0 && partial_end) { - sz -= line; - cache(HitWBInvalidate_D, va + sz); - } - if (sz != 0) - mips4k_hitinv_primary(va, sz, line); - break; - case CACHE_SYNC_X: - case CACHE_SYNC_W: - mips4k_hitwbinv_primary(va, sz, line); - break; - } - - /* - * L2 - */ - - if (ci->ci_l2.size != 0) { - line = ci->ci_l2.linesize; - /* extend the range to integral cache lines */ - va = _va & ~(line - 1); - sz = ((_va + _sz + line - 1) & ~(line - 1)) - va; - - switch (how) { - case CACHE_SYNC_R: - /* writeback partial cachelines */ - if (((_va | _sz) & (line - 1)) != 0) { - partial_start = va != _va; - partial_end = va + sz != _va + _sz; - } else { - partial_start = partial_end = 0; - } - if (partial_start) { - cache(HitWBInvalidate_S, va); - va += line; - sz -= line; - } - if (sz != 0 && partial_end) { - sz -= line; - cache(HitWBInvalidate_S, va + sz); - } - if (sz != 0) - mips4k_hitinv_secondary(va, sz, line); - break; - case CACHE_SYNC_X: - case CACHE_SYNC_W: - mips4k_hitwbinv_secondary(va, sz, line); - break; - } - } -} diff --git a/sys/arch/mips64/mips64/cache_r5k.c b/sys/arch/mips64/mips64/cache_r5k.c deleted file mode 100644 index 64d8a0b52e5..00000000000 --- a/sys/arch/mips64/mips64/cache_r5k.c +++ /dev/null @@ -1,1062 +0,0 @@ -/* $OpenBSD: cache_r5k.c,v 1.15 2016/01/05 05:27:54 visa Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 1998-2004 Opsycon AB (www.opsycon.se) - * - * 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 ``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 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. - * - */ - -/* - * Cache handling for R5000 processor and close relatives: - * R4600/R4700, R5000, RM52xx, RM7xxx, RM9xxx. - * - * The following assumptions are made: - * - L1 I$ is 2-way or 4-way (RM7k/RM9k), VIPT, 32 bytes/line, up to 32KB - * - L1 D$ is 2-way or 4-way (RM7k/RM9k), VIPT, write-back, 32 bytes/line, - * up to 32KB - * - `internal' L2 on RM7k/RM9k is 4-way, PIPT, write-back, 32 bytes/line, - * 256KB total - * - L3 (on RM7k/RM9k) or `external' L2 (all others) may not exist. If it - * does, it is direct-mapped, PIPT, write-through - */ - -#include <sys/param.h> -#include <sys/systm.h> - -#include <mips64/cache.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> - -#include <uvm/uvm_extern.h> - -#define IndexInvalidate_I 0x00 -#define IndexWBInvalidate_D 0x01 -#define IndexWBInvalidate_S 0x03 - -#define IndexStoreTag_S 0x0b - -#define HitInvalidate_D 0x11 -#define HitInvalidate_S 0x13 - -#define HitWBInvalidate_D 0x15 -#define InvalidatePage_T 0x16 /* Only RM7k/RM9k */ -#define HitWBInvalidate_S 0x17 -#define InvalidatePage_S 0x17 /* Only RM527[0-1] */ - -#define HitWriteback_D 0x19 -#define HitWriteback_S 0x1b - -/* - * R5000 and RM52xx config register bits. - */ -#define CF_5_SE (1U << 12) /* Secondary cache enable */ -#define CF_5_SC (1U << 17) /* Secondary cache not present */ -#define CF_5_SS (3U << 20) /* Secondary cache size */ -#define CF_5_SS_AL 20 /* Shift to align */ - -/* - * RM7000 config register bits. - */ -#define CF_7_SE (1U << 3) /* Secondary cache enable */ -#define CF_7_SC (1U << 31) /* Secondary cache not present */ -#define CF_7_TE (1U << 12) /* Tertiary cache enable */ -#define CF_7_TC (1U << 17) /* Tertiary cache not present */ -#define CF_7_TS (3U << 20) /* Tertiary cache size */ -#define CF_7_TS_AL 20 /* Shift to align */ - - -#define R5K_LINE 32UL /* internal cache line */ -#define R5K_PAGE 4096UL /* external cache page */ - - -/* - * Cache configuration - */ -#define CTYPE_HAS_IL2 0x01 /* Internal L2 Cache present */ -#define CTYPE_HAS_XL2 0x02 /* External L2 Cache present */ -#define CTYPE_HAS_XL3 0x04 /* External L3 Cache present */ - -#define nop4() __asm__ volatile \ - ("nop; nop; nop; nop") -#define nop10() __asm__ volatile \ - ("nop; nop; nop; nop; nop; nop; nop; nop; nop; nop") - -#define cache(op,offs,addr) __asm__ volatile \ - ("cache %0, %1(%2)" :: "i"(op), "i"(offs), "r"(addr) : "memory") - -#define reset_taglo() __asm__ volatile \ - ("mtc0 $zero, $28") /* COP_0_TAG_LO */ -#define reset_taghi() __asm__ volatile \ - ("mtc0 $zero, $29") /* COP_0_TAG_HI */ - -static __inline__ register_t -get_config(void) -{ - register_t cfg; - __asm__ volatile ("mfc0 %0, $16" : "=r"(cfg)); /* COP_0_CONFIG */ - return cfg; -} - -static __inline__ void -set_config(register_t cfg) -{ - __asm__ volatile ("mtc0 %0, $16" :: "r"(cfg)); /* COP_0_CONFIG */ - /* MTC0_HAZARD */ -#ifdef CPU_RM7000 - nop10(); -#else - nop4(); -#endif -} - -static __inline__ void mips5k_hitinv_primary(vaddr_t, vsize_t); -static __inline__ void mips5k_hitinv_secondary(vaddr_t, vsize_t); -static __inline__ void mips5k_hitwbinv_primary(vaddr_t, vsize_t); -static __inline__ void mips5k_hitwbinv_secondary(vaddr_t, vsize_t); -static __inline__ void mips5k_hitwb_primary(vaddr_t, vsize_t); -#if 0 -static __inline__ void mips5k_hitwb_secondary(vaddr_t, vsize_t); -#endif - -void mips5k_l2_init(register_t); -void mips7k_l2_init(register_t); -void mips7k_l3_init(register_t); -void mips5k_c0_cca_update(register_t); -static void run_uncached(void (*)(register_t), register_t); - -/* - * Invoke a simple routine from uncached space (either CKSEG1 or uncached - * XKPHYS). - */ - -static void -run_uncached(void (*fn)(register_t), register_t arg) -{ - vaddr_t va; - paddr_t pa; - - va = (vaddr_t)fn; - if (IS_XKPHYS(va)) { - pa = XKPHYS_TO_PHYS(va); - va = PHYS_TO_XKPHYS(pa, CCA_NC); - } else { - pa = CKSEG0_TO_PHYS(va); - va = PHYS_TO_CKSEG1(pa); - } - fn = (void (*)(register_t))va; - - (*fn)(arg); -} - - -/* - * Initialize the external L2 cache of an R5000 (or close relative) processor. - * INTENDED TO BE RUN UNCACHED - BE SURE TO CHECK THAT IT WON'T STORE ANYTHING - * ON THE STACK IN THE ASSEMBLY OUTPUT EVERYTIME YOU CHANGE IT. - */ -void -mips5k_l2_init(register_t l2size) -{ - register vaddr_t va, eva; - register register_t cfg; - - cfg = get_config(); - cfg |= CF_5_SE; - set_config(cfg); - - reset_taglo(); - reset_taghi(); - - va = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = va + l2size; - while (va != eva) { - cache(InvalidatePage_S, 0, va); - va += R5K_PAGE; - } -} - -/* - * Initialize the internal L2 cache of an RM7000 (or close relative) processor. - * INTENDED TO BE RUN UNCACHED - BE SURE TO CHECK THAT IT WON'T STORE ANYTHING - * ON THE STACK IN THE ASSEMBLY OUTPUT EVERYTIME YOU CHANGE IT. - */ -void -mips7k_l2_init(register_t l2size) -{ - register vaddr_t va, eva; - register register_t cfg; - - cfg = get_config(); - cfg |= CF_7_SE; - set_config(cfg); - - reset_taglo(); - reset_taghi(); - - va = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = va + l2size; - while (va != eva) { - cache(IndexStoreTag_S, 0, va); - va += R5K_LINE; - } - mips_sync(); - - va = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = va + l2size; - while (va != eva) { - __asm__ volatile - ("lw $zero, 0(%0)" :: "r"(va)); - va += R5K_LINE; - } - mips_sync(); - - va = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = va + l2size; - while (va != eva) { - cache(IndexStoreTag_S, 0, va); - va += R5K_LINE; - } - mips_sync(); -} - -/* - * Initialize the external L3 cache of an RM7000 (or close relative) processor. - * INTENDED TO BE RUN UNCACHED - BE SURE TO CHECK THAT IT WON'T STORE ANYTHING - * ON THE STACK IN THE ASSEMBLY OUTPUT EVERYTIME YOU CHANGE IT. - */ -void -mips7k_l3_init(register_t l3size) -{ - register vaddr_t va, eva; - register register_t cfg; - - cfg = get_config(); - cfg |= CF_7_TE; - set_config(cfg); - - reset_taglo(); - reset_taghi(); - - va = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = va + l3size; - while (va != eva) { - cache(InvalidatePage_T, 0, va); - va += R5K_PAGE; - } -} - -/* - * Update the coherency of KSEG0. - * INTENDED TO BE RUN UNCACHED - BE SURE TO CHECK THAT IT WON'T STORE ANYTHING - * ON THE STACK IN THE ASSEMBLY OUTPUT EVERYTIME YOU CHANGE IT. - */ -void -mips5k_c0_cca_update(register_t cfg) -{ - set_config(cfg); - -#if defined(CPU_R5000) || defined(CPU_RM7000) - /* - * RM52xx and RM7000 hazard: after updating the K0 field of the Config - * register, the KSEG0 and CKSEG0 address segments should not be used - * for 5 cycles. The register modification and the use of these address - * segments should be separated by at least five (RM52xx) or - * ten (RM7000) integer instructions. - */ - nop10(); -#endif -} - -/* - * Discover cache configuration and update cpu_info accordingly. - * Initialize L2 and L3 caches found if necessary. - */ -void -Mips5k_ConfigCache(struct cpu_info *ci) -{ - register_t cfg, ncfg; - uint setshift; - - cfg = cp0_get_config(); - - /* L1 cache */ - ci->ci_l1inst.size = (1 << 12) << ((cfg >> 9) & 0x07); /* IC */ - ci->ci_l1inst.linesize = R5K_LINE; - ci->ci_l1data.size = (1 << 12) << ((cfg >> 6) & 0x07); /* DC */ - ci->ci_l1data.linesize = R5K_LINE; - - /* sane defaults */ - setshift = 1; - memset(&ci->ci_l2, 0, sizeof(struct cache_info)); - memset(&ci->ci_l3, 0, sizeof(struct cache_info)); - ci->ci_cacheconfiguration = 0; - - switch ((cp0_get_prid() >> 8) & 0xff) { - default: - /* shouldn't happen, really; but we can't panic here */ - break; -#ifdef CPU_R4600 - case MIPS_R4600: - case MIPS_R4700: - /* no external L2 interface */ - break; -#endif -#ifdef CPU_R5000 - case MIPS_R5000: - case MIPS_RM52X0: - /* optional external direct L2 cache */ - if ((cfg & CF_5_SC) == 0) { - ci->ci_l2.size = (1 << 19) << - ((cfg & CF_5_SS) >> CF_5_SS_AL); - ci->ci_l2.linesize = R5K_LINE; - ci->ci_l2.setsize = ci->ci_l2.size; - ci->ci_l2.sets = 1; - } - if (ci->ci_l2.size != 0) { - ci->ci_cacheconfiguration |= CTYPE_HAS_XL2; - cfg |= CF_5_SE; - run_uncached(mips5k_l2_init, ci->ci_l2.size); - } - break; -#endif /* CPU_R5000 */ -#ifdef CPU_RM7000 - case MIPS_RM7000: - case MIPS_RM9000: - setshift = 2; - /* optional external direct L3 cache */ - if ((cfg & CF_7_TC) == 0) { -#ifndef L3SZEXT - /* - * Assume L3 size is provided in the system information - * field of the Config register. This is usually the - * case on systems where the RM7k/RM9k processor is - * an upgrade from an R5000/RM52xx processor, such as - * the SGI O2. - */ - ci->ci_l3.size = (1 << 19) << - ((cfg & CF_7_TS) >> CF_7_TS_AL); - ci->ci_l3.linesize = R5K_LINE; - ci->ci_l3.setsize = ci->ci_l3.size; - ci->ci_l3.sets = 1; -#else - /* - * Assume machdep has initialized ci_l3 for us. - */ -#endif - } - if (ci->ci_l3.size != 0) { - ci->ci_cacheconfiguration |= CTYPE_HAS_XL3; - cfg |= CF_7_TE; - run_uncached(mips7k_l3_init, ci->ci_l3.size); - - } - /* internal 4-way L2 cache */ - if ((cfg & CF_7_SC) == 0) { - ci->ci_l2.size = 256 * 1024; /* fixed size */ - ci->ci_l2.linesize = R5K_LINE; - ci->ci_l2.setsize = ci->ci_l2.size / 4; - ci->ci_l2.sets = 4; - } - if (ci->ci_l2.size != 0) { - ci->ci_cacheconfiguration |= CTYPE_HAS_IL2; - if ((cfg & CF_7_SE) == 0) { - cfg |= CF_7_SE; - run_uncached(mips7k_l2_init, ci->ci_l2.size); - } - } - break; -#endif /* CPU_RM7000 */ - } - - ci->ci_l1inst.setsize = ci->ci_l1inst.size >> setshift; - ci->ci_l1inst.sets = setshift == 2 ? 4 : 2; - ci->ci_l1data.setsize = ci->ci_l1data.size >> setshift; - ci->ci_l1data.sets = setshift == 2 ? 4 : 2; - - cache_valias_mask = - (max(ci->ci_l1inst.setsize, ci->ci_l1data.setsize) - 1) & - ~PAGE_MASK; - - if (cache_valias_mask != 0) { - cache_valias_mask |= PAGE_MASK; - pmap_prefer_mask = cache_valias_mask; - } - - ci->ci_SyncCache = Mips5k_SyncCache; - ci->ci_InvalidateICache = Mips5k_InvalidateICache; - ci->ci_InvalidateICachePage = Mips5k_InvalidateICachePage; - ci->ci_SyncICache = Mips5k_SyncICache; - ci->ci_SyncDCachePage = Mips5k_SyncDCachePage; - ci->ci_HitSyncDCachePage = Mips5k_HitSyncDCachePage; - ci->ci_HitSyncDCache = Mips5k_HitSyncDCache; - ci->ci_HitInvalidateDCache = Mips5k_HitInvalidateDCache; - ci->ci_IOSyncDCache = Mips5k_IOSyncDCache; - - ncfg = (cfg & ~CFGR_CCA_MASK) | CCA_CACHED; - if (cfg != ncfg) - run_uncached(mips5k_c0_cca_update, ncfg); -} - -/* - * Writeback and invalidate all caches. - */ -void -Mips5k_SyncCache(struct cpu_info *ci) -{ - vaddr_t sva, eva; -#ifdef CPU_R4600 - /* - * Revision 1 R4600 need to perform `Index' cache operations with - * interrupt disabled, to make sure both ways are correctly updated. - */ - register_t sr = disableintr(); -#endif - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l1inst.size; - while (sva != eva) { - cache(IndexInvalidate_I, 0, sva); - sva += R5K_LINE; - } - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l1data.size; - while (sva != eva) { - cache(IndexWBInvalidate_D, 0, sva); - sva += R5K_LINE; - } - -#ifdef CPU_R4600 - setsr(sr); -#endif - -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) { - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l2.size; - while (sva != eva) { - cache(IndexWBInvalidate_S, 0, sva); - sva += R5K_LINE; - } - } else -#endif -#ifdef CPU_R5000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_XL2) { - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l2.size; - reset_taglo(); - while (sva != eva) { - cache(InvalidatePage_S, 0, sva); - sva += R5K_PAGE; - } - } else -#endif - { - } - -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_XL3) { - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + ci->ci_l3.size; - reset_taglo(); - while (sva != eva) { - cache(InvalidatePage_T, 0, sva); - sva += R5K_PAGE; - } - } -#endif - - mips_sync(); -} - -/* - * Invalidate I$ for the given range. - */ -void -Mips5k_InvalidateICache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va, sva, eva, iva; - vsize_t sz, offs; -#ifdef CPU_R4600 - /* - * Revision 1 R4600 need to perform `Index' cache operations with - * interrupt disabled, to make sure both ways are correctly updated. - */ - register_t sr = disableintr(); -#endif - - /* extend the range to integral cache lines */ - va = _va & ~(R5K_LINE - 1); - sz = ((_va + _sz + R5K_LINE - 1) & ~(R5K_LINE - 1)) - va; - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - offs = ci->ci_l1inst.setsize; - /* keep only the index bits */ - sva |= va & (offs - 1); - eva = sva + sz; - - switch (ci->ci_l1inst.sets) { - default: -#ifdef CPU_RM7000 - case 4: - while (sva != eva) { - iva = sva; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - sva += R5K_LINE; - } - break; -#endif -#if defined(CPU_R5000) || defined(CPU_R4600) - case 2: - iva = sva + offs; - while (sva != eva) { - cache(IndexInvalidate_I, 0, iva); - cache(IndexInvalidate_I, 0, sva); - iva += R5K_LINE; - sva += R5K_LINE; - } - break; -#endif - } - -#ifdef CPU_R4600 - setsr(sr); -#endif - mips_sync(); -} - -/* - * Register a given page for I$ invalidation. - */ -void -Mips5k_InvalidateICachePage(struct cpu_info *ci, vaddr_t va) -{ - /* - * Mark the particular page index bits as needing to be flushed. - */ - ci->ci_cachepending_l1i |= - 1ULL << ((va & (ci->ci_l1inst.setsize - 1)) >> PAGE_SHIFT); -} - -/* - * Perform postponed I$ invalidation. - */ -void -Mips5k_SyncICache(struct cpu_info *ci) -{ - vaddr_t sva, eva, iva; - vsize_t offs; - uint64_t idx; -#ifdef CPU_R4600 - register_t sr; -#endif - - if (ci->ci_cachepending_l1i == 0) - return; - -#ifdef CPU_R4600 - /* - * Revision 1 R4600 need to perform `Index' cache operations with - * interrupt disabled, to make sure both ways are correctly updated. - */ - sr = disableintr(); -#endif - - offs = ci->ci_l1inst.setsize; - - if (ci->ci_l1inst.setsize <= PAGE_SIZE) { - ci->ci_cachepending_l1i = 0; - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - eva = sva + offs; - switch (ci->ci_l1inst.sets) { - default: -#ifdef CPU_RM7000 - case 4: - while (sva != eva) { - iva = sva; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - sva += R5K_LINE; - } - break; -#endif -#if defined(CPU_R5000) || defined(CPU_R4600) - case 2: - iva = sva + offs; - while (sva != eva) { - cache(IndexInvalidate_I, 0, iva); - cache(IndexInvalidate_I, 0, sva); - iva += R5K_LINE; - sva += R5K_LINE; - } - break; -#endif - } - } else { - /* - * Iterate on all pending page index bits. - */ - for (idx = 0; ci->ci_cachepending_l1i != 0; idx++) { - if ((ci->ci_cachepending_l1i & (1ULL << idx)) == 0) - continue; - - sva = PHYS_TO_XKPHYS(idx << PAGE_SHIFT, CCA_CACHED); - eva = sva + offs; - switch (ci->ci_l1inst.sets) { - default: -#ifdef CPU_RM7000 - case 4: - while (sva != eva) { - iva = sva; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - iva += offs; - cache(IndexInvalidate_I, 0, iva); - sva += R5K_LINE; - } - break; -#endif -#if defined(CPU_R5000) || defined(CPU_R4600) - case 2: - iva = sva + offs; - while (sva != eva) { - cache(IndexInvalidate_I, 0, iva); - cache(IndexInvalidate_I, 0, sva); - iva += R5K_LINE; - sva += R5K_LINE; - } - break; -#endif - } - - ci->ci_cachepending_l1i &= ~(1ULL << idx); - } - } - -#ifdef CPU_R4600 - setsr(sr); -#endif -} - -static __inline__ void -mips5k_hitwbinv_primary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWBInvalidate_D, 0, va); - va += R5K_LINE; - } -} - -static __inline__ void -mips5k_hitwbinv_secondary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWBInvalidate_S, 0, va); - cache(HitWBInvalidate_D, 0, va); /* orphans in L1 */ - va += R5K_LINE; - } -} - -/* - * Writeback D$ for the given page. - */ -void -Mips5k_SyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ -#ifdef CPU_R4600 - /* - * Revision 1 R4600 need to perform `Index' cache operations with - * interrupt disabled, to make sure both ways are correctly updated. - */ - register_t sr = disableintr(); -#endif - - switch (ci->ci_l1data.sets) { - default: -#ifdef CPU_RM7000 - case 4: - /* - * On RM7000 and RM9000, the D$ cache set is never larger than - * the page size, causing it to behave as a physically-indexed - * cache. We can thus use Hit operations on the physical - * address. - */ - if ((ci->ci_cacheconfiguration & CTYPE_HAS_IL2) == 0) { - mips5k_hitwbinv_primary(PHYS_TO_XKPHYS(pa, CCA_CACHED), - PAGE_SIZE); - } /* else - done below */ - break; -#endif -#if defined(CPU_R5000) || defined(CPU_R4600) - case 2: - { - vaddr_t sva, eva, iva; - vsize_t offs; - - sva = PHYS_TO_XKPHYS(0, CCA_CACHED); - offs = ci->ci_l1data.setsize; - /* keep only the index bits */ - sva |= va & (offs - 1); - eva = sva + PAGE_SIZE; - - iva = sva + offs; - while (sva != eva) { - cache(IndexWBInvalidate_D, 0, iva); - cache(IndexWBInvalidate_D, 0, sva); - iva += R5K_LINE; - sva += R5K_LINE; - } - } - break; -#endif - } - -#ifdef CPU_R4600 - setsr(sr); -#endif - -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) { - mips5k_hitwbinv_secondary(PHYS_TO_XKPHYS(pa, CCA_CACHED), - PAGE_SIZE); - } -#endif - - mips_sync(); -} - -/* - * Writeback D$ for the given page, which is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -void -Mips5k_HitSyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - mips5k_hitwbinv_secondary(va, PAGE_SIZE); - else { -#ifdef CPU_R4600 - /* - * R4600 revision 2 needs to load from an uncached address - * before any Hit or CreateDEX operation. Alternatively, 12 - * nop (cycles) will empty the cache load buffer. - * We are only putting 10 here, and hope the overhead of the - * code around will provide the rest. - */ - nop10(); -#endif - mips5k_hitwbinv_primary(va, PAGE_SIZE); - } - - mips_sync(); -} - -/* - * Writeback D$ for the given range. Range is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -void -Mips5k_HitSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - - /* extend the range to integral cache lines */ - va = _va & ~(R5K_LINE - 1); - sz = ((_va + _sz + R5K_LINE - 1) & ~(R5K_LINE - 1)) - va; - - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - mips5k_hitwbinv_secondary(va, sz); - else { -#ifdef CPU_R4600 - /* - * R4600 revision 2 needs to load from an uncached address - * before any Hit or CreateDEX operation. Alternatively, 12 - * nop (cycles) will empty the cache load buffer. - * We are only putting 10 here, and hope the overhead of the - * code around will provide the rest. - */ - nop10(); -#endif - mips5k_hitwbinv_primary(va, sz); - } - - mips_sync(); -} - -/* - * Invalidate D$ for the given range. Range is expected to be currently - * mapped, allowing the use of `Hit' operations. This is less aggressive - * than using `Index' operations. - */ - -static __inline__ void -mips5k_hitinv_primary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitInvalidate_D, 0, va); - va += R5K_LINE; - } -} - -static __inline__ void -mips5k_hitinv_secondary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitInvalidate_S, 0, va); - cache(HitInvalidate_D, 0, va); /* orphans in L1 */ - va += R5K_LINE; - } -} - -void -Mips5k_HitInvalidateDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - - /* extend the range to integral cache lines */ - va = _va & ~(R5K_LINE - 1); - sz = ((_va + _sz + R5K_LINE - 1) & ~(R5K_LINE - 1)) - va; - - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - mips5k_hitinv_secondary(va, sz); - else { -#ifdef CPU_R4600 - /* - * R4600 revision 2 needs to load from an uncached address - * before any Hit or CreateDEX operation. Alternatively, 12 - * nop (cycles) will empty the cache load buffer. - * We are only putting 10 here, and hope the overhead of the - * code around will provide the rest. - */ - nop10(); -#endif - mips5k_hitinv_primary(va, sz); - } - - mips_sync(); -} - -static __inline__ void -mips5k_hitwb_primary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWriteback_D, 0, va); - va += R5K_LINE; - } -} - -#if 0 -static __inline__ void -mips5k_hitwb_secondary(vaddr_t va, vsize_t sz) -{ - vaddr_t eva; - - eva = va + sz; - while (va != eva) { - cache(HitWriteback_S, 0, va); - cache(HitWriteback_D, 0, va); /* orphans in L1 */ - va += R5K_LINE; - } -} -#endif - -/* - * Backend for bus_dmamap_sync(). Enforce coherency of the given range - * by performing the necessary cache writeback and/or invalidate - * operations. - */ -void -Mips5k_IOSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz, int how) -{ - vaddr_t va; - vsize_t sz; - int partial_start, partial_end; - - /* - * internal cache - */ - - /* extend the range to integral cache lines */ - va = _va & ~(R5K_LINE - 1); - sz = ((_va + _sz + R5K_LINE - 1) & ~(R5K_LINE - 1)) - va; - -#ifdef CPU_R4600 - /* - * R4600 revision 2 needs to load from an uncached address - * before any Hit or CreateDEX operation. Alternatively, 12 - * nop (cycles) will empty the cache load buffer. - * We are only putting 10 here, and hope the overhead of the - * code around will provide the rest. - */ - nop10(); -#endif - - switch (how) { - case CACHE_SYNC_R: - /* writeback partial cachelines */ - if (((_va | _sz) & (R5K_LINE - 1)) != 0) { - partial_start = va != _va; - partial_end = va + sz != _va + _sz; - } else { - partial_start = partial_end = 0; - } - if (partial_start) { -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - cache(HitWBInvalidate_S, 0, va); -#endif - cache(HitWBInvalidate_D, 0, va); - va += R5K_LINE; - sz -= R5K_LINE; - } - if (sz != 0 && partial_end) { - sz -= R5K_LINE; -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - cache(HitWBInvalidate_S, 0, va + sz); -#endif - cache(HitWBInvalidate_D, 0, va + sz); - } - - if (sz != 0) { -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - mips5k_hitinv_secondary(va, sz); - else -#endif - mips5k_hitinv_primary(va, sz); - } - break; - - case CACHE_SYNC_W: -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - mips5k_hitwbinv_secondary(va, sz); /* XXX */ - else -#endif - mips5k_hitwb_primary(va, sz); - break; - - case CACHE_SYNC_X: -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_IL2) - mips5k_hitwbinv_secondary(va, sz); - else -#endif - mips5k_hitwbinv_primary(va, sz); - break; - } - - /* - * external cache - */ - - switch (how) { - case CACHE_SYNC_W: - break; - case CACHE_SYNC_X: - case CACHE_SYNC_R: -#ifdef CPU_R5000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_XL2) { - /* align on external page size */ - va = _va & ~(R5K_PAGE - 1); - sz = ((_va + _sz + R5K_PAGE - 1) - va) / R5K_PAGE; - reset_taglo(); - while (sz != 0) { - cache(InvalidatePage_S, 0, va); - va += R5K_PAGE; - sz--; - } - } else -#endif -#ifdef CPU_RM7000 - if (ci->ci_cacheconfiguration & CTYPE_HAS_XL3) { - /* align on external page size */ - va = _va & ~(R5K_PAGE - 1); - sz = ((_va + _sz + R5K_PAGE - 1) - va) / R5K_PAGE; - reset_taglo(); - while (sz != 0) { - cache(InvalidatePage_T, 0, va); - va += R5K_PAGE; - sz--; - } - } else -#endif - { - } - break; - } - - mips_sync(); -} diff --git a/sys/arch/mips64/mips64/cache_tfp.c b/sys/arch/mips64/mips64/cache_tfp.c deleted file mode 100644 index 7cb9f6a8851..00000000000 --- a/sys/arch/mips64/mips64/cache_tfp.c +++ /dev/null @@ -1,229 +0,0 @@ -/* $OpenBSD: cache_tfp.c,v 1.8 2021/03/11 11:16:59 jsg Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * R8000 cache routines. - * - * These routines only handle the L1 cache found onboard the R8000. - * The L2 (Streaming Cache) cache handling is apparently quite different - * across R8000-based designs (well... the two of them: IP21 and IP26), - * and is handled on a per-platform basis. - */ - -#include <sys/param.h> -#include <sys/systm.h> - -#include <mips64/cache.h> -#include <machine/cpu.h> - -#include <uvm/uvm_extern.h> - -void tfp_dctw_zero(vaddr_t); -void tfp_inval_icache(vsize_t); - -#define TFP_DCTW_STEP 16UL /* 4 words per tag */ - -void -tfp_ConfigCache(struct cpu_info *ci) -{ - register_t cfg; - - cfg = cp0_get_config(); - - /* - * XXX It would make sense to trust the configuration register, - * XXX but at least on my system it would report a 32KB I$, while - * XXX ARCS reports the architected 16KB. - * XXX Better not trust anything from the configuration register, - * XXX then. - */ -#if 0 - ci->ci_l1inst.size = (1 << 11) << ((cfg >> 9) & 0x07); /* IC */ - if (cfg & (1 << 5)) /* IB */ - ci->ci_l1inst.linesize = 32; - else - ci->ci_l1inst.linesize = 16; - - ci->ci_l1data.size = (1 << 12) << ((cfg >> 6) & 0x07); /* DC */ - if (cfg & (1 << 4)) /* DB */ - ci->ci_l1data.linesize = 32; - else - ci->ci_l1data.linesize = 16; -#else - ci->ci_l1inst.size = 16384; - ci->ci_l1inst.linesize = TFP_DCTW_STEP; /* but handled in 32b chunks */ - ci->ci_l1data.size = 16384; - ci->ci_l1data.linesize = TFP_DCTW_STEP; -#endif - - /* R8000 L1 caches are direct */ - ci->ci_l1inst.setsize = ci->ci_l1inst.size; - ci->ci_l1inst.sets = 1; - ci->ci_l1data.setsize = ci->ci_l1data.size; - ci->ci_l1data.sets = 1; - - cache_valias_mask = - (max(ci->ci_l1inst.size, ci->ci_l1data.size) - 1) & - ~PAGE_MASK; -#ifdef DIAGNOSTIC - if (cache_valias_mask != 0) - panic("page size is too small"); -#endif - - /* R8000 L2 cache are platform-specific, and not covered here */ - memset(&ci->ci_l2, 0, sizeof(struct cache_info)); - memset(&ci->ci_l3, 0, sizeof(struct cache_info)); - - ci->ci_SyncCache = tfp_SyncCache; - ci->ci_InvalidateICache = tfp_InvalidateICache; - ci->ci_InvalidateICachePage = tfp_InvalidateICachePage; - ci->ci_SyncICache = tfp_SyncICache; - ci->ci_SyncDCachePage = tfp_SyncDCachePage; - ci->ci_HitSyncDCachePage = tfp_SyncDCachePage; - ci->ci_HitSyncDCache = tfp_HitSyncDCache; - ci->ci_HitInvalidateDCache = tfp_HitInvalidateDCache; - ci->ci_IOSyncDCache = tfp_IOSyncDCache; -} - -/* - * Writeback and invalidate all caches. - */ -void -tfp_SyncCache(struct cpu_info *ci) -{ - vaddr_t va, eva; - register_t sr; - - tfp_InvalidateICache(ci, 0, ci->ci_l1inst.size); - - sr = disableintr(); - eva = ci->ci_l1data.size; - for (va = 0; va < eva; va += TFP_DCTW_STEP) - tfp_dctw_zero(va); - setsr(sr); -} - -/* - * Invalidate I$ for the given range. - */ -void -tfp_InvalidateICache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - void (*inval_subr)(vsize_t); - - if (ci->ci_cachepending_l1i != 0) - return; - - if (_sz >= ci->ci_l1inst.size) { - ci->ci_cachepending_l1i = 1; - } else { - /* extend the range to multiple of 32 bytes */ - va = _va & ~(32UL - 1); - sz = ((_va + _sz + 32 - 1) & ~(32UL - 1)) - va; - - /* compute cache offset */ - va &= (ci->ci_l1inst.size - 1); - inval_subr = (void (*)(vsize_t)) - ((vaddr_t)tfp_inval_icache + va); - (*inval_subr)(sz); - } -} - -/* - * Register a given page for I$ invalidation. - */ -void -tfp_InvalidateICachePage(struct cpu_info *ci, vaddr_t va) -{ - /* - * Since the page size matches the size of the instruction cache, - * all we need to do here is remember there are postponed flushes. - */ - ci->ci_cachepending_l1i = 1; -} - -/* - * Perform postponed I$ invalidation. - */ -void -tfp_SyncICache(struct cpu_info *ci) -{ - if (ci->ci_cachepending_l1i != 0) { - tfp_inval_icache(ci->ci_l1inst.size); - ci->ci_cachepending_l1i = 0; - } -} - -/* - * Writeback D$ for the given page. - */ -void -tfp_SyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ - /* nothing to do, D$ is write-through */ -} - -/* - * Writeback D$ for the given range. - */ -void -tfp_HitSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - /* nothing to do, D$ is write-through */ -} - -/* - * Invalidate D$ for the given range. - */ -void -tfp_HitInvalidateDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va, eva; - vsize_t sz; - register_t sr; - - /* extend the range to multiples of the D$ tag span */ - va = _va & ~(TFP_DCTW_STEP - 1); - sz = ((_va + _sz + TFP_DCTW_STEP - 1) & ~(TFP_DCTW_STEP - 1)) - va; - - sr = disableintr(); - for (eva = va + sz; va < eva; va += TFP_DCTW_STEP) - tfp_dctw_zero(va); - setsr(sr); -} - -/* - * Backend for bus_dmamap_sync(). Enforce coherency of the given range - * by performing the necessary cache writeback and/or invalidate - * operations. - */ -void -tfp_IOSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz, int how) -{ - switch (how) { - case CACHE_SYNC_R: - case CACHE_SYNC_X: - tfp_HitInvalidateDCache(ci, _va, _sz); - break; - case CACHE_SYNC_W: - /* nothing to do */ - break; - } -} diff --git a/sys/arch/mips64/mips64/cache_tfp_subr.S b/sys/arch/mips64/mips64/cache_tfp_subr.S deleted file mode 100644 index bac506ced65..00000000000 --- a/sys/arch/mips64/mips64/cache_tfp_subr.S +++ /dev/null @@ -1,99 +0,0 @@ -/* $OpenBSD: cache_tfp_subr.S,v 1.3 2015/09/23 19:04:31 miod Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <machine/param.h> -#include <machine/asm.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> - -#include "assym.h" - - .set mips4 - .set noreorder - -/* - * The R8000 processor does not have documented cache maintainance - * instructions. While this is not really a problem for D$, which is - * write-through and physically tagged, this is a problem for I$, - * which is virtually tagged. - * - * Since there is no way to invalidate I$, the best we can do is - * override existing cache lines to evict them from the cache. - * - * The following routine will attempt to do so. It spans the whole I$ - * cache size, and may be invoked from any offset multiple of 32 bytes - * (in case a smaller portion of the cache needs to be invalidated). - * - * void tfp_inval_icache(register_t size) - */ - .align 14 -LEAF(tfp_inval_icache, 0) /* { */ - -#define ICACHE_CHUNK_INVALIDATE \ - subu a0, 32; \ - NOP; \ - NOP; \ - NOP; \ - blez a0, 9f; \ - NOP; \ - NOP; \ - NOP - -#define ICACHE_256B_INVALIDATE \ - ICACHE_CHUNK_INVALIDATE; ICACHE_CHUNK_INVALIDATE; \ - ICACHE_CHUNK_INVALIDATE; ICACHE_CHUNK_INVALIDATE; \ - ICACHE_CHUNK_INVALIDATE; ICACHE_CHUNK_INVALIDATE; \ - ICACHE_CHUNK_INVALIDATE; ICACHE_CHUNK_INVALIDATE; - -#define ICACHE_2KB_INVALIDATE \ - ICACHE_256B_INVALIDATE; ICACHE_256B_INVALIDATE; \ - ICACHE_256B_INVALIDATE; ICACHE_256B_INVALIDATE; \ - ICACHE_256B_INVALIDATE; ICACHE_256B_INVALIDATE; \ - ICACHE_256B_INVALIDATE; ICACHE_256B_INVALIDATE - -#define ICACHE_16KB_INVALIDATE \ - ICACHE_2KB_INVALIDATE; ICACHE_2KB_INVALIDATE; \ - ICACHE_2KB_INVALIDATE; ICACHE_2KB_INVALIDATE; \ - ICACHE_2KB_INVALIDATE; ICACHE_2KB_INVALIDATE; \ - ICACHE_2KB_INVALIDATE; ICACHE_2KB_INVALIDATE - - ICACHE_16KB_INVALIDATE - - b tfp_inval_icache /* wrap around */ - NOP -9: - j ra - NOP -END(tfp_inval_icache) /* } */ - -/* - * Clear the D$ cache tag for the given address. - * Interrupts must be disabled (to be free to alter the Vaddr register). - */ - -#define DCTW .align 4; .word 0x4300000a; SSNOP; SSNOP; SSNOP - -LEAF(tfp_dctw_zero, 0) /* { */ - DMTC0 a0, COP_0_VADDR - MTC0_HAZARD - DMTC0 zero, COP_0_DCACHE - MTC0_HAZARD - DCTW - j ra - NOP -END(tfp_dctw_zero) /* } */ diff --git a/sys/arch/mips64/mips64/clock.c b/sys/arch/mips64/mips64/clock.c index bd2e01c2d61..05ca4fce5e0 100644 --- a/sys/arch/mips64/mips64/clock.c +++ b/sys/arch/mips64/mips64/clock.c @@ -1,4 +1,4 @@ -/* $OpenBSD: clock.c,v 1.43 2021/03/04 15:38:06 visa Exp $ */ +/* $OpenBSD: clock.c,v 1.44 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -67,9 +67,6 @@ clockmatch(struct device *parent, void *vcf, void *aux) { struct mainbus_attach_args *maa = aux; -#ifdef CPU_R8000 - return 0; /* shouldn't be in the kernel configuration anyway */ -#endif return strcmp(maa->maa_name, clock_cd.cd_name) == 0; } diff --git a/sys/arch/mips64/mips64/context.S b/sys/arch/mips64/mips64/context.S index 4fd81d21562..5b82bf6b4c2 100644 --- a/sys/arch/mips64/mips64/context.S +++ b/sys/arch/mips64/mips64/context.S @@ -1,4 +1,4 @@ -/* $OpenBSD: context.S,v 1.62 2021/04/29 12:49:19 visa Exp $ */ +/* $OpenBSD: context.S,v 1.63 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -87,28 +87,6 @@ LEAF(cpu_idle_cycle_wait, 0) NOP END(cpu_idle_cycle_wait) -LEAF(cpu_idle_cycle_rm7k, 0) - /* - * RM7000 errata #38: The R4600, R4640, R4700, R5000, RM52xx, - * and RM7xxx processors do not handle bus signalling properly - * in the standby mode, which can cause incorrect behaviour - * upon leaving the mode. This can be avoided by flushing - * any writes from the pipeline before the WAIT instruction - * is executed. - */ - mfc0 a0, COP_0_STATUS_REG # save status - ori a1, a0, SR_INT_ENAB - xori a1, SR_INT_ENAB - mtc0 a1, COP_0_STATUS_REG # disable interrupts - sync # flush pending writes - mtc0 a1, COP_0_STATUS_REG # stall until W stage - wait # enter standby mode - mtc0 a0, COP_0_STATUS_REG # stall until W stage, - # and restore status - j ra - NOP -END(cpu_idle_cycle_rm7k) - /* * cpu_switchto_asm(struct proc *oldproc, struct proc *newproc) */ @@ -121,15 +99,8 @@ NON_LEAF(cpu_switchto_asm, FRAMESZ(CF_SZ), ra) REG_S ra, CF_RA_OFFS(sp) .mask 0x80000000, (CF_RA_OFFS - FRAMESZ(CF_SZ)) -#ifdef CPU_R8000 /* XXX everywhere where MFC0_HAZARD is not empty */ - MFC0 v0, COP_0_STATUS_REG - MFC0_HAZARD - beqz a0, 1f - NOP -#else beqz a0, 1f MFC0 v0, COP_0_STATUS_REG -#endif REG_S s0, PCB_CONTEXT+0*REGSZ(t3) # do a 'savectx()' REG_S s1, PCB_CONTEXT+1*REGSZ(t3) @@ -181,35 +152,8 @@ NON_LEAF(cpu_switchto_asm, FRAMESZ(CF_SZ), ra) PTR_ADDU t1, t1, v0 #endif lw v0, PM_ASID(t1) # ->pm_asid[cpuid].pma_asid -#ifdef CPU_R8000 - PTR_L t0, PCB_SEGTAB(t3) # save pcb_segtab for - DMTC0 t0, COP_0_UBASE # Utlbmiss handler - MTC0_HAZARD -#endif - -#ifdef CPU_R4000 - /* - * Restore the number of wired TLB entries to the minimal possible - * value, in case the EOP errata workaround has caused more wired - * entries to be created. - */ - lw a0, PCB_NWIRED(t3) - beqz a0, 1f - sw zero, PCB_NWIRED(t3) - - li a1, UPAGES / 2 - move s0, v0 # save asid - mtc0 a1, COP_0_TLB_WIRED - jal tlb_flush # clear formerly wired entries - addu a0, a1, a0 - move v0, s0 -1: -#endif #if UPAGES > 1 /* { */ -#ifdef CPU_R8000 -#error Your processor has just been eaten by a grue. -#endif or v0, t3 dmtc0 v0, COP_0_TLB_HI # init high entry (tlbid) diff --git a/sys/arch/mips64/mips64/cp0access.S b/sys/arch/mips64/mips64/cp0access.S index 8c121b6d546..cd2a34b6c6e 100644 --- a/sys/arch/mips64/mips64/cp0access.S +++ b/sys/arch/mips64/mips64/cp0access.S @@ -1,4 +1,4 @@ -/* $OpenBSD: cp0access.S,v 1.22 2021/04/29 12:49:19 visa Exp $ */ +/* $OpenBSD: cp0access.S,v 1.23 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -182,43 +182,19 @@ LEAF(cp0_get_count, 0) NOP END(cp0_get_count) -#ifndef CPU_R8000 LEAF(cp0_set_compare, 0) MTC0 a0, COP_0_COMPARE MTC0_HAZARD j ra NOP END(cp0_set_compare) -#endif - -#ifdef CPU_R8000 -LEAF(cp0_reset_cause, 0) - DMFC0 v0, COP_0_CAUSE_REG - MFC0_HAZARD - or v0, a0 - xor v0, a0 - DMTC0 v0, COP_0_CAUSE_REG - MTC0_HAZARD - j ra - NOP -END(cp0_reset_cause) - -LEAF(cp0_set_trapbase, 0) - DMTC0 a0, COP_0_TRAPBASE - MTC0_HAZARD - j ra - NOP -END(cp0_set_trapbase) -#endif LEAF(cpu_rnd_messybits, 0) MFC0 v0, COP_0_COUNT MFC0_HAZARD -#ifndef CPU_R8000 MFC0 v1, COP_0_BAD_VADDR MFC0_HAZARD xor v0, v1 -#endif j ra NOP END(cpu_rnd_messybits) diff --git a/sys/arch/mips64/mips64/cpu.c b/sys/arch/mips64/mips64/cpu.c index a485808b4b5..0ac501e49ad 100644 --- a/sys/arch/mips64/mips64/cpu.c +++ b/sys/arch/mips64/mips64/cpu.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.c,v 1.77 2020/07/22 08:04:41 fcambus Exp $ */ +/* $OpenBSD: cpu.c,v 1.78 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 1997-2004 Opsycon AB (www.opsycon.se) @@ -50,7 +50,6 @@ struct cpuset cpus_running; #endif extern void cpu_idle_cycle_nop(void); -extern void cpu_idle_cycle_rm7k(void); extern void cpu_idle_cycle_wait(void); void (*cpu_idle_cycle_func)(void) = cpu_idle_cycle_nop; @@ -84,7 +83,6 @@ cpuattach(struct device *parent, struct device *dev, void *aux) struct cpu_hwinfo *ch = caa->caa_hw; struct cpu_info *ci; int cpuno = dev->dv_unit; - int isr16k = 0; int fptype, vers_maj, vers_min; int displayver; @@ -141,65 +139,6 @@ cpuattach(struct device *parent, struct device *dev, void *aux) vers_maj = (ch->c0prid >> 4) & 0x0f; vers_min = ch->c0prid & 0x0f; switch (ch->type) { - case MIPS_R4000: - if (vers_maj < 4) - printf("MIPS R4000 CPU"); - else { - vers_maj -= 3; - printf("MIPS R4400 CPU"); - } - fptype = MIPS_R4000; - break; -#if 0 - case MIPS_R4100: - printf("NEC VR41xx CPU"); - break; - case MIPS_R4200: - printf("NEC VR4200 CPU (ICE)"); - break; - case MIPS_R4300: - printf("NEC VR4300 CPU"); - break; -#endif - case MIPS_R4600: - printf("QED R4600 Orion CPU"); - break; -#if 0 - case MIPS_R4700: - printf("QED R4700 Orion CPU"); - break; -#endif - case MIPS_R5000: - printf("MIPS R5000 CPU"); - break; - case MIPS_RM52X0: - printf("PMC-Sierra RM52X0 CPU"); - break; - case MIPS_RM7000: - if (vers_maj < 2) - printf("PMC-Sierra RM7000 CPU"); - else - printf("PMC-Sierra RM7000A CPU"); - break; - case MIPS_R8000: - printf("MIPS R8000 CPU"); - break; - case MIPS_RM9000: - printf("PMC-Sierra RM9000 CPU"); - break; - case MIPS_R10000: - printf("MIPS R10000 CPU"); - break; - case MIPS_R12000: - printf("MIPS R12000 CPU"); - break; - case MIPS_R14000: - if (vers_maj > 2) { - vers_maj -= 2; - isr16k = 1; - } - printf("R1%d000 CPU", isr16k ? 6 : 4); - break; case MIPS_LOONGSON2: switch (ch->c0prid & 0xff) { case 0x00: @@ -272,51 +211,6 @@ cpuattach(struct device *parent, struct device *dev, void *aux) #endif displayver = 0; break; - case MIPS_R4000: - printf("R4010 FPC"); - break; -#if 0 - case MIPS_R4200: - printf("VR4200 FPC (ICE)"); - break; -#endif - case MIPS_R4600: - printf("R4600 Orion FPC"); - break; -#if 0 - case MIPS_R4700: - printf("R4700 Orion FPC"); - break; -#endif - case MIPS_R5000: - printf("R5000 based FPC"); - break; - case MIPS_RM52X0: - printf("RM52X0 FPC"); - break; - case MIPS_RM7000: - printf("RM7000 FPC"); - break; - case MIPS_R8000: - printf("R8010 FPU"); - break; - case MIPS_RM9000: - printf("RM9000 FPC"); - break; - case MIPS_R10000: - printf("R10000 FPU"); - break; - case MIPS_R12000: - printf("R12000 FPU"); - break; - case MIPS_R14000: - if (isr16k) { - if (ch->c0prid == ch->c1prid) - vers_maj -= 2; - printf("R16000 FPU"); - } else - printf("R14000 FPU"); - break; case MIPS_LOONGSON2: switch (ch->c1prid & 0xff) { case 0x00: @@ -392,13 +286,6 @@ cpuattach(struct device *parent, struct device *dev, void *aux) if (cpuno == 0) { switch (ch->type) { - case MIPS_R4600: - case MIPS_R4700: - case MIPS_R5000: - case MIPS_RM52X0: - case MIPS_RM7000: - cpu_idle_cycle_func = cpu_idle_cycle_rm7k; - break; case MIPS_CN50XX: case MIPS_CN61XX: case MIPS_CN71XX: diff --git a/sys/arch/mips64/mips64/db_machdep.c b/sys/arch/mips64/mips64/db_machdep.c index cb3ab0f485c..877cc1c9999 100644 --- a/sys/arch/mips64/mips64/db_machdep.c +++ b/sys/arch/mips64/mips64/db_machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: db_machdep.c,v 1.55 2019/11/07 14:44:53 mpi Exp $ */ +/* $OpenBSD: db_machdep.c,v 1.56 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 1998-2003 Opsycon AB (www.opsycon.se) @@ -380,8 +380,6 @@ db_trap_trace_cmd(db_expr_t addr, int have_addr, db_expr_t count, char *m) void db_print_tlb(uint tlbno, uint64_t tlblo) { - paddr_t pa; -#ifndef CPU_R8000 /* short description of coherency attributes */ static const char *attr[] = { "CCA 0", @@ -393,22 +391,17 @@ db_print_tlb(uint tlbno, uint64_t tlblo) "CCA 6", "NCACC" }; -#endif + paddr_t pa; pa = pfn_to_pad(tlblo); -#ifdef CPU_R8000 - pa |= ptoa(tlbno % 128); -#endif if (tlblo & PG_V) { db_printf("%016lx ", pa); #ifdef CPU_MIPS64R2 db_printf("%c", tlblo & PG_XI ? 'X' : ' '); #endif db_printf("%c", tlblo & PG_M ? 'M' : ' '); -#ifndef CPU_R8000 db_printf("%c", tlblo & PG_G ? 'G' : ' '); db_printf("%s ", attr[(tlblo >> 3) & 7]); -#endif } else { db_printf("invalid "); } @@ -484,19 +477,12 @@ db_dump_tlb_cmd(db_expr_t addr, int have_addr, db_expr_t count, char *m) asid = (tlb.tlb_hi & PG_ASID_MASK) >> PG_ASID_SHIFT; va = tlb.tlb_hi & ~((vaddr_t)PG_ASID_MASK); -#ifdef CPU_R8000 - if ((int64_t)va < 0) - asid = 0; /* KV1 addresses ignore ASID */ - va |= ptoa((tlbno ^ asid) % 128); -#endif db_printf("%3d v=%016lx", tlbno, va); db_printf("/%02x ", asid); db_print_tlb(tlbno, tlb.tlb_lo0); -#ifndef CPU_R8000 db_print_tlb(tlbno, tlb.tlb_lo1); db_printf(" sz=%llx", tlb.tlb_mask); -#endif } else if (pid < 0) { db_printf("%3d v=invalid ", tlbno); } diff --git a/sys/arch/mips64/mips64/exception.S b/sys/arch/mips64/mips64/exception.S index 81d55390492..0460a6e68d4 100644 --- a/sys/arch/mips64/mips64/exception.S +++ b/sys/arch/mips64/mips64/exception.S @@ -1,4 +1,4 @@ -/* $OpenBSD: exception.S,v 1.42 2021/04/29 12:49:19 visa Exp $ */ +/* $OpenBSD: exception.S,v 1.43 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -70,11 +70,7 @@ k_exception_table: PTR_VAL k_general /* T_COP_UNUSABLE */ PTR_VAL k_general /* T_OVFLOW */ PTR_VAL k_general /* T_TRAP */ -#ifdef CPU_R4000 - PTR_VAL vcei /* T_VCEI */ -#else PTR_VAL k_general /* T_VCEI */ -#endif PTR_VAL k_general /* T_FPE */ PTR_VAL k_general /* T_IWATCH */ PTR_VAL k_general @@ -91,11 +87,7 @@ k_exception_table: PTR_VAL k_general PTR_VAL k_general PTR_VAL k_general /* T_CACHEERR */ -#ifdef CPU_R4000 - PTR_VAL vced /* T_VCED */ -#else PTR_VAL k_general /* T_VCED */ -#endif u_exception_table: PTR_VAL u_intr /* T_INT */ @@ -112,11 +104,7 @@ u_exception_table: PTR_VAL u_general /* T_COP_UNUSABLE */ PTR_VAL u_general /* T_OVFLOW */ PTR_VAL u_general /* T_TRAP */ -#ifdef CPU_R4000 - PTR_VAL vcei /* T_VCEI */ -#else PTR_VAL u_general /* T_VCEI */ -#endif PTR_VAL u_general /* T_FPE */ PTR_VAL u_general /* T_IWATCH */ PTR_VAL u_general @@ -133,11 +121,7 @@ u_exception_table: PTR_VAL u_general PTR_VAL u_general PTR_VAL u_general /* T_CACHEERR */ -#ifdef CPU_R4000 - PTR_VAL vced /* T_VCED */ -#else PTR_VAL u_general /* T_VCED */ -#endif .set noreorder # Noreorder is default style! @@ -146,11 +130,6 @@ u_exception_table: * to the vector area and must thus be PIC and less than 128 * bytes long to fit. Only k0 and k1 may be used at this time. */ - .globl cache_err -cache_err: -#ifdef CPU_R4000 - nop -#endif .globl exception exception: .set noat @@ -391,27 +370,3 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra) ERET .set at END(u_general) - -#ifdef CPU_R4000 -LEAF(vced, 0) - .set noat - dmfc0 k0, COP_0_BAD_VADDR - ori k0, k0, 3 # need to align badvaddr... - xori k0, k0, 3 # ...to a word boundary. - cache 0x17, 0(k0) # HitWBInvalidate_S - cache 0x11, 0(k0) # HitWBInvalidate_D - LI k0, 0 - ERET - .set at -END(vced) - -LEAF(vcei, 0) - .set noat - dmfc0 k0, COP_0_BAD_VADDR - cache 0x17, 0(k0) # HitWBInvalidate_S - cache 0x10, 0(k0) # HitInvalidate_I - LI k0, 0 - ERET - .set at -END(vcei) -#endif diff --git a/sys/arch/mips64/mips64/exception_tfp.S b/sys/arch/mips64/mips64/exception_tfp.S deleted file mode 100644 index 6fdf3686b4d..00000000000 --- a/sys/arch/mips64/mips64/exception_tfp.S +++ /dev/null @@ -1,422 +0,0 @@ -/* $OpenBSD: exception_tfp.S,v 1.8 2021/02/11 14:44:13 visa Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * k_general and u_general are heavily based upon their counterparts in - * exception.S under the following licence terms: - */ -/* - * Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -/* - * Trap handling subpage for R8000 systems. - */ - -#include <machine/param.h> -#include <machine/asm.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/pte.h> -#include <machine/regnum.h> -#include <machine/cpustate.h> - -#include "assym.h" - -#ifdef MIPS_PTE64 -#error "R8000 doesn't need 64-bit PTE" -#endif - -#define TLBW .align 4; .word 0x43000002 - - .set mips4 - .set noreorder - - .text - - .align 12 - .globl tfp_trapbase -tfp_trapbase: - - /* - * 000: tlb miss handler for U region - */ - .align 10 - - .ent utlb_miss, 0 -utlb_miss: - .set noat - .align 4 - PRE_MFC0_ADDR_HAZARD - DMFC0 k0, COP_0_VADDR - MFC0_HAZARD - DMTC0 k0, COP_0_WORK0 - MTC0_HAZARD - PTR_SRL k0, SEGSHIFT - sltiu k1, k0, PMAP_SEGTABSIZE - beqz k1, _inv_seg - NOP - DMFC0 k1, COP_0_UBASE # PCB_SEGTAB(CI_CURPROCPADDR(curcpu)) - MFC0_HAZARD - PTR_SLL k0, LOGREGSZ - PTR_ADDU k1, k0 - PTR_L k1, 0(k1) # get pointer to page directory - DMFC0 k0, COP_0_WORK0 # saved COP_0_VADDR - MFC0_HAZARD - PTR_SRL k0, (DIRSHIFT - LOGREGSZ) - beqz k1, _inv_seg - andi k0, (NPDEPG - 1) << LOGREGSZ - PTR_ADDU k1, k0 - PTR_L k1, 0(k1) # get pointer to page table - DMFC0 k0, COP_0_WORK0 # saved COP_0_VADDR - MFC0_HAZARD - beqz k1, _inv_seg - PTR_SRL k0, PAGE_SHIFT - PTE_LOG - andi k0, (NPTEPG - 1) << PTE_LOG - PTR_ADDU k1, k0 - PTE_LOAD k0, 0(k1) # get pte - DMTC0 k0, COP_0_TLB_LO - MTC0_HAZARD - TLBW - ERET - -_inv_seg: - DMFC0 k0, COP_0_STATUS_REG - MFC0_HAZARD - andi k0, SR_KSU_USER - bnez k0, u_general - NOP - b k_general - NOP - - .set at - .end utlb_miss - - /* - * 400: tlb miss handler for KV0 region - */ - .align 10 - - .ent kv0tlb_miss, 0 -kv0tlb_miss: - .set noat - /* - * Since we do not set up KV0 mappings, fall through directly - * into the `invalid address' fault handling. - */ - .align 4 - b _inv_seg - NOP - .set at - .end kv0tlb_miss - - /* - * 800: tlb miss handler for KV1 region - */ - .align 10 - - .ent kv1tlb_miss, 0 -kv1tlb_miss: - .set noat - .align 4 - PRE_MFC0_ADDR_HAZARD - DMFC0 k0, COP_0_VADDR - MFC0_HAZARD - DMFC0 k1, COP_0_STATUS_REG - MFC0_HAZARD - andi k1, SR_KSU_USER - bnez k1, u_general - LA k1, VM_MIN_KERNEL_ADDRESS - PTR_SUBU k0, k1 - DMFC0 k1, COP_0_WORK1 # Sysmapsize - MFC0_HAZARD - PTR_SRL k0, PAGE_SHIFT - sltu k1, k0, k1 - beqz k1, k_general - PTR_SLL k0, 2 - DMFC0 k1, COP_0_GBASE # Sysmap - MFC0_HAZARD - PTR_ADDU k1, k0 - PTE_LOAD k0, 0(k1) # get pte - DMTC0 k0, COP_0_TLB_LO - MTC0_HAZARD - TLBW - ERET - .set at - .end kv1tlb_miss - - /* - * C00: tlb miss exception while servicing an exception - * tlb invalid exception - * tlb modified exception - * all other exceptions - */ - .align 10 - .ent exception, 0 -exception: - .set noat - .align 4 - DMFC0 k0, COP_0_STATUS_REG - MFC0_HAZARD - andi k0, SR_KSU_USER - DMFC0 k1, COP_0_CAUSE_REG - MFC0_HAZARD - bnez k0, u_general - and k1, CR_EXC_CODE - - LA k0, k_exception_table - PTR_ADDU k0, k1 - PTR_L k1, 0(k0) - j k1 - NOP - - .set at - .end exception - - /* - * Handle a TLB invalid exception from kernel mode. This implies there - * is a TLB match, but currently not valid. Check if the pte is now - * valid and update, or pass the mess to the regular exception handler. - */ -k_tlb_inv: - .set noat - .align 4 - PRE_MFC0_ADDR_HAZARD - DMFC0 k0, COP_0_VADDR - MFC0_HAZARD - LA k1, VM_MIN_KERNEL_ADDRESS - PTR_SUBU k0, k1 - DMFC0 k1, COP_0_WORK1 # Sysmapsize - MFC0_HAZARD - PTR_SRL k0, PAGE_SHIFT - sltu k1, k0, k1 - beqz k1, k_general - PTR_SLL k0, 2 - DMFC0 k1, COP_0_GBASE # Sysmap - MFC0_HAZARD - PTR_ADDU k1, k0 - PTE_LOAD k0, 0(k1) # get pte - andi k1, k0, PG_V - beqz k1, k_general # if not valid - NOP - - DMTC0 k0, COP_0_TLB_LO - MTC0_HAZARD - TLBW - ERET - .set at - -k_exception_table: - PTR_VAL k_general # interrupt - PTR_VAL k_general # TLB modification - PTR_VAL k_tlb_inv - PTR_VAL k_tlb_inv - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - PTR_VAL k_general - - .align 5 -NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra) - .globl u_intr # for trap.c peace of mind -u_intr: - .set noat - .mask 0x80000000, (CF_RA_OFFS - FRAMESZ(CF_SZ)) - - GET_CPU_INFO(k1, k0) - PTR_L k0, CI_CURPROCPADDR(k1) - SAVE_CPU(k0, 0) - SAVE_CPU_SREG(k0, 0) - PTR_ADDU sp, k0, USPACE-FRAMESZ(CF_SZ) - .set at - and t0, a1, ~(SR_COP_1_BIT | SR_EXL | SR_INT_ENAB | SR_KSU_MASK) - DMTC0 t0, COP_0_STATUS_REG - MTC0_SR_IE_HAZARD - - jal trap - PTR_S a3, CF_RA_OFFS(sp) # for debugging - - DMFC0 t0, COP_0_STATUS_REG # enable interrupts before checking - ori t0, SR_INT_ENAB # for ast. - DMTC0 t0, COP_0_STATUS_REG - MTC0_SR_IE_HAZARD - -0: - GET_CPU_INFO(t1, t0) - PTR_L t0, CI_CURPROC(t1) - lw v0, P_ASTPENDING(t0) # any pending AST? - beq v0, zero, 4f - NOP - - jal ast - NOP - - b 0b - NOP - -4: - DMFC0 t0, COP_0_STATUS_REG # disable interrupts - MFC0_HAZARD - ori t0, SR_INT_ENAB - xori t0, SR_INT_ENAB - DMTC0 t0, COP_0_STATUS_REG - MTC0_SR_IE_HAZARD - - ori t0, SR_EXL # restoring to user mode. - DMTC0 t0, COP_0_STATUS_REG # must set exception level bit. - MTC0_SR_IE_HAZARD - - # t1 is curcpu() from earlier - move k1, t1 - PTR_L k0, CI_CURPROCPADDR(k1) - RESTORE_REG(a3, CPL, k0, 0) - sw a3, CI_IPL(k1) - .set noat - RESTORE_CPU_SREG(k0, 0) - RESTORE_REG(a0, PC, k0, 0) - RESTORE_CPU(k0, 0) - RESTORE_REG(sp, SP, k0, 0) - LI k0, 0 - LI k1, 0 - ERET - .set at -END(u_general) - - .align 5 -NNON_LEAF(k_general, FRAMESZ(KERN_EXC_FRAME_SIZE), ra) - .globl k_intr # for trap.c peace of mind -k_intr: - .set noat - .mask 0x80000000, (CF_RA_OFFS - FRAMESZ(KERN_EXC_FRAME_SIZE)) - -#ifdef DEBUG - GET_CPU_INFO(k1, k0) - PTR_L k1, CI_CURPROCPADDR(k1) - PTR_SUBU k0, sp, k1 - sltiu k0, 2048 - beqz k0, 8f - NOP - - LA a0, start - FRAMESZ(CF_SZ) - 4 * REGSZ - move a6, sp - move sp, a0 - DMFC0 a1, COP_0_EXC_PC - MFC0_HAZARD - LA a0, 1f - PRE_MFC0_ADDR_HAZARD - DMFC0 a3, COP_0_VADDR - MFC0_HAZARD - DMFC0 a4, COP_0_STATUS_REG - MFC0_HAZARD - DMFC0 a5, COP_0_CAUSE_REG - MFC0_HAZARD - jal printf - move a2, ra - - LA sp, start-FRAMESZ(CF_SZ) -#ifdef DDB - LA a1, db_printf - LA a0, 2f - jal trapDump - NOP -#endif - PANIC("kernel stack overflow") - - .data -1: - .asciiz "\rtfptrap: PC %p RA %p ADR %p\nSR %p CR %p SP %p\n" -2: - .asciiz "stack oflow" - - .text -8: -#endif - - PTR_SUB k0, sp, FRAMESZ(KERN_EXC_FRAME_SIZE) - SAVE_CPU(k0, CF_RA_OFFS) -#if defined(DDB) - SAVE_CPU_SREG(k0, CF_RA_OFFS) -#endif - .set at - move sp, k0 # Already on kernel stack - and t0, a1, ~(SR_COP_1_BIT | SR_EXL | SR_INT_ENAB | SR_KSU_MASK) - DMTC0 t0, COP_0_STATUS_REG - MTC0_SR_IE_HAZARD - PTR_S a0, 0(sp) - jal trap - PTR_S a3, CF_RA_OFFS + KERN_REG_SIZE(sp) - - DMFC0 t0, COP_0_STATUS_REG # disable interrupts - MFC0_HAZARD - ori t0, SR_INT_ENAB - xori t0, SR_INT_ENAB - DMTC0 t0, COP_0_STATUS_REG - MTC0_SR_IE_HAZARD - - .set noat - RESTORE_REG(a0, PC, sp, CF_RA_OFFS) - RESTORE_CPU(sp, CF_RA_OFFS) - PTR_ADDU sp, sp, FRAMESZ(KERN_EXC_FRAME_SIZE) - ERET - .set at -END(k_general) diff --git a/sys/arch/mips64/mips64/lcore_access.S b/sys/arch/mips64/mips64/lcore_access.S index c8f941e2d8d..3be8ea655a4 100644 --- a/sys/arch/mips64/mips64/lcore_access.S +++ b/sys/arch/mips64/mips64/lcore_access.S @@ -1,4 +1,4 @@ -/* $OpenBSD: lcore_access.S,v 1.30 2020/10/21 15:50:00 deraadt Exp $ */ +/* $OpenBSD: lcore_access.S,v 1.31 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -339,29 +339,23 @@ LEAF(guarded_read_1, 0) GET_CPU_INFO(t1, t0) PTR_L t3, CI_CURPROCPADDR(t1) -#ifndef CPU_R8000 li a3, SR_BOOT_EXC_VEC MFC0 a2, COP_0_STATUS_REG or a4, a2, a3 xor a4, a4, a3 -#endif li v0, KT_GUARDERR lw v1, PCB_ONFAULT(t3) sw v0, PCB_ONFAULT(t3) -#ifndef CPU_R8000 MTC0 a4, COP_0_STATUS_REG MTC0_HAZARD -#endif lb v0, 0(a0) sb v0, 0(a1) -#ifndef CPU_R8000 MTC0 a2, COP_0_STATUS_REG MTC0_HAZARD -#endif sw v1, PCB_ONFAULT(t3) j ra @@ -372,29 +366,23 @@ LEAF(guarded_read_2, 0) GET_CPU_INFO(t1, t0) PTR_L t3, CI_CURPROCPADDR(t1) -#ifndef CPU_R8000 li a3, SR_BOOT_EXC_VEC MFC0 a2, COP_0_STATUS_REG or a4, a2, a3 xor a4, a4, a3 -#endif li v0, KT_GUARDERR lw v1, PCB_ONFAULT(t3) sw v0, PCB_ONFAULT(t3) -#ifndef CPU_R8000 MTC0 a4, COP_0_STATUS_REG MTC0_HAZARD -#endif lh v0, 0(a0) sh v0, 0(a1) -#ifndef CPU_R8000 MTC0 a2, COP_0_STATUS_REG MTC0_HAZARD -#endif sw v1, PCB_ONFAULT(t3) j ra @@ -405,29 +393,23 @@ LEAF(guarded_read_4, 0) GET_CPU_INFO(t1, t0) PTR_L t3, CI_CURPROCPADDR(t1) -#ifndef CPU_R8000 li a3, SR_BOOT_EXC_VEC MFC0 a2, COP_0_STATUS_REG or a4, a2, a3 xor a4, a4, a3 -#endif li v0, KT_GUARDERR lw v1, PCB_ONFAULT(t3) sw v0, PCB_ONFAULT(t3) -#ifndef CPU_R8000 MTC0 a4, COP_0_STATUS_REG MTC0_HAZARD -#endif lw v0, 0(a0) sw v0, 0(a1) -#ifndef CPU_R8000 MTC0 a2, COP_0_STATUS_REG MTC0_HAZARD -#endif sw v1, PCB_ONFAULT(t3) j ra @@ -438,28 +420,22 @@ LEAF(guarded_write_4, 0) GET_CPU_INFO(t1, t0) PTR_L t3, CI_CURPROCPADDR(t1) -#ifndef CPU_R8000 li a3, SR_BOOT_EXC_VEC MFC0 a2, COP_0_STATUS_REG or a4, a2, a3 xor a4, a4, a3 -#endif li v0, KT_GUARDERR lw v1, PCB_ONFAULT(t3) sw v0, PCB_ONFAULT(t3) -#ifndef CPU_R8000 MTC0 a4, COP_0_STATUS_REG MTC0_HAZARD -#endif sw a1, 0(a0) -#ifndef CPU_R8000 MTC0 a2, COP_0_STATUS_REG MTC0_HAZARD -#endif sw v1, PCB_ONFAULT(t3) j ra @@ -467,10 +443,8 @@ LEAF(guarded_write_4, 0) END(guarded_write_4) _guarderr: -#ifndef CPU_R8000 MTC0 a2, COP_0_STATUS_REG MTC0_HAZARD -#endif sw v1, PCB_ONFAULT(t3) j ra diff --git a/sys/arch/mips64/mips64/mips64_machdep.c b/sys/arch/mips64/mips64/mips64_machdep.c index 1803d0bbd60..6c7bab77939 100644 --- a/sys/arch/mips64/mips64/mips64_machdep.c +++ b/sys/arch/mips64/mips64/mips64_machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: mips64_machdep.c,v 1.36 2021/04/29 12:49:19 visa Exp $ */ +/* $OpenBSD: mips64_machdep.c,v 1.37 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 2009, 2010, 2012 Miodrag Vallat. @@ -130,12 +130,7 @@ build_trampoline(vaddr_t addr, vaddr_t dest) * Prototype status registers value for userland processes. */ register_t protosr = SR_FR_32 | SR_XX | SR_UX | SR_KSU_USER | SR_EXL | -#ifdef CPU_R8000 - SR_SERIALIZE_FPU | -#else - SR_KX | -#endif - SR_INT_ENAB; + SR_KX | SR_INT_ENAB; /* * Set registers on exec for native exec format. For o64/64. @@ -199,20 +194,7 @@ exec_md_map(struct proc *p, struct exec_package *pack) void tlb_init(unsigned int tlbsize) { -#ifdef CPU_R8000 - register_t sr; - - sr = getsr(); - sr &= ~(((uint64_t)SR_PGSZ_MASK << SR_KPGSZ_SHIFT) | - ((uint64_t)SR_PGSZ_MASK << SR_UPGSZ_SHIFT)); - sr |= ((uint64_t)SR_PGSZ_16K << SR_KPGSZ_SHIFT) | - ((uint64_t)SR_PGSZ_16K << SR_UPGSZ_SHIFT); - protosr |= ((uint64_t)SR_PGSZ_16K << SR_KPGSZ_SHIFT) | - ((uint64_t)SR_PGSZ_16K << SR_UPGSZ_SHIFT); - setsr(sr); -#else tlb_set_page_mask(TLB_PAGE_MASK); -#endif tlb_set_wired(0); tlb_flush(tlbsize); #if UPAGES > 1 @@ -227,7 +209,7 @@ void tlb_asid_wrap(struct cpu_info *ci) { tlb_flush(ci->ci_hw.tlbsize); -#if defined(CPU_OCTEON) || defined(CPU_R8000) +#if defined(CPU_OCTEON) Mips_InvalidateICache(ci, 0, ci->ci_l1inst.size); #endif } diff --git a/sys/arch/mips64/mips64/pmap.c b/sys/arch/mips64/mips64/pmap.c index b68d54266cf..030b26af270 100644 --- a/sys/arch/mips64/mips64/pmap.c +++ b/sys/arch/mips64/mips64/pmap.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pmap.c,v 1.116 2021/03/11 11:16:59 jsg Exp $ */ +/* $OpenBSD: pmap.c,v 1.117 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -174,14 +174,8 @@ pmap_invalidate_user_page(pmap_t pmap, vaddr_t va) u_long asid = pmap->pm_asid[cpuid].pma_asid << PG_ASID_SHIFT; if (pmap->pm_asid[cpuid].pma_asidgen == - pmap_asid_info[cpuid].pma_asidgen) { -#ifdef CPU_R4000 - if (r4000_errata != 0) - eop_tlb_flush_addr(pmap, va, asid); - else -#endif - tlb_flush_addr(va | asid); - } + pmap_asid_info[cpuid].pma_asidgen) + tlb_flush_addr(va | asid); } void @@ -371,9 +365,7 @@ void pmap_bootstrap(void) { u_int i; -#ifndef CPU_R8000 pt_entry_t *spte; -#endif /* * Create a mapping table for kernel virtual memory. This @@ -386,10 +378,8 @@ pmap_bootstrap(void) Sysmapsize = (VM_MAX_KERNEL_ADDRESS - VM_MIN_KERNEL_ADDRESS) / PAGE_SIZE; -#ifndef CPU_R8000 if (Sysmapsize & 1) Sysmapsize++; /* force even number of pages */ -#endif Sysmap = (pt_entry_t *) uvm_pageboot_alloc(sizeof(pt_entry_t) * Sysmapsize); @@ -403,7 +393,6 @@ pmap_bootstrap(void) pmap_kernel()->pm_count = 1; -#ifndef CPU_R8000 /* * The 64 bit Mips architecture stores the AND result * of the Global bits in the pte pair in the on chip @@ -414,9 +403,7 @@ pmap_bootstrap(void) */ for (i = Sysmapsize, spte = Sysmap; i != 0; i--, spte++) *spte = PG_G; -#else - bzero(Sysmap, sizeof(pt_entry_t) * Sysmapsize); -#endif + tlb_set_gbase((vaddr_t)Sysmap, Sysmapsize); for (i = 0; i < MAXCPUS; i++) { @@ -477,19 +464,7 @@ pmap_steal_memory(vsize_t size, vaddr_t *vstartp, vaddr_t *vendp) if (vendp) *vendp = virtual_end; -#ifdef __sgi__ -#ifndef CPU_R8000 - /* - * Return a CKSEG0 address whenever possible. - */ - if (pa + size < CKSEG_SIZE) - va = PHYS_TO_CKSEG0(pa); - else -#endif - va = PHYS_TO_XKPHYS(pa, CCA_CACHED); -#else va = PHYS_TO_XKPHYS(pa, CCA_CACHED); -#endif bzero((void *)va, size); return (va); @@ -1251,24 +1226,6 @@ pmap_enter(pmap_t pmap, vaddr_t va, paddr_t pa, vm_prot_t prot, int flags) DPRINTF(PDB_ENTER, ("pmap_enter: new pte 0x%08x\n", npte)); } -#ifdef CPU_R4000 - /* - * If mapping an executable page, check for the R4000 EOP bug, and - * flag it in the pte. - */ - if (r4000_errata != 0) { - if (pg != NULL && (prot & PROT_EXEC)) { - if ((pg->pg_flags & PGF_EOP_CHECKED) == 0) - atomic_setbits_int(&pg->pg_flags, - PGF_EOP_CHECKED | - eop_page_check(pa)); - - if (pg->pg_flags & PGF_EOP_VULN) - npte |= PG_SP; - } - } -#endif - opte = *pte; *pte = npte; pmap_update_user_page(pmap, va, npte); @@ -1413,14 +1370,12 @@ pmap_extract(pmap_t pmap, vaddr_t va, paddr_t *pap) if (pmap == pmap_kernel()) { if (IS_XKPHYS(va)) pa = XKPHYS_TO_PHYS(va); -#ifndef CPU_R8000 else if (va >= (vaddr_t)CKSEG0_BASE && va < (vaddr_t)CKSEG0_BASE + CKSEG_SIZE) pa = CKSEG0_TO_PHYS(va); else if (va >= (vaddr_t)CKSEG1_BASE && va < (vaddr_t)CKSEG1_BASE + CKSEG_SIZE) pa = CKSEG1_TO_PHYS(va); -#endif else { #ifdef DIAGNOSTIC if (va < VM_MIN_KERNEL_ADDRESS || @@ -1507,10 +1462,6 @@ pmap_zero_page(struct vm_page *pg) mem_zero_page(va); if (df || cache_valias_mask != 0) Mips_HitSyncDCachePage(ci, va, phys); - -#ifdef CPU_R4000 - atomic_clearbits_int(&pg->pg_flags, PGF_EOP_CHECKED | PGF_EOP_VULN); -#endif } /* @@ -1566,12 +1517,6 @@ pmap_copy_page(struct vm_page *srcpg, struct vm_page *dstpg) Mips_HitInvalidateDCache(ci, s, PAGE_SIZE); if (df || cache_valias_mask != 0) Mips_HitSyncDCachePage(ci, d, dst); - -#ifdef CPU_R4000 - atomic_clearbits_int(&dstpg->pg_flags, PGF_EOP_CHECKED | PGF_EOP_VULN); - atomic_setbits_int(&dstpg->pg_flags, - srcpg->pg_flags & (PGF_EOP_CHECKED | PGF_EOP_VULN)); -#endif } /* @@ -2119,19 +2064,7 @@ pmap_map_direct(vm_page_t pg) paddr_t pa = VM_PAGE_TO_PHYS(pg); vaddr_t va; -#ifdef __sgi__ -#ifndef CPU_R8000 - /* - * Return a CKSEG0 address whenever possible. - */ - if (pa < CKSEG_SIZE) - va = PHYS_TO_CKSEG0(pa); - else -#endif - va = PHYS_TO_XKPHYS(pa, CCA_CACHED); -#else va = PHYS_TO_XKPHYS(pa, CCA_CACHED); -#endif return va; } @@ -2142,17 +2075,7 @@ pmap_unmap_direct(vaddr_t va) paddr_t pa; vm_page_t pg; -#ifdef __sgi__ -#ifndef CPU_R8000 - if (va >= CKSEG0_BASE) - pa = CKSEG0_TO_PHYS(va); - else -#endif - pa = XKPHYS_TO_PHYS(va); -#else pa = XKPHYS_TO_PHYS(va); -#endif - pg = PHYS_TO_VM_PAGE(pa); if (cache_valias_mask) Mips_HitSyncDCachePage(curcpu(), va, pa); diff --git a/sys/arch/mips64/mips64/r4000_errata.c b/sys/arch/mips64/mips64/r4000_errata.c deleted file mode 100644 index 23a8180c198..00000000000 --- a/sys/arch/mips64/mips64/r4000_errata.c +++ /dev/null @@ -1,271 +0,0 @@ -/* $OpenBSD: r4000_errata.c,v 1.7 2016/12/22 15:33:36 visa Exp $ */ - -/* - * Copyright (c) 2014 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * The following routines attempt to workaround the `end-of-page' errata - * affecting R4000 processors rev < 3. - * - * This particular errata, scarcely documented as errata #4 and #14 in the - * `R4000PC, R4000SC Errata, Processor Revision 2.2 and 3.0' document, - * is not recoverable. - * - * - * This errata is triggered by branch instructions in the last word of a - * page, when the next page (containing the delay slot instruction) causes - * a TLB miss. The only safe way to avoid it is to have the toolchain - * force all branch instructions to be aligned on 8-byte boundaries, but - * that wouldn't prevent a rogue binary (or just-in-time compilation) to - * fail this requirement. - * - * The following logic is a ``best effort'' (well, ok, ``lazy man's effort'') - * at trying to prevent the errata from triggering. It will not be enough - * when confronted to a carefully crafted binary (but then, there are easier - * way to get kernel mode privileges from userland, when running on the R4000 - * processors vulnerable to the end-of-page errata, so why bother?). Yet, - * experience has shown this code is surprisingly good enough to allow for - * regular binaries to run, with a minimal performance hit. - * - * - * The idea behind this code is simple: - * - executable pages are checked - with eop_page_check() - for a branch in - * their last word. If they are vulnerable to this errata, page table entries - * for these pages get the `special' bit set. - * - tlb miss handlers will check for the `special' bit set in the pte and - * will always defer to the C code in trap() in that case. trap() will - * then invoke eop_tlb_miss_handler(), which will 1) force the next page - * to be faulted in, and 2) set up wired TLB entries for both the vulnerable - * page and the next page (and their neighbors if they do not share the same - * TLB pair), so that there is no risk of a TLB miss when the branch - * instruction is reached. - * - context switches will remove these wired entries. - * - tlb modification handlers will check for the current exception PC, and - * will remove the wired entries if the exception PC is no longer in the - * vulnerable page. - * - * - * There are a few limitations: - * - heavy paging may cause the page next to a vulnerable page to be swapped - * out (this code does not attempt to wire the vm_page). It would be worth - * mapping a page full of special break instructions when the page gets - * swapped out. - * - there might be other vulnerable pages in the wired tlb entries being - * set up. It should be simple enough to walk the next pages until the last - * would-be-wired TLB pair contains two safe pages. However, the amount of - * TLB is quite limited, so a limit has to be set at some point. - * - no effort has been put to catch executable pages being temporarily made - * writable, then vulnerable (by putting a branch instruction in the last - * word). This is unlikely to happen (except for just-in-time compilation). - * - * - * Note that, by using 16KB page sizes, the number of vulnerable pages is - * reduced. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/proc.h> -#include <sys/user.h> - -#include <machine/cpu.h> - -#include <uvm/uvm_extern.h> - -int r4000_errata; - -static inline void eop_undo(struct pcb *); - -static inline void -eop_undo(struct pcb *pcb) -{ - tlb_set_wired(UPAGES / 2); - tlb_flush((UPAGES / 2) + pcb->pcb_nwired); - pcb->pcb_nwired = 0; -} - -/* - * Check for an R4000 end-of-page errata condition in an executable code page. - * Returns a bitmask to set in the given page pg_flags. - */ -u_int -eop_page_check(paddr_t pa) -{ - uint32_t insn; - - insn = *(uint32_t *)PHYS_TO_XKPHYS(pa + PAGE_SIZE - 4, CCA_CACHED); - if (classify_insn(insn) != INSNCLASS_NEUTRAL) - return PGF_EOP_VULN; - - return 0; -} - -/* - * Invalidate a TLB entry. If it is part of a wired pair, drop all wired - * entries. - * - * Note that, in case of heavy swapping, this can cause the page following - * a vulnerable page to be swapped out and immediately faulted back in, - * iff the userland pc is in the vulnerable page. Help me, Obi Wan LRU. - * You are my only hope. - */ -void -eop_tlb_flush_addr(struct pmap *pmap, vaddr_t va, u_long asid) -{ - struct proc *p = curproc; - struct pcb *pcb; - - if (p->p_vmspace->vm_map.pmap == pmap) { - pcb = &p->p_addr->u_pcb; - if (pcb->pcb_nwired != 0 && - (va - pcb->pcb_wiredva) < ptoa(pcb->pcb_nwired * 2)) { - eop_undo(pcb); - return; - } - } - - tlb_flush_addr(va | asid); -} - -/* - * Handle a TLB miss exception for a page marked as able to trigger the - * end-of-page errata. - * Returns nonzero if the exception has been completely serviced, and no - * further processing in the trap handler is necessary. - */ -int -eop_tlb_miss_handler(struct trapframe *trapframe, struct cpu_info *ci, - struct proc *p) -{ - struct pcb *pcb; - vaddr_t va, faultva; - struct vmspace *vm; - vm_map_t map; - pmap_t pmap; - pt_entry_t *pte, entry; - int onfault; - u_long asid; - uint i, npairs; - int64_t tlbidx; - - /* - * Check for a valid pte with the `special' bit set (PG_SP) - * in order to apply the end-of-page errata workaround. - */ - - vm = p->p_vmspace; - map = &vm->vm_map; - faultva = trunc_page((vaddr_t)trapframe->badvaddr); - pmap = map->pmap; - - pte = pmap_pte_lookup(pmap, faultva); - if (pte == NULL) - return 0; - entry = *pte; - if ((entry & PG_SP) == 0) - return 0; - - pcb = &p->p_addr->u_pcb; - asid = pmap->pm_asid[ci->ci_cpuid].pma_asid << PG_ASID_SHIFT; - - /* - * For now, only allow one EOP vulnerable page to get a wired TLB - * entry. We will aggressively attempt to recycle the wired TLB - * entries created for that purpose, as soon as we are no longer - * needing the EOP page resident in the TLB. - */ - - /* - * Figure out how many pages to wire in the TLB. - */ - - if ((faultva & PG_ODDPG) != 0) { - /* odd page: need two pairs */ - npairs = 2; - } else { - /* even page: only need one pair */ - npairs = 1; - } - - /* - * Fault-in the next page. - */ - - va = faultva + PAGE_SIZE; - pte = pmap_pte_lookup(pmap, va); - if (pte == NULL || (*pte & PG_V) == 0) { - onfault = pcb->pcb_onfault; - pcb->pcb_onfault = 0; - KERNEL_LOCK(); - (void)uvm_fault(map, va, 0, PROT_READ | PROT_EXEC); - KERNEL_UNLOCK(); - pcb->pcb_onfault = onfault; - } - - /* - * Clear possible TLB entries for the pages we're about to wire. - */ - - for (i = npairs, va = faultva & PG_HVPN; i != 0; - i--, va += 2 * PAGE_SIZE) { - tlbidx = tlb_probe(va | asid); - if (tlbidx >= 0) - tlb_update_indexed(CKSEG0_BASE, PG_NV, PG_NV, tlbidx); - } - - /* - * Reserve the extra wired TLB, and fill them with the existing ptes. - */ - - tlb_set_wired((UPAGES / 2) + npairs); - for (i = 0, va = faultva & PG_HVPN; i != npairs; - i++, va += 2 * PAGE_SIZE) { - pte = pmap_pte_lookup(pmap, va); - if (pte == NULL) - tlb_update_indexed(va | asid, - PG_NV, PG_NV, (UPAGES / 2) + i); - else - tlb_update_indexed(va | asid, - pte[0], pte[1], (UPAGES / 2) + i); - } - - /* - * Save the base address of the EOP vulnerable page, to be able to - * figure out when the wired entry is no longer necessary. - */ - - pcb->pcb_nwired = npairs; - pcb->pcb_wiredva = faultva & PG_HVPN; - pcb->pcb_wiredpc = faultva; - - return 1; -} - -/* - * Attempt to cleanup the current end-of-page errata workaround, if the - * current pc is no longer in an errata vulnerable page. - */ -void -eop_cleanup(struct trapframe *trapframe, struct proc *p) -{ - struct pcb *pcb; - - pcb = &p->p_addr->u_pcb; - if (pcb->pcb_nwired != 0) { - if (trunc_page(trapframe->pc) != pcb->pcb_wiredpc) - eop_undo(pcb); - } -} diff --git a/sys/arch/mips64/mips64/tlb_tfp.S b/sys/arch/mips64/mips64/tlb_tfp.S deleted file mode 100644 index 43c3b812a97..00000000000 --- a/sys/arch/mips64/mips64/tlb_tfp.S +++ /dev/null @@ -1,317 +0,0 @@ -/* $OpenBSD: tlb_tfp.S,v 1.4 2015/09/23 19:13:55 miod Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <machine/param.h> -#include <machine/asm.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/pte.h> - -#include "assym.h" - -#ifdef MIPS_PTE64 -#error "R8000 doesn't need 64-bit PTE" -#endif - -#define TLBR .align 4; .word 0x43000001; SSNOP; SSNOP; SSNOP; SSNOP -#define TLBW .align 4; .word 0x43000002; SSNOP; SSNOP; SSNOP -#define TLBP .align 4; .word 0x43000008; SSNOP; SSNOP; SSNOP; SSNOP - -#ifdef TLB_DEBUG -#define TLBOP(crounha) Xtlb_##crounha -#else -#define TLBOP(crounha) tlb_##crounha -#endif - - .set mips4 - .set noreorder - -/* - * void tlb_flush(int); - * Flush all the TLB entries. Argument is ignored (128x3 layout is hardcoded). - * Assumes there are no wired entries. - */ -LEAF(TLBOP(flush), 0) /* { */ - DMFC0 v1, COP_0_STATUS_REG # Save the status register. - MFC0_HAZARD - ori v0, v1, SR_INT_ENAB - xori v0, SR_INT_ENAB - DMTC0 v0, COP_0_STATUS_REG # Disable interrupts - MTC0_SR_IE_HAZARD - - LI v0, 01 - dsll v0, v0, 62 # KV0 base - DMFC0 a2, COP_0_TLB_HI # Read current ASID - MFC0_HAZARD - LI a1, 2 # TLB set counter -1: - DMTC0 a1, COP_0_TLB_SET - MTC0_HAZARD - LI a0, 127 # TLB index counter -2: - DMTC0 zero, COP_0_TLB_LO - MTC0_HAZARD - DMTC0 v0, COP_0_TLB_HI - MTC0_HAZARD - DMTC0 v0, COP_0_VADDR - MTC0_HAZARD - - TLBW - beqz a0, 3f - addu v0, PAGE_SIZE # Make sure no duplicates will exist - b 2b - subu a0, 1 -3: - beqz a1, 4f - NOP - b 1b - subu a1, 1 -4: - DMTC0 a2, COP_0_TLB_HI # Restore current ASID - MTC0_HAZARD - MTC0_SR_IE_HAZARD - DMTC0 v1, COP_0_STATUS_REG # Restore the status register - MTC0_SR_IE_HAZARD - - j ra - NOP -END(TLBOP(flush)) /* } */ - -/* - * void tlb_flush_addr(vaddr_t); - * Flush matching TLB entry, if any, for the given address and ASID (the - * ASID bits are in the same position as in EntryHi). - */ -LEAF(TLBOP(flush_addr), 0) /* { */ - DMFC0 v1, COP_0_STATUS_REG # Save the status register. - MFC0_HAZARD - ori v0, v1, SR_INT_ENAB - xori v0, v0, SR_INT_ENAB - DMTC0 v0, COP_0_STATUS_REG # Disable interrupts - MTC0_SR_IE_HAZARD - DMFC0 a2, COP_0_TLB_HI # Read current ASID - MFC0_HAZARD - - /* - * NOTE: I used to only write the ASID bits of TLB_HI and not bother - * about the VPN bits (since we are about to invalidate that entry - * anyway), with this: - * and a1, a0, PG_ASID_MASK - * DMTC0 a1, COP_0_TLB_HI - * - * It turns out that this was a VERY BAD idea. Doing this seems to - * work, but leaves the TLB in an inconsistent state (although - * reading the TLB entry afterwards does not report anything wrong), - * and eventually causes TLBX exceptions - although, at the time of - * the exception, the TLB values obtained by TLBR are consistent and - * no duplicate is to be found. - * -- miod - */ - DMTC0 a0, COP_0_TLB_HI - MTC0_HAZARD - DMTC0 a0, COP_0_VADDR - MTC0_HAZARD - - TLBP - DMFC0 v0, COP_0_TLB_SET - MFC0_HAZARD - - bltz v0, 1f # Missing - NOP - - DMTC0 zero, COP_0_TLB_LO - MTC0_HAZARD - TLBW - -1: - DMTC0 a2, COP_0_TLB_HI # restore PID - MTC0_HAZARD - DMTC0 v1, COP_0_STATUS_REG # Restore the status register - MTC0_SR_IE_HAZARD - j ra - NOP -END(TLBOP(flush_addr)) /* } */ - -/* - * void tlb_update(vaddr_t, register_t); - * Update (or create) TLB entry for given address and ASID, and PTE. - */ -LEAF(TLBOP(update), 0) /* { */ - DMFC0 v1, COP_0_STATUS_REG # Save the status register. - MFC0_HAZARD - ori v0, v1, SR_INT_ENAB - xori v0, v0, SR_INT_ENAB - DMTC0 v0, COP_0_STATUS_REG # Disable interrupts - MTC0_SR_IE_HAZARD - - DMFC0 a2, COP_0_TLB_HI # Read current ASID - MFC0_HAZARD - /* - * If setting up a kernel mapping (va < 0), merge the ASID field - * so that we do not need to write it back. - */ - bgez a0, 1f - andi a2, PG_ASID_MASK - or a0, a2 -1: - - DMTC0 a0, COP_0_TLB_HI - MTC0_HAZARD - DMTC0 a0, COP_0_VADDR - MTC0_HAZARD - - TLBP - DMFC0 v0, COP_0_TLB_SET - MFC0_HAZARD - - bgez v0, 2f - - /* - * Page not found: pick a random set. This algorithm is biased as it - * will select set #0 with a 1/2 probability, and sets #1 and #2 with - * 1/4 probability. But it's simple, fast, and still better than - * always picking set #0. - */ - li a3, 1 # delay slot from above - DMFC0 v0, COP_0_COUNT - MFC0_HAZARD - and v0, 3 - movz a3, zero, v0 # a3 = v0 == 0 ? 0 : 1 - subu v0, a3 - DMTC0 v0, COP_0_TLB_SET - MTC0_HAZARD - -2: - DMTC0 a1, COP_0_TLB_LO - MTC0_HAZARD - TLBW - - blez a0, 3f - NOP - DMTC0 a2, COP_0_TLB_HI # restore ASID - MTC0_HAZARD -3: - DMTC0 v1, COP_0_STATUS_REG # Restore the status register - MTC0_SR_IE_HAZARD - - j ra - NOP -END(TLBOP(update)) /* } */ - -/* - * void tlb_read(int, struct tlb_entry *); - * Read the given TLB entry. On R8000, only the tlb_hi and tlb_lo0 fields are - * filled. - */ -LEAF(tlb_read, 0) /* { */ - DMFC0 v1, COP_0_STATUS_REG # Save the status register. - MFC0_HAZARD - ori v0, v1, SR_INT_ENAB - xori v0, v0, SR_INT_ENAB - DMTC0 v0, COP_0_STATUS_REG # Disable interrupts - MTC0_SR_IE_HAZARD - - DMFC0 a3, COP_0_TLB_HI # Get current PID - MFC0_HAZARD - - DMTC0 zero, COP_0_TLB_HI # Force ASID to zero so we don't need - MTC0_HAZARD # to hash the index - - dsrl a2, a0, 7 - DMTC0 a2, COP_0_TLB_SET - MTC0_HAZARD - dsll a0, PAGE_SHIFT - DMTC0 a0, COP_0_VADDR - MTC0_HAZARD - - TLBR - - DMFC0 a0, COP_0_TLB_HI - MFC0_HAZARD - DMFC0 a2, COP_0_TLB_LO - MFC0_HAZARD - - DMTC0 a3, COP_0_TLB_HI - MTC0_HAZARD - DMTC0 v1, COP_0_STATUS_REG # Restore the status register - MTC0_SR_IE_HAZARD - - sd a0, 8(a1) # tlb_hi - j ra - sd a2, 16(a1) # tlb_lo0 -END(tlb_read) /* } */ - -/* - * uint tlb_get_pid(void); - * Read the current TLB ASID. - */ -LEAF(tlb_get_pid, 0) /* { */ - DMFC0 v0, COP_0_TLB_HI # get PID - MFC0_HAZARD - and v0, PG_ASID_MASK - j ra - dsrl v0, PG_ASID_SHIFT -END(tlb_get_pid) /* } */ - -/* - * void tlb_set_pid(uint); - * Set the current TLB ASID. - */ -LEAF(TLBOP(set_pid), 0) /* { */ - DMFC0 v1, COP_0_STATUS_REG # Save the status register. - MFC0_HAZARD - ori v0, v1, SR_INT_ENAB - xori v0, v0, SR_INT_ENAB - DMTC0 v0, COP_0_STATUS_REG # Disable interrupts - MTC0_SR_IE_HAZARD - - dsll a1, a0, ICACHE_ASID_SHIFT - dsll a0, PG_ASID_SHIFT - DMTC0 a0, COP_0_TLB_HI - MTC0_HAZARD - DMTC0 a1, COP_0_ICACHE - MTC0_HAZARD - - DMTC0 v1, COP_0_STATUS_REG # Restore the status register - MTC0_SR_IE_HAZARD - - j ra - NOP -END(TLBOP(set_pid)) /* } */ - -/* - * void tlb_set_wired(uint32_t); - */ -LEAF(tlb_set_wired, 0) /* { */ - DMTC0 a0, COP_0_TFP_TLB_WIRED - MTC0_HAZARD - j ra - NOP -END(tlb_set_wired) /* } */ - -/* - * void tlb_set_gbase(vaddr_t, vsize_t); - */ -LEAF(tlb_set_gbase, 0) /* { */ - DMTC0 a0, COP_0_GBASE - MTC0_HAZARD - DMTC0 a1, COP_0_WORK1 - MTC0_HAZARD - j ra - NOP -END(tlb_set_gbase) /* } */ diff --git a/sys/arch/mips64/mips64/tlbhandler.S b/sys/arch/mips64/mips64/tlbhandler.S index 86633daa440..2f03840444b 100644 --- a/sys/arch/mips64/mips64/tlbhandler.S +++ b/sys/arch/mips64/mips64/tlbhandler.S @@ -1,4 +1,4 @@ -/* $OpenBSD: tlbhandler.S,v 1.50 2019/01/05 12:18:13 visa Exp $ */ +/* $OpenBSD: tlbhandler.S,v 1.51 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 1995-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -55,70 +55,6 @@ */ .set noat -#ifdef CPU_R4000 - .globl xtlb_miss_err_r4k - .ent xtlb_miss_err_r4k, 0 -xtlb_miss_err_r4k: - /* - * R4000 errata #27: TLB miss exception may be invoked with BadVAddr - * being incorrect. - */ - tlbp - mfc0 k1, COP_0_TLB_INDEX - bltz k1, xtlb_miss # missing! - nop - ERET - nop - .end xtlb_miss_err_r4k - - .globl xtlb_miss_err_r4000SC - .ent xtlb_miss_err_r4000SC, 0 -xtlb_miss_err_r4000SC: - /* - * R4000SC errata #12: In addition to errata #27 above, the tlbp - * instruction needs to be issued in uncached space, to prevent - * BadVAddr to be further corrupted if a VCE exception occurs - * immediately after the TLB miss exception has been serviced. - */ - tlbp - mfc0 k1, COP_0_TLB_INDEX - bltz k1, 1f # missing! - nop - ERET - nop -1: - LA k1, xtlb_miss - jr k1 - nop - .end xtlb_miss_err_r4000SC -#endif /* CPU_R4000 */ -#if defined(CPU_R5000) || defined(CPU_RM7000) - .globl xtlb_miss_err_r5k - .ent xtlb_miss_err_r5k, 0 -xtlb_miss_err_r5k: - /* - * R5000 errata: edge cases can trigger a TLB miss exception - * instead of an invalid TLB exception. Servicing the TLB miss - * exception would cause a duplicate TLB to be inserted, which - * causes the processor operation to become unpredictable (but - * very bad for the kernel's health, ten times out of nine). - * - * More details about the problem can be found in: - * http://www.linux-mips.org/archives/linux-mips/2000-02/msg00040.html - * - * We work around the issue by checking for an existing TLB entry, - * and handling this as an invalid TLB exception (as it was intended - * to be), in this case. - */ - tlbp - mfc0 k1, COP_0_TLB_INDEX - bltz k1, xtlb_miss # missing! - nop - b k_tlb_inv - nop - .end xtlb_miss_err_r5k -#endif /* CPU_R5000 || CPU_RM7000 */ - .globl xtlb_miss .ent xtlb_miss, 0 xtlb_miss: @@ -149,19 +85,8 @@ xtlb_miss: PTR_ADDU k1, k1, k0 PTE_LOAD k0, 0(k1) PTE_LOAD k1, PTE_OFFS(k1) -#ifdef CPU_R4000 - dsll k0, k0, (64 - PG_FRAMEBITS - 1) # clear bits left of PG_FRAME... - dsll k1, k1, (64 - PG_FRAMEBITS - 1) # ...but PG_SP - bltz k0, _inv_seg # defer to trap() if PG_SP set. - bltz k1, _inv_seg - dsll k0, k0, 1 - dsll k1, k1, 1 - dsrl k0, k0, (64 - PG_FRAMEBITS) - dsrl k1, k1, (64 - PG_FRAMEBITS) -#else PTE_CLEAR_SWBITS(k0) PTE_CLEAR_SWBITS(k1) -#endif dmtc0 k0, COP_0_TLB_LO0 dmtc0 k1, COP_0_TLB_LO1 TLB_HAZARD @@ -687,18 +612,6 @@ LEAF(tlb_set_wired, 0) nop END(tlb_set_wired) -#ifdef CPU_RM7000 -/* - * Similar to tlb_set_wired() above, but returns the value of the random - * register. - */ -LEAF(tlb_set_wired_get_random, 0) - mtc0 a0, COP_0_TLB_WIRED - j ra - mfc0 v0, COP_0_TLB_RANDOM -END(tlb_set_wired_get_random) -#endif - /* * Initialize the TLB page mask. */ diff --git a/sys/arch/mips64/mips64/trap.c b/sys/arch/mips64/mips64/trap.c index 6530ef75203..588f3af4dfe 100644 --- a/sys/arch/mips64/mips64/trap.c +++ b/sys/arch/mips64/mips64/trap.c @@ -1,4 +1,4 @@ -/* $OpenBSD: trap.c,v 1.153 2021/03/11 11:16:59 jsg Exp $ */ +/* $OpenBSD: trap.c,v 1.154 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 1988 University of Utah. @@ -178,16 +178,9 @@ trap(struct trapframe *trapframe) type = (trapframe->cause & CR_EXC_CODE) >> CR_EXC_CODE_SHIFT; -#if defined(CPU_R8000) && !defined(DEBUG_INTERRUPT) - if (type != T_INT) -#endif - trapdebug_enter(ci, trapframe, -1); + trapdebug_enter(ci, trapframe, -1); -#ifdef CPU_R8000 - if (type != T_INT && type != T_SYSCALL) -#else if (type != T_SYSCALL) -#endif atomic_inc_int(&uvmexp.traps); if (USERMODE(trapframe->sr)) type |= T_USER; @@ -197,10 +190,6 @@ trap(struct trapframe *trapframe) * enable IPI interrupts only otherwise. */ switch (type) { -#ifdef CPU_R8000 - case T_INT: - case T_INT | T_USER: -#endif case T_BREAK: break; default: @@ -214,52 +203,6 @@ trap(struct trapframe *trapframe) break; } -#ifdef CPU_R8000 - /* - * Some exception causes on R8000 are actually detected by external - * circuitry, and as such are reported as external interrupts. - * On R8000 kernels, external interrupts vector to trap() instead of - * interrupt(), so that we can process these particular exceptions - * as if they were triggered as regular exceptions. - */ - if ((type & ~T_USER) == T_INT) { - if (trapframe->cause & CR_VCE) { -#ifndef DEBUG_INTERRUPT - trapdebug_enter(ci, trapframe, -1); -#endif - panic("VCE or TLBX"); - } - - if (trapframe->cause & CR_FPE) { -#ifndef DEBUG_INTERRUPT - trapdebug_enter(ci, trapframe, -1); -#endif - atomic_inc_int(&uvmexp.traps); - if (type & T_USER) - refreshcreds(p); - itsa(trapframe, ci, p, T_FPE | (type & T_USER)); - cp0_reset_cause(CR_FPE); - } - - if (trapframe->cause & CR_INT_MASK) { - /* - * Similar reality check as done in interrupt(), in - * case an interrupt occurred between a write to - * COP_0_STATUS_REG and it taking effect. - * (I have never seen this occurring on R8000 but - * this is cheap) - */ - if (ISSET(trapframe->sr, SR_INT_ENAB)) - interrupt(trapframe); - } - - if ((trapframe->cause & CR_FPE) && (type & T_USER)) - userret(p); - - return; - } -#endif - if (type & T_USER) refreshcreds(p); @@ -394,21 +337,7 @@ fault_common: uvm_map_inentry_sp, p->p_vmspace->vm_map.sserial)) return; -#ifdef CPU_R4000 - if (r4000_errata != 0) { - if (eop_tlb_miss_handler(trapframe, ci, p) != 0) - return; - } -#endif - fault_common_no_miss: - -#ifdef CPU_R4000 - if (r4000_errata != 0) { - eop_cleanup(trapframe, p); - } -#endif - { vaddr_t va; struct vmspace *vm; @@ -873,31 +802,6 @@ fault_common_no_miss: } goto err; -#ifdef CPU_R10000 - case T_BUS_ERR_IFETCH: - /* - * At least R16000 processor have been found triggering - * reproduceable bus error on instruction fetch in the - * kernel code, which are trivially recoverable (and - * look like an obscure errata to me). - * - * Thus, ignore these exceptions if the faulting address - * is in the kernel. - */ - { - extern void *kernel_text; - extern void *etext; - vaddr_t va; - - va = (vaddr_t)trapframe->pc; - if (trapframe->cause & CR_BR_DELAY) - va += 4; - if (va > (vaddr_t)&kernel_text && va < (vaddr_t)&etext) - return; - } - goto err; -#endif - default: err: disableintr(); @@ -984,18 +888,11 @@ trapDump(const char *msg, int (*pr)(const char *, ...)) if (ptrp->cause == 0) break; -#ifdef CPU_R8000 - (*pr)("%s: PC %p CR 0x%016lx SR 0x%011lx\n", - trap_type[(ptrp->cause & CR_EXC_CODE) >> - CR_EXC_CODE_SHIFT], - ptrp->pc, ptrp->cause, ptrp->status); -#else (*pr)("%s: PC %p CR 0x%08lx SR 0x%08lx\n", trap_type[(ptrp->cause & CR_EXC_CODE) >> CR_EXC_CODE_SHIFT], ptrp->pc, ptrp->cause & 0xffffffff, ptrp->status & 0xffffffff); -#endif (*pr)(" RA %p SP %p ADR %p\n", ptrp->ra, ptrp->sp, ptrp->vadr); } @@ -1253,15 +1150,9 @@ stacktrace(struct trapframe *regs) stacktrace_subr(regs, 6, printf); } -#ifdef CPU_R8000 -#define VALID_ADDRESS(va) \ - (((va) >= VM_MIN_KERNEL_ADDRESS && (va) < VM_MAX_KERNEL_ADDRESS) || \ - IS_XKPHYS(va)) -#else #define VALID_ADDRESS(va) \ (((va) >= VM_MIN_KERNEL_ADDRESS && (va) < VM_MAX_KERNEL_ADDRESS) || \ IS_XKPHYS(va) || ((va) >= CKSEG0_BASE && (va) < CKSEG1_BASE)) -#endif void stacktrace_subr(struct trapframe *regs, int count, diff --git a/sys/arch/mips64/mips64/vm_machdep.c b/sys/arch/mips64/mips64/vm_machdep.c index 2a93303d13e..4c1eca92b6d 100644 --- a/sys/arch/mips64/mips64/vm_machdep.c +++ b/sys/arch/mips64/mips64/vm_machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vm_machdep.c,v 1.40 2021/04/29 12:49:19 visa Exp $ */ +/* $OpenBSD: vm_machdep.c,v 1.41 2021/05/01 16:11:11 visa Exp $ */ /* * Copyright (c) 1988 University of Utah. * Copyright (c) 1992, 1993 @@ -72,20 +72,8 @@ cpu_fork(struct proc *p1, struct proc *p2, void *stack, void *tcb, /* replace p_addr with a direct translation address */ p2->p_md.md_uarea = (vaddr_t)p2->p_addr; pmap_extract(pmap_kernel(), p2->p_md.md_uarea, &pa); -#ifdef __sgi__ -#ifndef CPU_R8000 - /* - * Return a CKSEG0 address whenever possible. - */ - if (pa < CKSEG_SIZE) - p2->p_addr = (void *)PHYS_TO_CKSEG0(pa); - else -#endif - p2->p_addr = (void *)PHYS_TO_XKPHYS(pa, CCA_CACHED); -#else p2->p_addr = (void *)PHYS_TO_XKPHYS(pa, CCA_CACHED); #endif -#endif pcb = &p2->p_addr->u_pcb; /* diff --git a/sys/arch/sgi/Makefile b/sys/arch/sgi/Makefile deleted file mode 100644 index 32e35ebf871..00000000000 --- a/sys/arch/sgi/Makefile +++ /dev/null @@ -1,50 +0,0 @@ -# $OpenBSD: Makefile,v 1.11 2017/01/22 03:27:31 tb Exp $ - -.include <bsd.own.mk> # for KEEPKERNELS - -S= ${.CURDIR}/../.. -KFILE= GENERIC-IP30 -.if exists(conf/GENERIC.MP) -KFILE= GENERIC-IP30.MP -.endif -TDIRS= ${_arch} include pci gio hpc localbus xbow -TAGS= ${.CURDIR}/tags - -NOPROG= -NOMAN= -NOOBJ= -SUBDIR= stand -.if !defined(KEEPKERNELS) || !(make(clean) || make(cleandir)) -SUBDIR+=compile -.endif - -# config the fattest kernel we can find into a temporary dir -# to create a Makefile. Then use make to pull some variables -# out and push them into the sub-shell to expand the paths, -# and finally run ctags. -tags:: - TDIR=`mktemp -d /tmp/_tagXXXXXXXXXX` || exit 1; \ - eval "S=${S}" && \ - config -s ${S} -b $${TDIR} ${.CURDIR}/conf/${KFILE} && \ - eval "_arch=\"`make -V _arch -f $${TDIR}/Makefile`\"" && \ - eval "_mach=\"`make -V _mach -f $${TDIR}/Makefile`\"" && \ - eval "_machdir=\$S/arch/$${_mach}" && \ - eval "_archdir=\$S/arch/$${_arch}" && \ - eval "HFILES=\"`find $S \( -path $S/arch -o -path $S/stand -o -path $S/lib/libsa -o -path $S/lib/libkern/arch \) -prune -o -name '*.h'; find $${_machdir} $${_archdir} $S/lib/libkern/arch/$${_arch} \( -name boot -o -name stand \) -prune -o -name '*.h'`\"" && \ - eval "SFILES=\"`make -V SFILES -f $${TDIR}/Makefile`\"" && \ - eval "CFILES=\"`make -V CFILES -f $${TDIR}/Makefile`\"" && \ - eval "AFILES=\"`make -V AFILES -f $${TDIR}/Makefile`\"" && \ - ctags -wd -f ${TAGS} $${CFILES} $${HFILES} && \ - egrep "^[_A-Z]*ENTRY[_A-Z]*\(.*\)" $${SFILES} $${AFILES} | \ - sed "s;\\([^:]*\\):\\([^(]*\\)(\\([^, )]*\\)\\(.*\\);\\3 \\1 /^\\2(\\3\\4$$/;" \ - >> ${TAGS} && \ - sort -o ${TAGS} ${TAGS} && \ - rm -rf $${TDIR} - -links: - -for i in conf ${TDIRS}; do \ - (cd $$i && rm -f tags; ln -s tags tags); done - -obj: _SUBDIRUSE - -.include <bsd.prog.mk> diff --git a/sys/arch/sgi/compile/GENERIC-IP22/Makefile b/sys/arch/sgi/compile/GENERIC-IP22/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP22/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/GENERIC-IP26/Makefile b/sys/arch/sgi/compile/GENERIC-IP26/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP26/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/GENERIC-IP27.MP/Makefile b/sys/arch/sgi/compile/GENERIC-IP27.MP/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP27.MP/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/GENERIC-IP27/Makefile b/sys/arch/sgi/compile/GENERIC-IP27/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP27/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/GENERIC-IP28/Makefile b/sys/arch/sgi/compile/GENERIC-IP28/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP28/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/GENERIC-IP30.MP/Makefile b/sys/arch/sgi/compile/GENERIC-IP30.MP/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP30.MP/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/GENERIC-IP30/Makefile b/sys/arch/sgi/compile/GENERIC-IP30/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP30/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/GENERIC-IP32/Makefile b/sys/arch/sgi/compile/GENERIC-IP32/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/GENERIC-IP32/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/Makefile b/sys/arch/sgi/compile/Makefile deleted file mode 100644 index 83dd5c4899f..00000000000 --- a/sys/arch/sgi/compile/Makefile +++ /dev/null @@ -1,7 +0,0 @@ -# $OpenBSD: Makefile,v 1.2 2016/10/15 13:45:08 deraadt Exp $ - -.if make(obj) || make(clean) || make(cleandir) -SUBDIR!=find . -type d -maxdepth 1 \! \( -name . -o -name CVS \) | cut -b3- -.endif - -.include <bsd.subdir.mk> diff --git a/sys/arch/sgi/compile/Makefile.inc b/sys/arch/sgi/compile/Makefile.inc deleted file mode 100644 index 9e9e38f1ed1..00000000000 --- a/sys/arch/sgi/compile/Makefile.inc +++ /dev/null @@ -1,19 +0,0 @@ -SYSDIR != cd ${.CURDIR}/../../../..; pwd -CONFDIR != cd ${.CURDIR}/../../conf; pwd - -.if ${.CURDIR} == ${.OBJDIR} -.PHONY: config -config: - @echo make obj required first >&2 - @false -.else -.PHONY: config clean -config: - config ${.CURDIR:M*.PROF:C/.*/-p/} -b ${.OBJDIR} \ - -s ${SYSDIR} ${CONFDIR}/${.CURDIR:T:S/.PROF$//} -.endif - -cleandir clean: - -.include <bsd.obj.mk> - diff --git a/sys/arch/sgi/compile/RAMDISK-IP22/Makefile b/sys/arch/sgi/compile/RAMDISK-IP22/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/RAMDISK-IP22/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/RAMDISK-IP26/Makefile b/sys/arch/sgi/compile/RAMDISK-IP26/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/RAMDISK-IP26/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/RAMDISK-IP27/Makefile b/sys/arch/sgi/compile/RAMDISK-IP27/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/RAMDISK-IP27/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/RAMDISK-IP28/Makefile b/sys/arch/sgi/compile/RAMDISK-IP28/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/RAMDISK-IP28/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/RAMDISK-IP30/Makefile b/sys/arch/sgi/compile/RAMDISK-IP30/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/RAMDISK-IP30/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/compile/RAMDISK-IP32/Makefile b/sys/arch/sgi/compile/RAMDISK-IP32/Makefile deleted file mode 100644 index 01b5f23410c..00000000000 --- a/sys/arch/sgi/compile/RAMDISK-IP32/Makefile +++ /dev/null @@ -1 +0,0 @@ -.include "../Makefile.inc" diff --git a/sys/arch/sgi/conf/GENERIC-IP22 b/sys/arch/sgi/conf/GENERIC-IP22 deleted file mode 100644 index 63f4eb42f7a..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP22 +++ /dev/null @@ -1,105 +0,0 @@ -# $OpenBSD: GENERIC-IP22,v 1.18 2018/02/14 23:51:49 jsg Exp $ -# -# THIS KERNEL IS FOR INDIGO (IP20), INDY (IP22) AND INDIGO2 (IP24) SYSTEMS ONLY. -# -# For further information on compiling OpenBSD kernels, see the config(8) -# man page. -# -# For further information on hardware support for this architecture, see -# the intro(4) man page. For further information about kernel options -# for this architecture, see the options(4) man page. For an explanation -# of each device driver in this file see the section 4 man page for the -# device. - -machine sgi mips64 -include "../../../conf/GENERIC" -maxusers 32 # Estimated number of users - -# Make options -makeoption LINK_ADDRESS="0xffffffff88800000" -option KERNBASE="0xffffffff88000000" -# Force use of 16KB pages. The R5000 Indy, which has the infamous XKPHYS -# coherency bug wrt ll/sc instructions, can not have more than 256MB of -# physical memory, all of it fitting within CKSEG0. -option PAGE_SHIFT="14" - -option WSDISPLAY_COMPAT_RAWKBD # Provide raw scancodes; needed for X11 - -option EISAVERBOSE -option PCIVERBOSE -option USER_PCICONF # User-space PCI configuration - -# Define what targets to support -option TGT_INDIGO # R4x00 Indigo (IP20) -option TGT_INDIGO2 # Indigo2, Challenge M (IP22) -option TGT_INDY # Indy, Challenge S (IP24) -option ARCBIOS # mandatory -option CPU_R4000 # R4000/R4400 support (IP20/IP22/IP24) -option CPU_R4600 # R4600 support (IP22/IP24) -option CPU_R5000 # R5000 support (IP24) - -config bsd swap generic - -# -# Definition of system -# -mainbus0 at root -cpu* at mainbus0 -clock0 at mainbus0 # scheduling clock on Indy - -int0 at mainbus0 # Interrupt Controller and scheduling clock -imc0 at mainbus0 # Memory Controller -gio0 at imc0 -eisa0 at imc0 - -hpc0 at gio? addr 0x1fb80000 -hpc1 at gio? addr 0x1fb00000 -hpc2 at gio? addr 0x1f980000 - -dpclock0 at hpc0 # IP20 -dsclock0 at hpc0 # IP22/24 -sq* at hpc? # On-board Ethernet or E++ adapter -wdsc* at hpc? # On-board SCSI or GIO32 SCSI adapter -panel* at hpc0 # Indy front panel buttons -pckbc* at hpc0 # Indy/Indigo2 keyboard and mouse - -zs0 at hpc0 -zs1 at hpc0 -zstty* at zs0 # Serial ports -zskbd* at zs1 channel 0 -wskbd* at zskbd? mux 1 -zsms* at zs1 channel 1 -wsmouse* at zsms? mux 0 - -pckbd* at pckbc? -wskbd* at pckbd? mux 1 -pms* at pckbc? -wsmouse* at pms? mux 0 - -grtwo* at gio? # Express (GR2/GR3) graphics -wsdisplay* at grtwo? -impact* at gio? # Impact graphics -wsdisplay* at impact? -light* at gio? # Light/Starter/Entry (LG1/LG2) graphics -wsdisplay* at light? -newport* at gio? # Indy Newport and Indigo2 XL graphics -wsdisplay* at newport? - -giopci* at gio? -pci* at giopci? - -#dc* at pci? # Phobos G100/G130/G160 Fast Ethernet -#lxtphy* at mii? # Level1 LXT970 PHYs -#ukphy* at mii? # "unknown" PHYs - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? -ch* at scsibus? -safte* at scsibus? -ses* at scsibus? -uk* at scsibus? - -#pseudo-device hotplug 1 # devices hot plugging -pseudo-device wsmux 2 # Mouse and keyboard multiplexor diff --git a/sys/arch/sgi/conf/GENERIC-IP26 b/sys/arch/sgi/conf/GENERIC-IP26 deleted file mode 100644 index 616f6b9bde4..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP26 +++ /dev/null @@ -1,87 +0,0 @@ -# $OpenBSD: GENERIC-IP26,v 1.4 2018/02/14 23:51:49 jsg Exp $ -# -# THIS KERNEL IS FOR POWER INDIGO2 R8000 (IP26) SYSTEMS ONLY. -# -# For further information on compiling OpenBSD kernels, see the config(8) -# man page. -# -# For further information on hardware support for this architecture, see -# the intro(4) man page. For further information about kernel options -# for this architecture, see the options(4) man page. For an explanation -# of each device driver in this file see the section 4 man page for the -# device. - -machine sgi mips64 -include "../../../conf/GENERIC" -maxusers 32 # Estimated number of users - -# Make options -makeoption LINK_ADDRESS="0xa800000008010000" -option KERNBASE="0xa800000008000000" - -option WSDISPLAY_COMPAT_RAWKBD # Provide raw scancodes; needed for X11 - -option EISAVERBOSE -option PCIVERBOSE -option USER_PCICONF # User-space PCI configuration - -# Define what targets to support -option TGT_INDIGO2 # Indigo2 -option ARCBIOS # mandatory -option CPU_R8000 # R8000 support - -config bsd swap generic - -# -# Definition of system -# -mainbus0 at root -cpu* at mainbus0 - -tcc0 at mainbus0 # Streaming Cache Controller -int0 at mainbus0 # Interrupt Controller and scheduling clock -imc0 at mainbus0 # Memory Controller -gio0 at imc0 -eisa0 at imc0 - -hpc0 at gio? addr 0x1fb80000 - -dsclock0 at hpc0 -sq* at hpc? # On-board Ethernet -wdsc* at hpc? # On-board SCSI -panel* at hpc0 # front panel buttons -pckbc* at hpc0 # keyboard and mouse - -zs0 at hpc0 -zstty* at zs0 # Serial ports - -pckbd* at pckbc? -wskbd* at pckbd? mux 1 -pms* at pckbc? -wsmouse* at pms? mux 0 - -grtwo* at gio? # Express (GR2/GR3) graphics -wsdisplay* at grtwo? -#impact* at gio? # Impact graphics -#wsdisplay* at impact? -newport* at gio? # XL graphics -wsdisplay* at newport? - -giopci* at gio? -pci* at giopci? - -#dc* at pci? # Phobos G100/G130/G160 Fast Ethernet -#lxtphy* at mii? # Level1 LXT970 PHYs -#ukphy* at mii? # "unknown" PHYs - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? -ch* at scsibus? -safte* at scsibus? -ses* at scsibus? -uk* at scsibus? - -#pseudo-device hotplug 1 # devices hot plugging -pseudo-device wsmux 2 # Mouse and keyboard multiplexor diff --git a/sys/arch/sgi/conf/GENERIC-IP27 b/sys/arch/sgi/conf/GENERIC-IP27 deleted file mode 100644 index 75ce0247c65..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP27 +++ /dev/null @@ -1,292 +0,0 @@ -# $OpenBSD: GENERIC-IP27,v 1.68 2021/02/04 16:25:39 anton Exp $ -# -# THIS KERNEL IS FOR Origin, Onyx, Fuel, Tezro (IP27, IP35) SYSTEMS ONLY. -# -# For further information on compiling OpenBSD kernels, see the config(8) -# man page. -# -# For further information on hardware support for this architecture, see -# the intro(4) man page. For further information about kernel options -# for this architecture, see the options(4) man page. For an explanation -# of each device driver in this file see the section 4 man page for the -# device. - -machine sgi mips64 -include "../../../conf/GENERIC" -maxusers 32 # Estimated number of users - -# Make options -makeoption LINK_ADDRESS="0xa800000000040000" -option KERNBASE="0xa800000000000000" - -option PCIVERBOSE -option USER_PCICONF # User-space PCI configuration -option USBVERBOSE - -# Define what targets to support -option TGT_ORIGIN # IP27/IP35 -option TGT_COHERENT # mandatory -option ARCBIOS # mandatory -option CPU_R10000 # R10000/R12000/R14000/R16000 support -option MIPS_PTE64 - -config bsd swap generic - -# -# Definition of system -# -mainbus0 at root -cpu* at mainbus0 -spdmem* at mainbus0 # SPD memory eeproms -clock0 at mainbus0 - -#### Main local buses -xbow* at mainbus0 - -# XBow devices -xbridge* at xbow? -xbpci* at xbridge? -pci* at xbpci? -impact* at xbow? -wsdisplay* at impact? -odyssey* at xbow? -wsdisplay* at odyssey? - -# IOC3 -ioc* at pci? -com0 at ioc? base 0x00020178 -com1 at ioc? base 0x00020170 -com* at ioc? -dsrtc0 at ioc? -iec* at ioc? -iockbc* at ioc? - -onewire* at ioc? -option ONEWIREVERBOSE -owmac* at onewire? -owserial* at onewire? - -# IOC4 -iof* at pci? -com0 at iof? base 0x380 -com1 at iof? base 0x388 -com2 at iof? base 0x390 -com3 at iof? base 0x398 -com* at iof? -dsrtc0 at iof? -iockbc* at iof? - -#### SCSI -ahc* at pci? -qlw* at pci? -qla* at pci? -qle* at pci? -mpi* at pci? -siop* at pci? - - -# CardBus bus support -cbb* at pci? -cardslot* at cbb? -cardbus* at cardslot? -pcmcia* at cardslot? - -# USB Controllers -ohci* at pci? # Open Host Controller -ohci* at cardbus? -uhci* at pci? # Universal Host Controller -uhci* at cardbus? -ehci* at pci? # Enhanced Host Controller -ehci* at cardbus? - -# USB bus support -usb* at ohci? -usb* at uhci? -usb* at ehci? - -# USB devices -uhub* at usb? # USB Hubs -uhub* at uhub? # USB Hubs -urng* at uhub? # USB Random Number Generator -uonerng* at uhub? # Moonbase Otago OneRNG -umodem* at uhub? # USB Modems/Serial -ucom* at umodem? -uvscom* at uhub? # SUNTAC Slipper U VS-10U serial -ucom* at uvscom? -ubsa* at uhub? # Belkin serial adapter -ucom* at ubsa? -uaudio* at uhub? # USB Audio -audio* at uaudio? -ulpt* at uhub? # USB Printers -umass* at uhub? # USB Mass Storage devices -uhidev* at uhub? # Human Interface Devices -ums* at uhidev? # USB mouse -wsmouse* at ums? mux 0 -ukbd* at uhidev? # USB keyboard -wskbd* at ukbd? mux 1 -uslhcom* at uhidev? # Silicon Labs CP2110 USB HID UART -ucom* at uslhcom? -uhid* at uhidev? # USB generic HID support -fido* at uhidev? # FIDO/U2F security key support -ujoy* at uhidev? # USB joystick/gamecontroller support -uhidpp* at uhidev? # Logitech HID++ Devices -atu* at uhub? # Atmel AT76c50x based 802.11b -aue* at uhub? # ADMtek AN986 Pegasus Ethernet -axe* at uhub? # ASIX Electronics AX88172 USB Ethernet -axen* at uhub? # ASIX Electronics AX88179 USB Ethernet -cdce* at uhub? # CDC Ethernet -cue* at uhub? # CATC USB-EL1201A based Ethernet -kue* at uhub? # Kawasaki KL5KUSB101B based Ethernet -mos* at uhub? # MOSCHIP MCS7730/7830 10/100 Ethernet -otus* at uhub? # Atheros AR9001U -rsu* at uhub? # Realtek RTL8188SU/RTL8191SU/RTL8192SU -rum* at uhub? # Ralink RT2501USB/RT2601USB -run* at uhub? # Ralink RT2700U/RT2800U/RT3000U -smsc* at uhub? # SMSC LAN95xx Ethernet -uath* at uhub? # Atheros AR5005UG/AR5005UX -udav* at uhub? # Davicom DM9601 based Ethernet -upgt* at uhub? # Conexant/Intersil PrismGT SoftMAC USB -upl* at uhub? # Prolific PL2301/PL2302 host-to-host `network' -ugl* at uhub? # Genesys Logic GL620USB-A host-to-host `network' -ural* at uhub? # Ralink RT2500USB -url* at uhub? # Realtek RTL8150L based adapters -ure* at uhub? # Realtek RTL8152 based adapters -urtw* at uhub? # Realtek 8187 -urtwn* at uhub? # Realtek RTL8188CU/RTL8192CU -wi* at uhub? # WaveLAN IEEE 802.11DS -zyd* at uhub? # Zydas ZD1211 -ugen* at uhub? # USB Generic driver -uthum* at uhidev? # TEMPerHUM sensor -ugold* at uhidev? # gold TEMPer sensor -utwitch* at uhidev? # YUREX BBU sensor - -# USB Video -uvideo* at uhub? -video* at uvideo? - -utvfu* at uhub? # Fushicai Audio-Video Grabber -video* at utvfu? -audio* at utvfu? - -udl* at uhub? -wsdisplay* at udl? - -ppb* at pci? # PCI-PCI bridges -pci* at ppb? - -#### NICs -pcn* at pci? # AMD PCnet-PCI Ethernet -epic* at pci? # SMC EPIC/100 ethernet -de* at pci? # DC21X4X-based ethernet -dc* at pci? # 21143, "tulip" clone ethernet -dc* at cardbus? -sf* at pci? # Adaptec AIC-6915 ethernet -em* at pci? # Intel Pro/1000 ethernet -ep* at pci? # 3Com 3c59x -ep* at pcmcia? -fxp* at pci? # EtherExpress 10/100B ethernet -fxp* at cardbus? -mtd* at pci? # Myson MTD803 3-in-1 Ethernet -ne* at pci? # NE2000-compatible Ethernet -ne* at pcmcia? -ti* at pci? # Alteon ACEnic gigabit Ethernet -stge* at pci? # Sundance TC9021 GigE -vr* at pci? # VIA Rhine Fast Ethernet -xl* at pci? # 3C9xx ethernet -xl* at cardbus? -re* at pci? # Realtek 8169/8169S/8110S -re* at cardbus? -rl* at pci? # Realtek 81[23]9 ethernet -rl* at cardbus? -hme* at pci? # Sun Happy Meal -gem* at pci? # Sun 'gem' ethernet -cas* at pci? # Sun Cassini 100/Gigabit -skc* at pci? # SysKonnect GEnesis 984x -sk* at skc? # each port of above -mskc* at pci? # Marvell Yukon-2 -msk* at mskc? # each port of above -bge* at pci? # Broadcom BCM570x (aka Tigon3) -vge* at pci? # VIA VT612x -bnx* at pci? # Broadcom BCM5706/5708 GigE -sis* at pci? # SiS 900/7016 ethernet - -##### Media Independent Interface (mii) drivers -exphy* at mii? # 3Com internal PHYs -inphy* at mii? # Intel 82555 PHYs -iophy* at mii? # Intel 82553 PHYs -icsphy* at mii? # ICS 1890 PHYs -lxtphy* at mii? # Level1 LXT970 PHYs -nsphy* at mii? # NS and compatible PHYs -nsphyter* at mii? # NS and compatible PHYs -qsphy* at mii? # Quality Semi QS6612 PHYs -sqphy* at mii? # Seeq 8x220 PHYs -luphy* at mii? # Lucent LU6612 PHY -rlphy* at mii? # Realtek 8139 internal PHYs -mtdphy* at mii? # Myson MTD972 PHYs -dcphy* at mii? # Digital Clone PHYs -acphy* at mii? # Altima AC101 PHYs -amphy* at mii? # AMD 79C873 PHYs -tqphy* at mii? # TDK 78Q212x PHYs -bmtphy* at mii? # Broadcom 10/100 PHYs -brgphy* at mii? # Broadcom Gigabit PHYs -ciphy* at mii? # Cicada CS8201 10/100/1000 copper PHY -eephy* at mii? # Marvell 88E1000 series PHY -xmphy* at mii? # XaQti XMAC-II PHYs -nsgphy* at mii? # NS gigabit PHYs -urlphy* at mii? # Realtek RTL8150L internal PHY -rgephy* at mii? # Realtek 8169S/8110S PHY -ipgphy* at mii? # IC Plus IP1000A PHYs -gentbi* at mii? # Generic 1000BASE-X ten-bit PHY -ukphy* at mii? # "unknown" PHYs - -#### Wireless -acx* at pci? # TI ACX100/ACX111 (802.11b/g) -acx* at cardbus? -malo* at pci? # Marvell Libertas -wi* at pci? # WaveLAN IEEE 802.11DS -wi* at pcmcia? - -#### Audio -cmpci* at pci? # C-Media CMI8338/8738 -eap* at pci? # Ensoniq AudioPCI S5016 -emu* at pci? # SB Live! -envy* at pci? # VIA Envy24 (aka ICE1712) - -audio* at cmpci? -audio* at eap? -audio* at emu? -audio* at envy? - -# MIDI support -midi* at eap? - -#### Keyboard and Mouse -pckbd* at iockbc? -pms* at iockbc? -wskbd* at pckbd? mux 1 -wsmouse* at pms? mux 0 - -#### SCSI Bus devices -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? -ch* at scsibus? -safte* at scsibus? -ses* at scsibus? -uk* at scsibus? - -#### Crypto devices -hifn* at pci? # Hifn7751/7811/7951 -ubsec* at pci? # Broadcom 58xx - -# PCI "universal" communication device -puc* at pci? -com* at puc? -#lpt* at puc? - -com* at pcmcia? -com* at cardbus? - -pseudo-device hotplug 1 # devices hot plugging -pseudo-device wsmux 2 # Mouse and keyboard multiplexor diff --git a/sys/arch/sgi/conf/GENERIC-IP27.MP b/sys/arch/sgi/conf/GENERIC-IP27.MP deleted file mode 100644 index 592277b3a38..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP27.MP +++ /dev/null @@ -1,6 +0,0 @@ -# $OpenBSD: GENERIC-IP27.MP,v 1.1 2015/12/27 16:31:08 deraadt Exp $ - -include "arch/sgi/conf/GENERIC-IP27" - -option MULTIPROCESSOR -#option MP_LOCKDEBUG diff --git a/sys/arch/sgi/conf/GENERIC-IP28 b/sys/arch/sgi/conf/GENERIC-IP28 deleted file mode 100644 index 9918a08414c..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP28 +++ /dev/null @@ -1,86 +0,0 @@ -# $OpenBSD: GENERIC-IP28,v 1.6 2018/02/14 23:51:49 jsg Exp $ -# -# THIS KERNEL IS FOR POWER INDIGO2 R10000 (IP28) SYSTEMS ONLY. -# -# For further information on compiling OpenBSD kernels, see the config(8) -# man page. -# -# For further information on hardware support for this architecture, see -# the intro(4) man page. For further information about kernel options -# for this architecture, see the options(4) man page. For an explanation -# of each device driver in this file see the section 4 man page for the -# device. - -machine sgi mips64 -include "../../../conf/GENERIC" -maxusers 32 # Estimated number of users - -# Make options -makeoption LINK_ADDRESS="0xa800000020020000" -option KERNBASE="0xa800000020000000" - -option WSDISPLAY_COMPAT_RAWKBD # Provide raw scancodes; needed for X11 - -option EISAVERBOSE -option PCIVERBOSE -option USER_PCICONF # User-space PCI configuration - -# Define what targets to support -option TGT_INDIGO2 # Indigo2 -option ARCBIOS # mandatory -option CPU_R10000 # R10000 support - -config bsd swap generic - -# -# Definition of system -# -mainbus0 at root -cpu* at mainbus0 - -int0 at mainbus0 # Interrupt Controller and scheduling clock -imc0 at mainbus0 # Memory Controller -gio0 at imc0 -eisa0 at imc0 - -hpc0 at gio? addr 0x1fb80000 - -dsclock0 at hpc0 -sq* at hpc? # On-board Ethernet -wdsc* at hpc? # On-board SCSI -panel* at hpc0 # front panel buttons -pckbc* at hpc0 # keyboard and mouse - -zs0 at hpc0 -zstty* at zs0 # Serial ports - -pckbd* at pckbc? -wskbd* at pckbd? mux 1 -pms* at pckbc? -wsmouse* at pms? mux 0 - -grtwo* at gio? # Express (GR2/GR3) graphics -wsdisplay* at grtwo? -impact* at gio? # Impact graphics -wsdisplay* at impact? -newport* at gio? # XL graphics -wsdisplay* at newport? - -giopci* at gio? -pci* at giopci? - -#dc* at pci? # Phobos G100/G130/G160 Fast Ethernet -#lxtphy* at mii? # Level1 LXT970 PHYs -#ukphy* at mii? # "unknown" PHYs - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? -ch* at scsibus? -safte* at scsibus? -ses* at scsibus? -uk* at scsibus? - -#pseudo-device hotplug 1 # devices hot plugging -pseudo-device wsmux 2 # Mouse and keyboard multiplexor diff --git a/sys/arch/sgi/conf/GENERIC-IP30 b/sys/arch/sgi/conf/GENERIC-IP30 deleted file mode 100644 index a9e5b034fca..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP30 +++ /dev/null @@ -1,283 +0,0 @@ -# $OpenBSD: GENERIC-IP30,v 1.61 2021/02/04 16:25:39 anton Exp $ -# -# THIS KERNEL IS FOR Octane and Octane 2 (IP30) SYSTEMS ONLY. -# -# For further information on compiling OpenBSD kernels, see the config(8) -# man page. -# -# For further information on hardware support for this architecture, see -# the intro(4) man page. For further information about kernel options -# for this architecture, see the options(4) man page. For an explanation -# of each device driver in this file see the section 4 man page for the -# device. - -machine sgi mips64 -include "../../../conf/GENERIC" -maxusers 32 # Estimated number of users - -# Make options -makeoption LINK_ADDRESS="0xa800000020020000" -option KERNBASE="0xa800000020000000" - -option PCIVERBOSE -option USER_PCICONF # User-space PCI configuration -option USBVERBOSE - -# Define what targets to support -option TGT_OCTANE # Octane, Octane 2 -option TGT_COHERENT # mandatory -option ARCBIOS # mandatory -option CPU_R10000 # R10000/R12000/R14000/R16000 support - -config bsd swap generic - -# -# Definition of system -# -mainbus0 at root -cpu* at mainbus0 -clock0 at mainbus0 -power0 at mainbus0 - -#### Main local buses -xbow0 at mainbus0 - -# XBow devices -xheart* at xbow? -onewire* at xheart? -xbridge* at xbow? -xbpci* at xbridge? -pci* at xbpci? -impact* at xbow? -wsdisplay* at impact? -odyssey* at xbow? -wsdisplay* at odyssey? - -# IOC3 -ioc* at pci? -com0 at ioc? base 0x00020178 -com1 at ioc? base 0x00020170 -com* at ioc? -dsrtc0 at ioc? -iec* at ioc? -iockbc* at ioc? - -onewire* at ioc? -option ONEWIREVERBOSE -owmac* at onewire? -owserial* at onewire? - -#### SCSI -ahc* at pci? -qlw* at pci? -qla* at pci? -qle* at pci? -mpi* at pci? -siop* at pci? - - -# CardBus bus support -cbb* at pci? -cardslot* at cbb? -cardbus* at cardslot? -pcmcia* at cardslot? - -# USB Controllers -ohci* at pci? # Open Host Controller -ohci* at cardbus? -uhci* at pci? # Universal Host Controller -uhci* at cardbus? -ehci* at pci? # Enhanced Host Controller -ehci* at cardbus? - -# USB bus support -usb* at ohci? -usb* at uhci? -usb* at ehci? - -# USB devices -uhub* at usb? # USB Hubs -uhub* at uhub? # USB Hubs -urng* at uhub? # USB Random Number Generator -uonerng* at uhub? # Moonbase Otago OneRNG -umodem* at uhub? # USB Modems/Serial -ucom* at umodem? -uvscom* at uhub? # SUNTAC Slipper U VS-10U serial -ucom* at uvscom? -ubsa* at uhub? # Belkin serial adapter -ucom* at ubsa? -uaudio* at uhub? # USB Audio -audio* at uaudio? -ulpt* at uhub? # USB Printers -umass* at uhub? # USB Mass Storage devices -uhidev* at uhub? # Human Interface Devices -ums* at uhidev? # USB mouse -wsmouse* at ums? mux 0 -ukbd* at uhidev? # USB keyboard -wskbd* at ukbd? mux 1 -uslhcom* at uhidev? # Silicon Labs CP2110 USB HID UART -ucom* at uslhcom? -uhid* at uhidev? # USB generic HID support -fido* at uhidev? # FIDO/U2F security key support -ujoy* at uhidev? # USB joystick/gamecontroller support -uhidpp* at uhidev? # Logitech HID++ Devices -atu* at uhub? # Atmel AT76c50x based 802.11b -aue* at uhub? # ADMtek AN986 Pegasus Ethernet -axe* at uhub? # ASIX Electronics AX88172 USB Ethernet -axen* at uhub? # ASIX Electronics AX88179 USB Ethernet -cdce* at uhub? # CDC Ethernet -cue* at uhub? # CATC USB-EL1201A based Ethernet -kue* at uhub? # Kawasaki KL5KUSB101B based Ethernet -mos* at uhub? # MOSCHIP MCS7730/7830 10/100 Ethernet -otus* at uhub? # Atheros AR9001U -rsu* at uhub? # Realtek RTL8188SU/RTL8191SU/RTL8192SU -rum* at uhub? # Ralink RT2501USB/RT2601USB -run* at uhub? # Ralink RT2700U/RT2800U/RT3000U -smsc* at uhub? # SMSC LAN95xx Ethernet -uath* at uhub? # Atheros AR5005UG/AR5005UX -udav* at uhub? # Davicom DM9601 based Ethernet -upgt* at uhub? # Conexant/Intersil PrismGT SoftMAC USB -upl* at uhub? # Prolific PL2301/PL2302 host-to-host `network' -ugl* at uhub? # Genesys Logic GL620USB-A host-to-host `network' -ural* at uhub? # Ralink RT2500USB -url* at uhub? # Realtek RTL8150L based adapters -ure* at uhub? # Realtek RTL8152 based adapters -urtw* at uhub? # Realtek 8187 -urtwn* at uhub? # Realtek RTL8188CU/RTL8192CU -wi* at uhub? # WaveLAN IEEE 802.11DS -zyd* at uhub? # Zydas ZD1211 -ugen* at uhub? # USB Generic driver -uthum* at uhidev? # TEMPerHUM sensor -ugold* at uhidev? # gold TEMPer sensor -utwitch* at uhidev? # YUREX BBU sensor - -# USB Video -uvideo* at uhub? -video* at uvideo? - -utvfu* at uhub? # Fushicai Audio-Video Grabber -video* at utvfu? -audio* at utvfu? - -udl* at uhub? -wsdisplay* at udl? - -ppb* at pci? # PCI-PCI bridges -pci* at ppb? - -#### NICs -pcn* at pci? # AMD PCnet-PCI Ethernet -epic* at pci? # SMC EPIC/100 ethernet -de* at pci? # DC21X4X-based ethernet -dc* at pci? # 21143, "tulip" clone ethernet -dc* at cardbus? -sf* at pci? # Adaptec AIC-6915 ethernet -em* at pci? # Intel Pro/1000 ethernet -ep* at pci? # 3Com 3c59x -ep* at pcmcia? -fxp* at pci? # EtherExpress 10/100B ethernet -fxp* at cardbus? -mtd* at pci? # Myson MTD803 3-in-1 Ethernet -ne* at pci? # NE2000-compatible Ethernet -ne* at pcmcia? -ti* at pci? # Alteon ACEnic gigabit Ethernet -stge* at pci? # Sundance TC9021 GigE -vr* at pci? # VIA Rhine Fast Ethernet -xl* at pci? # 3C9xx ethernet -xl* at cardbus? -re* at pci? # Realtek 8169/8169S/8110S -re* at cardbus? -rl* at pci? # Realtek 81[23]9 ethernet -rl* at cardbus? -hme* at pci? # Sun Happy Meal -gem* at pci? # Sun 'gem' ethernet -cas* at pci? # Sun Cassini 100/Gigabit -skc* at pci? # SysKonnect GEnesis 984x -sk* at skc? # each port of above -mskc* at pci? # Marvell Yukon-2 -msk* at mskc? # each port of above -bge* at pci? # Broadcom BCM570x (aka Tigon3) -vge* at pci? # VIA VT612x -bnx* at pci? # Broadcom BCM5706/5708 GigE -sis* at pci? # SiS 900/7016 ethernet - -##### Media Independent Interface (mii) drivers -exphy* at mii? # 3Com internal PHYs -inphy* at mii? # Intel 82555 PHYs -iophy* at mii? # Intel 82553 PHYs -icsphy* at mii? # ICS 1890 PHYs -lxtphy* at mii? # Level1 LXT970 PHYs -nsphy* at mii? # NS and compatible PHYs -nsphyter* at mii? # NS and compatible PHYs -qsphy* at mii? # Quality Semi QS6612 PHYs -sqphy* at mii? # Seeq 8x220 PHYs -luphy* at mii? # Lucent LU6612 PHY -rlphy* at mii? # Realtek 8139 internal PHYs -mtdphy* at mii? # Myson MTD972 PHYs -dcphy* at mii? # Digital Clone PHYs -acphy* at mii? # Altima AC101 PHYs -amphy* at mii? # AMD 79C873 PHYs -tqphy* at mii? # TDK 78Q212x PHYs -bmtphy* at mii? # Broadcom 10/100 PHYs -brgphy* at mii? # Broadcom Gigabit PHYs -ciphy* at mii? # Cicada CS8201 10/100/1000 copper PHY -eephy* at mii? # Marvell 88E1000 series PHY -xmphy* at mii? # XaQti XMAC-II PHYs -nsgphy* at mii? # NS gigabit PHYs -urlphy* at mii? # Realtek RTL8150L internal PHY -rgephy* at mii? # Realtek 8169S/8110S PHY -ipgphy* at mii? # IC Plus IP1000A PHYs -gentbi* at mii? # Generic 1000BASE-X ten-bit PHY -ukphy* at mii? # "unknown" PHYs - -#### Wireless -acx* at pci? # TI ACX100/ACX111 (802.11b/g) -acx* at cardbus? -malo* at pci? # Marvell Libertas -wi* at pci? # WaveLAN IEEE 802.11DS -wi* at pcmcia? - -#### Audio -cmpci* at pci? # C-Media CMI8338/8738 -eap* at pci? # Ensoniq AudioPCI S5016 -emu* at pci? # SB Live! -envy* at pci? # VIA Envy24 (aka ICE1712) - -audio* at cmpci? -audio* at eap? -audio* at emu? -audio* at envy? - -# MIDI support -midi* at eap? - -#### Keyboard and Mouse -pckbd* at iockbc? -pms* at iockbc? -wskbd* at pckbd? mux 1 -wsmouse* at pms? mux 0 - -#### SCSI Bus devices -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? -ch* at scsibus? -safte* at scsibus? -ses* at scsibus? -uk* at scsibus? - -#### Crypto devices -hifn* at pci? # Hifn7751/7811/7951 -ubsec* at pci? # Broadcom 58xx - -# PCI "universal" communication device -puc* at pci? -com* at puc? -#lpt* at puc? - -com* at pcmcia? -com* at cardbus? - -pseudo-device hotplug 1 # devices hot plugging -pseudo-device wsmux 2 # Mouse and keyboard multiplexor diff --git a/sys/arch/sgi/conf/GENERIC-IP30.MP b/sys/arch/sgi/conf/GENERIC-IP30.MP deleted file mode 100644 index 1aec2cffa72..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP30.MP +++ /dev/null @@ -1,8 +0,0 @@ -# $OpenBSD: GENERIC-IP30.MP,v 1.1 2010/01/18 17:05:52 miod Exp $ - -include "arch/sgi/conf/GENERIC-IP30" - -option MULTIPROCESSOR -#option MP_LOCKDEBUG - -cpu* at mainbus? diff --git a/sys/arch/sgi/conf/GENERIC-IP32 b/sys/arch/sgi/conf/GENERIC-IP32 deleted file mode 100644 index 6719f883044..00000000000 --- a/sys/arch/sgi/conf/GENERIC-IP32 +++ /dev/null @@ -1,279 +0,0 @@ -# $OpenBSD: GENERIC-IP32,v 1.52 2021/02/04 16:25:39 anton Exp $ -# -# THIS KERNEL IS FOR O2 (IP32) SYSTEMS ONLY. -# -# For further information on compiling OpenBSD kernels, see the config(8) -# man page. -# -# For further information on hardware support for this architecture, see -# the intro(4) man page. For further information about kernel options -# for this architecture, see the options(4) man page. For an explanation -# of each device driver in this file see the section 4 man page for the -# device. - -machine sgi mips64 -include "../../../conf/GENERIC" -maxusers 32 # Estimated number of users - -# Make options -makeoption LINK_ADDRESS="0xffffffff80100000" -option KERNBASE="0xffffffff80000000" - -option WSDISPLAY_COMPAT_RAWKBD # Provide raw scancodes; needed for X11 - -option PCIVERBOSE -option USER_PCICONF # User-space PCI configuration - -# Define what targets to support -option TGT_O2 # O2, O2+ -option ARCBIOS # mandatory -option CPU_R5000 # R5000/RM5200 support -option CPU_RM7000 # RM7000 support -option CPU_R10000 # R10000/R12000/R14000/R16000 support - -config bsd swap generic - -# -# Definition of system -# -mainbus0 at root -cpu* at mainbus0 -clock0 at mainbus0 - -#### Main local buses -macebus0 at mainbus0 # MACE controller localbus. - -# GBE Framebuffer -gbe0 at mainbus0 - -# Localbus devices -mec0 at macebus0 -mavb0 at macebus0 -mkbc0 at macebus0 -com0 at macebus0 base 0x00390000 -com1 at macebus0 base 0x00398000 -dsrtc0 at macebus0 -power0 at macebus0 - -#### PCI Bus -macepcibr0 at macebus0 # MACE controller PCI Bus bridge. -pci* at macepcibr? - -#### SCSI -ahc* at pci? -qlw* at pci? -qla* at pci? -qle* at pci? -mpi* at pci? -siop* at pci? - - -# CardBus bus support -cbb* at pci? -cardslot* at cbb? -cardbus* at cardslot? -pcmcia* at cardslot? - -# USB Controllers -ohci* at pci? # Open Host Controller -ohci* at cardbus? -uhci* at pci? # Universal Host Controller -uhci* at cardbus? -ehci* at pci? # Enhanced Host Controller -ehci* at cardbus? - -# USB bus support -usb* at ohci? -usb* at uhci? -usb* at ehci? - -# USB devices -uhub* at usb? # USB Hubs -uhub* at uhub? # USB Hubs -urng* at uhub? # USB Random Number Generator -uonerng* at uhub? # Moonbase Otago OneRNG -umodem* at uhub? # USB Modems/Serial -ucom* at umodem? -uvscom* at uhub? # SUNTAC Slipper U VS-10U serial -ucom* at uvscom? -ubsa* at uhub? # Belkin serial adapter -ucom* at ubsa? -uaudio* at uhub? # USB Audio -audio* at uaudio? -ulpt* at uhub? # USB Printers -umass* at uhub? # USB Mass Storage devices -uhidev* at uhub? # Human Interface Devices -ums* at uhidev? # USB mouse -wsmouse* at ums? mux 0 -ukbd* at uhidev? # USB keyboard -wskbd* at ukbd? mux 1 -uslhcom* at uhidev? # Silicon Labs CP2110 USB HID UART -ucom* at uslhcom? -uhid* at uhidev? # USB generic HID support -fido* at uhidev? # FIDO/U2F security key support -ujoy* at uhidev? # USB joystick/gamecontroller support -uhidpp* at uhidev? # Logitech HID++ Devices -atu* at uhub? # Atmel AT76c50x based 802.11b -aue* at uhub? # ADMtek AN986 Pegasus Ethernet -axe* at uhub? # ASIX Electronics AX88172 USB Ethernet -axen* at uhub? # ASIX Electronics AX88179 USB Ethernet -cdce* at uhub? # CDC Ethernet -cue* at uhub? # CATC USB-EL1201A based Ethernet -kue* at uhub? # Kawasaki KL5KUSB101B based Ethernet -mos* at uhub? # MOSCHIP MCS7730/7830 10/100 Ethernet -otus* at uhub? # Atheros AR9001U -rsu* at uhub? # Realtek RTL8188SU/RTL8191SU/RTL8192SU -rum* at uhub? # Ralink RT2501USB/RT2601USB -run* at uhub? # Ralink RT2700U/RT2800U/RT3000U -smsc* at uhub? # SMSC LAN95xx Ethernet -uath* at uhub? # Atheros AR5005UG/AR5005UX -udav* at uhub? # Davicom DM9601 based Ethernet -upgt* at uhub? # Conexant/Intersil PrismGT SoftMAC USB -upl* at uhub? # Prolific PL2301/PL2302 host-to-host `network' -ugl* at uhub? # Genesys Logic GL620USB-A host-to-host `network' -ural* at uhub? # Ralink RT2500USB -url* at uhub? # Realtek RTL8150L based adapters -ure* at uhub? # Realtek RTL8152 based adapters -urtw* at uhub? # Realtek 8187 -urtwn* at uhub? # Realtek RTL8188CU/RTL8192CU -wi* at uhub? # WaveLAN IEEE 802.11DS -zyd* at uhub? # Zydas ZD1211 -ugen* at uhub? # USB Generic driver -uthum* at uhidev? # TEMPerHUM sensor -ugold* at uhidev? # gold TEMPer sensor -utwitch* at uhidev? # YUREX BBU sensor - -# USB Video -uvideo* at uhub? -video* at uvideo? - -utvfu* at uhub? # Fushicai Audio-Video Grabber -video* at utvfu? -audio* at utvfu? - -udl* at uhub? -wsdisplay* at udl? - -ppb* at pci? # PCI-PCI bridges -pci* at ppb? - -#### NICs -pcn* at pci? # AMD PCnet-PCI Ethernet -epic* at pci? # SMC EPIC/100 ethernet -de* at pci? # DC21X4X-based ethernet -dc* at pci? # 21143, "tulip" clone ethernet -dc* at cardbus? -sf* at pci? # Adaptec AIC-6915 ethernet -em* at pci? # Intel Pro/1000 ethernet -ep* at pci? # 3Com 3c59x -ep* at pcmcia? -fxp* at pci? # EtherExpress 10/100B ethernet -fxp* at cardbus? -mtd* at pci? # Myson MTD803 3-in-1 Ethernet -ne* at pci? # NE2000-compatible Ethernet -ne* at pcmcia? -ti* at pci? # Alteon ACEnic gigabit Ethernet -stge* at pci? # Sundance TC9021 GigE -vr* at pci? # VIA Rhine Fast Ethernet -xl* at pci? # 3C9xx ethernet -xl* at cardbus? -re* at pci? # Realtek 8169/8169S/8110S -re* at cardbus? -rl* at pci? # Realtek 81[23]9 ethernet -rl* at cardbus? -hme* at pci? # Sun Happy Meal -gem* at pci? # Sun 'gem' ethernet -cas* at pci? # Sun Cassini 100/Gigabit -skc* at pci? # SysKonnect GEnesis 984x -sk* at skc? # each port of above -mskc* at pci? # Marvell Yukon-2 -msk* at mskc? # each port of above -bge* at pci? # Broadcom BCM570x (aka Tigon3) -vge* at pci? # VIA VT612x -bnx* at pci? # Broadcom BCM5706/5708 GigE -sis* at pci? # SiS 900/7016 ethernet - -##### Media Independent Interface (mii) drivers -exphy* at mii? # 3Com internal PHYs -inphy* at mii? # Intel 82555 PHYs -iophy* at mii? # Intel 82553 PHYs -icsphy* at mii? # ICS 1890 PHYs -lxtphy* at mii? # Level1 LXT970 PHYs -nsphy* at mii? # NS and compatible PHYs -nsphyter* at mii? # NS and compatible PHYs -qsphy* at mii? # Quality Semi QS6612 PHYs -sqphy* at mii? # Seeq 8x220 PHYs -luphy* at mii? # Lucent LU6612 PHY -rlphy* at mii? # Realtek 8139 internal PHYs -mtdphy* at mii? # Myson MTD972 PHYs -dcphy* at mii? # Digital Clone PHYs -acphy* at mii? # Altima AC101 PHYs -amphy* at mii? # AMD 79C873 PHYs -tqphy* at mii? # TDK 78Q212x PHYs -bmtphy* at mii? # Broadcom 10/100 PHYs -brgphy* at mii? # Broadcom Gigabit PHYs -ciphy* at mii? # Cicada CS8201 10/100/1000 copper PHY -eephy* at mii? # Marvell 88E1000 series PHY -xmphy* at mii? # XaQti XMAC-II PHYs -nsgphy* at mii? # NS gigabit PHYs -urlphy* at mii? # Realtek RTL8150L internal PHY -rgephy* at mii? # Realtek 8169S/8110S PHY -ipgphy* at mii? # IC Plus IP1000A PHYs -gentbi* at mii? # Generic 1000BASE-X ten-bit PHY -ukphy* at mii? # "unknown" PHYs - -#### Wireless -acx* at pci? # TI ACX100/ACX111 (802.11b/g) -acx* at cardbus? -malo* at pci? -wi* at pci? # WaveLAN IEEE 802.11DS -wi* at pcmcia? - -#### Audio -cmpci* at pci? # C-Media CMI8338/8738 -eap* at pci? # Ensoniq AudioPCI S5016 -emu* at pci? # SB Live! -envy* at pci? # VIA Envy24 (aka ICE1712) - -audio* at cmpci? -audio* at eap? -audio* at emu? -audio* at envy? -audio* at mavb? - -# MIDI support -midi* at eap? - -#### WS Console -wsdisplay* at gbe? - -#### Keyboard and Mouse -pckbd* at mkbc? -pms* at mkbc? -wskbd* at pckbd? mux 1 -wsmouse* at pms? mux 0 - -#### SCSI Bus devices -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? -ch* at scsibus? -safte* at scsibus? -ses* at scsibus? -uk* at scsibus? - -#### Crypto devices -hifn* at pci? # Hifn7751/7811/7951 -ubsec* at pci? # Broadcom 58xx - -# PCI "universal" communication device -puc* at pci? -com* at puc? -#lpt* at puc? - -com* at pcmcia? -com* at cardbus? - -pseudo-device hotplug 1 # devices hot plugging -pseudo-device wsmux 2 # Mouse and keyboard multiplexor diff --git a/sys/arch/sgi/conf/Makefile.sgi b/sys/arch/sgi/conf/Makefile.sgi deleted file mode 100644 index 3d6e7c70a5f..00000000000 --- a/sys/arch/sgi/conf/Makefile.sgi +++ /dev/null @@ -1,174 +0,0 @@ -# $OpenBSD: Makefile.sgi,v 1.101 2021/01/28 17:39:03 deraadt Exp $ - -# For instructions on building kernels consult the config(8) and options(4) -# manual pages. -# -# N.B.: NO DEPENDENCIES ON FOLLOWING FLAGS ARE VISIBLE TO MAKEFILE -# IF YOU CHANGE THE DEFINITION OF ANY OF THESE RECOMPILE EVERYTHING -# DEBUG is set to -g by config if debugging is requested (config -g). -# PROF is set to -pg by config if profiling is requested (config -p). - -.include <bsd.own.mk> - -SIZE?= size -STRIP?= ctfstrip -AS?= as -CC?= cc -LD?= ld ${ENDIAN} - -AS+=${ENDIAN} -CC+=${ENDIAN} -LD+=${ENDIAN} - -# source tree is located via $S relative to the compilation directory -.ifndef S -S!= cd ../../../..; pwd -.endif - -_machdir?= $S/arch/${_mach} -_archdir?= $S/arch/${_arch} - -INCLUDES= -nostdinc -I$S -I${.OBJDIR} -I$S/arch -CPPFLAGS= ${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -D__${_mach}__ -MD -MP -CWARNFLAGS= -Werror -Wall -Wimplicit-function-declaration \ - -Wno-uninitialized -Wno-pointer-sign \ - -Wframe-larger-than=2047 - -CMACHFLAGS= -mno-abicalls ${ABI} -msoft-float -G 0 -CMACHFLAGS+= -ffreestanding ${NOPIE_FLAGS} -SORTR= sort -R -.if ${IDENT:M-DNO_PROPOLICE} -CMACHFLAGS+= -fno-stack-protector -.endif -.if ${IDENT:M-DSMALL_KERNEL} -SORTR= cat -COPTIMIZE?= -Oz -.endif - -DEBUG?= -g -COPTIMIZE?= -O2 -CFLAGS= ${DEBUG} ${CWARNFLAGS} ${CMACHFLAGS} ${COPTIMIZE} ${COPTS} ${PIPE} -AFLAGS= -D_LOCORE -x assembler-with-cpp ${CWARNFLAGS} ${CMACHFLAGS} -LINKFLAGS= -e start -T ld.script -Ttext=${LINK_ADDRESS} --warn-common -nopie - -HOSTCC?= ${CC} -HOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//} -HOSTED_CFLAGS= ${CFLAGS} -HOSTED_C= ${HOSTCC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $< - -NORMAL_C_NOP= ${CC} ${CFLAGS} ${CPPFLAGS} -c $< -NORMAL_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $< -NORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} ${PROF} -c $< - -%OBJS - -%CFILES - -%SFILES - -# load lines for config "xxx" will be emitted as: -# xxx: ${SYSTEM_DEP} swapxxx.o -# ${SYSTEM_LD_HEAD} -# ${SYSTEM_LD} swapxxx.o -# ${SYSTEM_LD_TAIL} -SYSTEM_HEAD= locore0.o gap.o -SYSTEM_OBJ= ${SYSTEM_HEAD} ${OBJS} param.o ioconf.o -SYSTEM_DEP= Makefile ${SYSTEM_OBJ} ld.script -SYSTEM_LD_HEAD= @rm -f $@ -SYSTEM_LD= @echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_HEAD} vers.o $${OBJS}'; \ - umask 007; \ - echo ${OBJS} param.o ioconf.o vers.o | tr " " "\n" | ${SORTR} > lorder; \ - ${LD} ${LINKFLAGS} -o $@ ${SYSTEM_HEAD} `cat lorder` -SYSTEM_LD_TAIL= @${SIZE} $@ - -.if ${DEBUG} == "-g" -STRIPFLAGS= -S -SYSTEM_LD_TAIL+=; umask 007; \ - echo mv $@ $@.gdb; rm -f $@.gdb; mv $@ $@.gdb; \ - echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \ - ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb -.else -LINKFLAGS+= -S -.endif - -%LOAD - -# cc's -MD puts the source and output paths in the dependency file; -# since those are temp files here we need to fix it up. It also -# puts the file in /tmp, so we use -MF to put it in the current -# directory as assym.P and then generate assym.d from it with a -# good target name -assym.h: $S/kern/genassym.sh Makefile \ - ${_archdir}/${_arch}/genassym.cf ${_machdir}/${_mach}/genassym.cf - cat ${_archdir}/${_arch}/genassym.cf ${_machdir}/${_mach}/genassym.cf | \ - sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} -MF assym.P > assym.h.tmp - sed '1s/.*/assym.h: \\/' assym.P > assym.d - sort -u assym.h.tmp > assym.h - -param.c: $S/conf/param.c - rm -f param.c - cp $S/conf/param.c . - -param.o: param.c Makefile - ${NORMAL_C} - -mcount.o: $S/lib/libkern/mcount.c Makefile - ${NORMAL_C_NOP} - -ioconf.o: ioconf.c - ${NORMAL_C} - -ld.script: ${_machdir}/conf/ld.script - cp ${_machdir}/conf/ld.script $@ - -gapdummy.o: - echo '__asm(".section .rodata,\"a\"");' > gapdummy.c - ${CC} -c ${CFLAGS} ${CPPFLAGS} gapdummy.c -o $@ - -makegap.sh: - cp $S/conf/makegap.sh $@ - -MAKE_GAP = LD="${LD}" sh makegap.sh 0xefefefef gapdummy.o - -gap.o: Makefile makegap.sh gapdummy.o vers.o - ${MAKE_GAP} - -vers.o: ${SYSTEM_DEP:Ngap.o} - sh $S/conf/newvers.sh - ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c - -clean: - rm -f *bsd *bsd.gdb *.[dio] [a-z]*.s assym.* \ - gap.link gapdummy.c ld.script lorder makegap.sh param.c - -cleandir: clean - rm -f Makefile *.h ioconf.c options machine ${_mach} vers.c - -depend obj: - -locore0.o: ${_machdir}/${_mach}/locore0.S assym.h -context.o cp0access.o exception.o exception_tfp.o: assym.h -lcore_access.o lcore_ddb.o lcore_float.o locore.o: assym.h -tlb_tfp.o tlbhandler.o: assym.h -cache_tfp_subr.o ip30_nmi.o: assym.h - -hardlink-obsd: - [[ ! -f /bsd ]] || cmp -s bsd /bsd || ln -f /bsd /obsd - -newinstall: - install -m 700 -F bsd /bsd && sha256 -h /var/db/kernel.SHA256 /bsd - -install: update-link hardlink-obsd newinstall - -# pull in the dependency information -.ifnmake clean -. for o in ${SYSTEM_OBJ:Ngap.o} assym.h -. if exists(${o:R}.d) -. include "${o:R}.d" -. elif exists($o) - .PHONY: $o -. endif -. endfor -.endif - -%RULES diff --git a/sys/arch/sgi/conf/RAMDISK-IP22 b/sys/arch/sgi/conf/RAMDISK-IP22 deleted file mode 100644 index 69abb6f6589..00000000000 --- a/sys/arch/sgi/conf/RAMDISK-IP22 +++ /dev/null @@ -1,88 +0,0 @@ -# $OpenBSD: RAMDISK-IP22,v 1.17 2020/04/06 02:10:33 visa Exp $ -# -# THIS KERNEL IS FOR INDIGO (IP20), INDY (IP22) AND INDIGO2 (IP24) SYSTEMS ONLY. - -machine sgi mips64 -maxusers 4 - -option SMALL_KERNEL -option NO_PROPOLICE -option BOOT_CONFIG - -option MINIROOTSIZE=10240 -option RAMDISK_HOOKS - -option EISAVERBOSE -option PCIVERBOSE - -option FFS -option FFS2 -option CD9660 -option NFSCLIENT -option INET6 - -makeoption LINK_ADDRESS="0xffffffff88800000" -option KERNBASE="0xffffffff88000000" -# Force use of 16KB pages. The R5000 Indy, which has the infamous XKPHYS -# coherency bug wrt ll/sc instructions, can not have more than 256MB of -# physical memory, all of it fitting within CKSEG0. -option PAGE_SHIFT="14" -option TGT_INDIGO # R4x00 Indigo (IP20) -option TGT_INDIGO2 # Indigo2, Challenge M (IP22) -option TGT_INDY # Indy, Challenge S (IP24) -option ARCBIOS # mandatory -option CPU_R4000 # R4000/R4400 support (IP20/IP22/IP24) -option CPU_R4600 # R4600 support (IP22/IP24) -option CPU_R5000 # R5000 support (IP24) - -config bsd root on rd0a swap on rd0b - -mainbus0 at root -cpu* at mainbus0 -clock0 at mainbus0 # scheduling clock on Indy - -int0 at mainbus0 # Interrupt Controller and scheduling clock -imc0 at mainbus0 # Memory Controller -gio0 at imc0 -eisa0 at imc0 - -hpc0 at gio? addr 0x1fb80000 -hpc1 at gio? addr 0x1fb00000 -hpc2 at gio? addr 0x1f980000 - -dpclock0 at hpc0 # IP20 -dsclock0 at hpc0 # IP22/24 -sq* at hpc? # On-board Ethernet or E++ adapter -wdsc* at hpc? # On-board SCSI or GIO32 SCSI adapter -pckbc* at hpc0 # Indy/Indigo2 keyboard and mouse - -zs0 at hpc0 -zs1 at hpc0 -zstty* at zs0 # Serial ports -zskbd* at zs1 channel 0 -wskbd* at zskbd? mux 1 - -pckbd* at pckbc? -wskbd* at pckbd? mux 1 - -grtwo* at gio? # Express (GR2/GR3) graphics -wsdisplay* at grtwo? -impact* at gio? # Impact graphics -wsdisplay* at impact? -light* at gio? # Light/Starter/Entry (LG1/LG2) graphics -wsdisplay* at light? -newport* at gio? # Indy Newport and Indigo2 XL graphics -wsdisplay* at newport? - -giopci* at gio? -pci* at giopci? - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? - -pseudo-device loop 1 -pseudo-device bpfilter 1 -pseudo-device rd 1 -pseudo-device bio 1 diff --git a/sys/arch/sgi/conf/RAMDISK-IP26 b/sys/arch/sgi/conf/RAMDISK-IP26 deleted file mode 100644 index 265c7606854..00000000000 --- a/sys/arch/sgi/conf/RAMDISK-IP26 +++ /dev/null @@ -1,70 +0,0 @@ -# $OpenBSD: RAMDISK-IP26,v 1.6 2020/04/06 02:10:33 visa Exp $ -# -# THIS KERNEL IS FOR POWER INDIGO2 R8000 (IP26) SYSTEMS ONLY. - -machine sgi mips64 -maxusers 4 - -option SMALL_KERNEL -option NO_PROPOLICE -option BOOT_CONFIG - -option MINIROOTSIZE=10240 -option RAMDISK_HOOKS - -option EISAVERBOSE -option PCIVERBOSE - -option FFS -option FFS2 -option CD9660 -option NFSCLIENT -option INET6 - -makeoption LINK_ADDRESS="0xa800000008010000" -option KERNBASE="0xa800000008000000" -option TGT_INDIGO2 # Indigo2 -option ARCBIOS # mandatory -option CPU_R8000 # R8000 support - -config bsd root on rd0a swap on rd0b - -mainbus0 at root -cpu* at mainbus0 - -tcc0 at mainbus0 # Streaming Cache Controller -int0 at mainbus0 # Interrupt Controller and scheduling clock -imc0 at mainbus0 # Memory Controller -gio0 at imc0 -eisa0 at imc0 - -hpc0 at gio? addr 0x1fb80000 - -dsclock0 at hpc0 -sq* at hpc? # On-board Ethernet -wdsc* at hpc? # On-board SCSI -pckbc* at hpc0 # keyboard and mouse - -zs0 at hpc0 -zstty* at zs0 # Serial ports - -pckbd* at pckbc? -wskbd* at pckbd? mux 1 - -grtwo* at gio? # Express (GR2/GR3) graphics -wsdisplay* at grtwo? -newport* at gio? # XL graphics -wsdisplay* at newport? - -giopci* at gio? -pci* at giopci? - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? - -pseudo-device loop 1 -pseudo-device bpfilter 1 -pseudo-device rd 1 -pseudo-device bio 1 diff --git a/sys/arch/sgi/conf/RAMDISK-IP27 b/sys/arch/sgi/conf/RAMDISK-IP27 deleted file mode 100644 index fde03982c2e..00000000000 --- a/sys/arch/sgi/conf/RAMDISK-IP27 +++ /dev/null @@ -1,190 +0,0 @@ -# $OpenBSD: RAMDISK-IP27,v 1.41 2020/04/06 02:10:33 visa Exp $ -# -# THIS KERNEL IS FOR Origin, Onyx, Fuel, Tezro (IP27, IP35) SYSTEMS ONLY. - -machine sgi mips64 -maxusers 4 - -option SMALL_KERNEL -option NO_PROPOLICE -option BOOT_CONFIG - -option MINIROOTSIZE=10240 -option RAMDISK_HOOKS - -option PCIVERBOSE -option USBVERBOSE -option ONEWIREVERBOSE - -option FFS -option FFS2 -option CD9660 -option NFSCLIENT -option INET6 - -makeoption LINK_ADDRESS="0xa800000000040000" -option KERNBASE="0xa800000000000000" -option TGT_ORIGIN # IP27/IP35 -option TGT_COHERENT -option ARCBIOS -option CPU_R10000 # R10000/R12000/R14000/R16000 support -option MIPS_PTE64 - -config bsd root on rd0a swap on rd0b - -mainbus0 at root -cpu* at mainbus0 -clock0 at mainbus0 - -xbow* at mainbus0 -xbridge* at xbow? -xbpci* at xbridge? -pci* at xbpci? -impact* at xbow? -wsdisplay* at impact? -odyssey* at xbow? -wsdisplay* at odyssey? - -ioc* at pci? -com0 at ioc? base 0x00020178 -com1 at ioc? base 0x00020170 -dsrtc0 at ioc? -iec* at ioc? -iockbc* at ioc? - -onewire* at ioc? -owmac* at onewire? -owserial* at onewire? - -iof* at pci? -com0 at iof? base 0x380 -com1 at iof? base 0x388 -com2 at iof? base 0x390 -com3 at iof? base 0x398 -com* at iof? -dsrtc0 at iof? -iockbc* at iof? - -ahc* at pci? -qlw* at pci? -qla* at pci? -qle* at pci? -mpi* at pci? -siop* at pci? - -ohci* at pci? -uhci* at pci? -ehci* at pci? -usb* at ohci? -usb* at uhci? -usb* at ehci? - -uhub* at usb? -uhub* at uhub? -umodem* at uhub? # USB Modems/Serial -ucom* at umodem? -uvscom* at uhub? # SUNTAC Slipper U VS-10U serial -ucom* at uvscom? -ubsa* at uhub? # Belkin serial adapter -ucom* at ubsa? -umass* at uhub? -uhidev* at uhub? # Human Interface Devices -ukbd* at uhidev? # USB keyboard -wskbd* at ukbd? mux 1 -uhid* at uhidev? # USB generic HID support -atu* at uhub? # Atmel AT76c50x based 802.11b -aue* at uhub? # ADMtek AN986 Pegasus Ethernet -axe* at uhub? # ASIX Electronics AX88172 USB Ethernet -axen* at uhub? # ASIX Electronics AX88179 USB Ethernet -cdce* at uhub? # CDC Ethernet -cue* at uhub? # CATC USB-EL1201A based Ethernet -kue* at uhub? # Kawasaki KL5KUSB101B based Ethernet -mos* at uhub? # MOSCHIP MCS7730/7830 10/100 Ethernet -otus* at uhub? # Atheros AR9001U -rum* at uhub? # Ralink RT2501USB/RT2601USB -run* at uhub? # Ralink RT2700U/RT2800U/RT3000U -smsc* at uhub? # SMSC LAN95xx Ethernet -uath* at uhub? # Atheros AR5005UG/AR5005UX -udav* at uhub? # Davicom DM9601 based Ethernet -upgt* at uhub? # Conexant/Intersil PrismGT SoftMAC USB -upl* at uhub? # Prolific PL2301/PL2302 host-to-host -ugl* at uhub? # Genesys Logic GL620USB-A host-to-host -ural* at uhub? # Ralink RT2500USB -url* at uhub? # Realtek RTL8150L based adapters -ure* at uhub? # Realtek RTL8152 based adapters -urtw* at uhub? # Realtek 8187 -wi* at uhub? # WaveLAN IEEE 802.11DS -zyd* at uhub? # Zydas ZD1211 -ugen* at uhub? # USB Generic driver - -ppb* at pci? # PCI-PCI bridges -pci* at ppb? - -pcn* at pci? # AMD PCnet-PCI Ethernet -epic* at pci? # SMC EPIC/100 ethernet -de* at pci? # DC21X4X-based ethernet -dc* at pci? # 21143, "tulip" clone ethernet -sf* at pci? # Adaptec AIC-6915 ethernet -em* at pci? # Intel Pro/1000 ethernet -ep* at pci? # 3Com 3c59x -fxp* at pci? # EtherExpress 10/100B ethernet -mtd* at pci? # Myson MTD803 3-in-1 Ethernet -ne* at pci? # NE2000-compatible Ethernet -ti* at pci? # Alteon ACEnic gigabit Ethernet -stge* at pci? # Sundance TC9021 GigE -vr* at pci? # VIA Rhine Fast Ethernet -xl* at pci? # 3C9xx ethernet -re* at pci? # Realtek 8169/8169S/8110S -rl* at pci? # Realtek 81[23]9 ethernet -hme* at pci? # Sun Happy Meal -gem* at pci? # Sun 'gem' ethernet -cas* at pci? # Sun Cassini 100/Gigabit -skc* at pci? # SysKonnect GEnesis 984x -sk* at skc? # each port of above -mskc* at pci? # Marvell Yukon-2 -msk* at mskc? # each port of above -bge* at pci? # Broadcom BCM570x (aka Tigon3) -vge* at pci? # VIA VT612x -bnx* at pci? # Broadcom BCM5706/5708 GigE -sis* at pci? # SiS 900/7016 ethernet - -exphy* at mii? # 3Com internal PHYs -inphy* at mii? # Intel 82555 PHYs -iophy* at mii? # Intel 82553 PHYs -icsphy* at mii? # ICS 1890 PHYs -lxtphy* at mii? # Level1 LXT970 PHYs -nsphy* at mii? # NS and compatible PHYs -nsphyter* at mii? # NS and compatible PHYs -qsphy* at mii? # Quality Semi QS6612 PHYs -sqphy* at mii? # Seeq 8x220 PHYs -luphy* at mii? # Lucent LU6612 PHY -rlphy* at mii? # Realtek 8139 internal PHYs -mtdphy* at mii? # Myson MTD972 PHYs -dcphy* at mii? # Digital Clone PHYs -acphy* at mii? # Altima AC101 PHYs -amphy* at mii? # AMD 79C873 PHYs -tqphy* at mii? # TDK 78Q212x PHYs -bmtphy* at mii? # Broadcom 10/100 PHYs -brgphy* at mii? # Broadcom Gigabit PHYs -ciphy* at mii? # Cicada CS8201 10/100/1000 copper PHY -eephy* at mii? # Marvell 88E1000 series PHY -xmphy* at mii? # XaQti XMAC-II PHYs -nsgphy* at mii? # NS gigabit PHYs -urlphy* at mii? # Realtek RTL8150L internal PHY -rgephy* at mii? # Realtek 8169S/8110S PHY -ipgphy* at mii? # IC Plus IP1000A PHYs -gentbi* at mii? # Generic 1000BASE-X ten-bit PHY -ukphy* at mii? # "unknown" PHYs - -pckbd* at iockbc? -wskbd* at pckbd? mux 1 - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? - -pseudo-device loop 1 -pseudo-device bpfilter 1 -pseudo-device rd 1 -pseudo-device bio 1 diff --git a/sys/arch/sgi/conf/RAMDISK-IP28 b/sys/arch/sgi/conf/RAMDISK-IP28 deleted file mode 100644 index e07ea14fbe7..00000000000 --- a/sys/arch/sgi/conf/RAMDISK-IP28 +++ /dev/null @@ -1,71 +0,0 @@ -# $OpenBSD: RAMDISK-IP28,v 1.8 2020/04/06 02:10:33 visa Exp $ -# -# THIS KERNEL IS FOR POWER INDIGO2 R10000 (IP28) SYSTEMS ONLY. - -machine sgi mips64 -maxusers 4 - -option SMALL_KERNEL -option NO_PROPOLICE -option BOOT_CONFIG - -option MINIROOTSIZE=10240 -option RAMDISK_HOOKS - -option PCIVERBOSE -option EISAVERBOSE - -option FFS -option FFS2 -option CD9660 -option NFSCLIENT -option INET6 - -makeoption LINK_ADDRESS="0xa800000020020000" -option KERNBASE="0xa800000020000000" -option TGT_INDIGO2 # Indigo2 -option ARCBIOS # mandatory -option CPU_R10000 # R10000 support - -config bsd root on rd0a swap on rd0b - -mainbus0 at root -cpu* at mainbus0 - -int0 at mainbus0 # Interrupt Controller and scheduling clock -imc0 at mainbus0 # Memory Controller -gio0 at imc0 -eisa0 at imc0 - -hpc0 at gio? addr 0x1fb80000 - -dsclock0 at hpc0 -sq* at hpc? # On-board Ethernet -wdsc* at hpc? # On-board SCSI -pckbc* at hpc0 # keyboard and mouse - -zs0 at hpc0 -zstty* at zs0 # Serial ports - -pckbd* at pckbc? -wskbd* at pckbd? mux 1 - -grtwo* at gio? # Express (GR2/GR3) graphics -wsdisplay* at grtwo? -impact* at gio? # Impact graphics -wsdisplay* at impact? -newport* at gio? # XL graphics -wsdisplay* at newport? - -giopci* at gio? -pci* at giopci? - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? - -pseudo-device loop 1 -pseudo-device bpfilter 1 -pseudo-device rd 1 -pseudo-device bio 1 diff --git a/sys/arch/sgi/conf/RAMDISK-IP30 b/sys/arch/sgi/conf/RAMDISK-IP30 deleted file mode 100644 index a251d53eb64..00000000000 --- a/sys/arch/sgi/conf/RAMDISK-IP30 +++ /dev/null @@ -1,183 +0,0 @@ -# $OpenBSD: RAMDISK-IP30,v 1.36 2020/04/06 02:10:33 visa Exp $ -# -# THIS KERNEL IS FOR Octane and Octane 2 (IP30) SYSTEMS ONLY. - -machine sgi mips64 -maxusers 4 - -option SMALL_KERNEL -option NO_PROPOLICE -option BOOT_CONFIG - -option MINIROOTSIZE=10240 -option RAMDISK_HOOKS - -option PCIVERBOSE -option USBVERBOSE -option ONEWIREVERBOSE - -option FFS -option FFS2 -option CD9660 -option NFSCLIENT -option INET6 - -makeoption LINK_ADDRESS="0xa800000020020000" -option KERNBASE="0xa800000020000000" - -option TGT_OCTANE # Octane, Octane 2 -option TGT_COHERENT -option ARCBIOS -option CPU_R10000 # R10000/R12000/R14000/R16000 support - -config bsd root on rd0a swap on rd0b - -mainbus0 at root -cpu* at mainbus0 -clock0 at mainbus0 -xbow0 at mainbus0 -xheart* at xbow? -onewire* at xheart? -xbridge* at xbow? -xbpci* at xbridge? -pci* at xbpci? -impact* at xbow? -wsdisplay* at impact? -odyssey* at xbow? -wsdisplay* at odyssey? - -ioc* at pci? -com0 at ioc? base 0x00020178 -com1 at ioc? base 0x00020170 -com* at ioc? -dsrtc0 at ioc? -iec* at ioc? -iockbc* at ioc? - -onewire* at ioc? -owmac* at onewire? -owserial* at onewire? - -ahc* at pci? -qlw* at pci? -qla* at pci? -qle* at pci? -mpi* at pci? -siop* at pci? - -ohci* at pci? -uhci* at pci? -ehci* at pci? -usb* at ohci? -usb* at uhci? -usb* at ehci? - -uhub* at usb? -uhub* at uhub? -umodem* at uhub? # USB Modems/Serial -ucom* at umodem? -uvscom* at uhub? # SUNTAC Slipper U VS-10U serial -ucom* at uvscom? -ubsa* at uhub? # Belkin serial adapter -ucom* at ubsa? -umass* at uhub? -uhidev* at uhub? # Human Interface Devices -ukbd* at uhidev? # USB keyboard -wskbd* at ukbd? mux 1 -uhid* at uhidev? # USB generic HID support -atu* at uhub? # Atmel AT76c50x based 802.11b -aue* at uhub? # ADMtek AN986 Pegasus Ethernet -axe* at uhub? # ASIX Electronics AX88172 USB Ethernet -axen* at uhub? # ASIX Electronics AX88179 USB Ethernet -cdce* at uhub? # CDC Ethernet -cue* at uhub? # CATC USB-EL1201A based Ethernet -kue* at uhub? # Kawasaki KL5KUSB101B based Ethernet -mos* at uhub? # MOSCHIP MCS7730/7830 10/100 Ethernet -otus* at uhub? # Atheros AR9001U -rum* at uhub? # Ralink RT2501USB/RT2601USB -run* at uhub? # Ralink RT2700U/RT2800U/RT3000U -smsc* at uhub? # SMSC LAN95xx Ethernet -uath* at uhub? # Atheros AR5005UG/AR5005UX -udav* at uhub? # Davicom DM9601 based Ethernet -upgt* at uhub? # Conexant/Intersil PrismGT SoftMAC USB -upl* at uhub? # Prolific PL2301/PL2302 host-to-host -ugl* at uhub? # Genesys Logic GL620USB-A host-to-host -ural* at uhub? # Ralink RT2500USB -url* at uhub? # Realtek RTL8150L based adapters -ure* at uhub? # Realtek RTL8152 based adapters -urtw* at uhub? # Realtek 8187 -wi* at uhub? # WaveLAN IEEE 802.11DS -zyd* at uhub? # Zydas ZD1211 -ugen* at uhub? # USB Generic driver - -ppb* at pci? # PCI-PCI bridges -pci* at ppb? - -pcn* at pci? # AMD PCnet-PCI Ethernet -epic* at pci? # SMC EPIC/100 ethernet -de* at pci? # DC21X4X-based ethernet -dc* at pci? # 21143, "tulip" clone ethernet -sf* at pci? # Adaptec AIC-6915 ethernet -em* at pci? # Intel Pro/1000 ethernet -ep* at pci? # 3Com 3c59x -fxp* at pci? # EtherExpress 10/100B ethernet -mtd* at pci? # Myson MTD803 3-in-1 Ethernet -ne* at pci? # NE2000-compatible Ethernet -ti* at pci? # Alteon ACEnic gigabit Ethernet -stge* at pci? # Sundance TC9021 GigE -vr* at pci? # VIA Rhine Fast Ethernet -xl* at pci? # 3C9xx ethernet -re* at pci? # Realtek 8169/8169S/8110S -rl* at pci? # Realtek 81[23]9 ethernet -hme* at pci? # Sun Happy Meal -gem* at pci? # Sun 'gem' ethernet -cas* at pci? # Sun Cassini 100/Gigabit -skc* at pci? # SysKonnect GEnesis 984x -sk* at skc? # each port of above -mskc* at pci? # Marvell Yukon-2 -msk* at mskc? # each port of above -bge* at pci? # Broadcom BCM570x (aka Tigon3) -vge* at pci? # VIA VT612x -bnx* at pci? # Broadcom BCM5706/5708 GigE -sis* at pci? # SiS 900/7016 ethernet - -exphy* at mii? # 3Com internal PHYs -inphy* at mii? # Intel 82555 PHYs -iophy* at mii? # Intel 82553 PHYs -icsphy* at mii? # ICS 1890 PHYs -lxtphy* at mii? # Level1 LXT970 PHYs -nsphy* at mii? # NS and compatible PHYs -nsphyter* at mii? # NS and compatible PHYs -qsphy* at mii? # Quality Semi QS6612 PHYs -sqphy* at mii? # Seeq 8x220 PHYs -luphy* at mii? # Lucent LU6612 PHY -rlphy* at mii? # Realtek 8139 internal PHYs -mtdphy* at mii? # Myson MTD972 PHYs -dcphy* at mii? # Digital Clone PHYs -acphy* at mii? # Altima AC101 PHYs -amphy* at mii? # AMD 79C873 PHYs -tqphy* at mii? # TDK 78Q212x PHYs -bmtphy* at mii? # Broadcom 10/100 PHYs -brgphy* at mii? # Broadcom Gigabit PHYs -ciphy* at mii? # Cicada CS8201 10/100/1000 copper PHY -eephy* at mii? # Marvell 88E1000 series PHY -xmphy* at mii? # XaQti XMAC-II PHYs -nsgphy* at mii? # NS gigabit PHYs -urlphy* at mii? # Realtek RTL8150L internal PHY -rgephy* at mii? # Realtek 8169S/8110S PHY -ipgphy* at mii? # IC Plus IP1000A PHYs -gentbi* at mii? # Generic 1000BASE-X ten-bit PHY -ukphy* at mii? # "unknown" PHYs - -pckbd* at iockbc? -wskbd* at pckbd? mux 1 - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? - -pseudo-device loop 1 -pseudo-device bpfilter 1 -pseudo-device rd 1 -pseudo-device bio 1 diff --git a/sys/arch/sgi/conf/RAMDISK-IP32 b/sys/arch/sgi/conf/RAMDISK-IP32 deleted file mode 100644 index d157923c9c4..00000000000 --- a/sys/arch/sgi/conf/RAMDISK-IP32 +++ /dev/null @@ -1,171 +0,0 @@ -# $OpenBSD: RAMDISK-IP32,v 1.31 2019/09/04 14:29:42 cheloha Exp $ -# -# THIS KERNEL IS FOR O2 (IP32) SYSTEMS ONLY. - -machine sgi mips64 -maxusers 4 - -option SMALL_KERNEL -option NO_PROPOLICE -option BOOT_CONFIG - -option MINIROOTSIZE=10240 -option RAMDISK_HOOKS - -makeoption LINK_ADDRESS="0xffffffff80100000" -option KERNBASE="0xffffffff80000000" - -option PCIVERBOSE -option USBVERBOSE - -option CD9660 -option FFS -option FFS2 -option NFSCLIENT -option INET6 - -option TGT_O2 # O2, O2+ -option ARCBIOS -option CPU_R5000 # R5000/RM5200 support -option CPU_RM7000 # RM7000 support -option CPU_R10000 # R10000/R12000/R14000/R16000 support - -config bsd root on rd0a swap on rd0b - -mainbus0 at root -cpu* at mainbus0 -clock0 at mainbus0 -macebus0 at mainbus0 # MACE controller localbus. -gbe0 at mainbus0 # GBE Framebuffer -mec0 at macebus0 -mkbc0 at macebus0 -com0 at macebus0 base 0x00390000 -com1 at macebus0 base 0x00398000 -dsrtc0 at macebus0 -macepcibr0 at macebus0 # MACE controller PCI Bus bridge. -pci* at macepcibr? # PCI is on pci bridge - -ahc* at pci? -qlw* at pci? -qla* at pci? -qle* at pci? -mpi* at pci? -siop* at pci? - -ohci* at pci? -uhci* at pci? -ehci* at pci? -usb* at ohci? -usb* at uhci? -usb* at ehci? - -uhub* at usb? -uhub* at uhub? -umodem* at uhub? # USB Modems/Serial -ucom* at umodem? -uvscom* at uhub? # SUNTAC Slipper U VS-10U serial -ucom* at uvscom? -ubsa* at uhub? # Belkin serial adapter -ucom* at ubsa? -umass* at uhub? -uhidev* at uhub? # Human Interface Devices -ukbd* at uhidev? # USB keyboard -wskbd* at ukbd? mux 1 -uhid* at uhidev? # USB generic HID support -atu* at uhub? # Atmel AT76c50x based 802.11b -aue* at uhub? # ADMtek AN986 Pegasus Ethernet -axe* at uhub? # ASIX Electronics AX88172 USB Ethernet -axen* at uhub? # ASIX Electronics AX88179 USB Ethernet -cdce* at uhub? # CDC Ethernet -cue* at uhub? # CATC USB-EL1201A based Ethernet -kue* at uhub? # Kawasaki KL5KUSB101B based Ethernet -mos* at uhub? # MOSCHIP MCS7730/7830 10/100 Ethernet -otus* at uhub? # Atheros AR9001U -rum* at uhub? # Ralink RT2501USB/RT2601USB -run* at uhub? # Ralink RT2700U/RT2800U/RT3000U -smsc* at uhub? # SMSC LAN95xx Ethernet -uath* at uhub? # Atheros AR5005UG/AR5005UX -udav* at uhub? # Davicom DM9601 based Ethernet -upgt* at uhub? # Conexant/Intersil PrismGT SoftMAC USB -upl* at uhub? # Prolific PL2301/PL2302 host-to-host -ugl* at uhub? # Genesys Logic GL620USB-A host-to-host -ural* at uhub? # Ralink RT2500USB -url* at uhub? # Realtek RTL8150L based adapters -ure* at uhub? # Realtek RTL8152 based adapters -urtw* at uhub? # Realtek 8187 -wi* at uhub? # WaveLAN IEEE 802.11DS -zyd* at uhub? # Zydas ZD1211 -ugen* at uhub? # USB Generic driver - -ppb* at pci? -pci* at ppb? - -pcn* at pci? # AMD PCnet-PCI Ethernet -epic* at pci? # SMC EPIC/100 ethernet -de* at pci? # DC21X4X-based ethernet -dc* at pci? # 21143, "tulip" clone ethernet -sf* at pci? # Adaptec AIC-6915 ethernet -em* at pci? # Intel Pro/1000 ethernet -ep* at pci? # 3Com 3c59x -fxp* at pci? # EtherExpress 10/100B ethernet -mtd* at pci? # Myson MTD803 3-in-1 Ethernet -ne* at pci? # NE2000-compatible Ethernet -ti* at pci? # Alteon ACEnic gigabit Ethernet -stge* at pci? # Sundance TC9021 GigE -vr* at pci? # VIA Rhine Fast Ethernet -xl* at pci? # 3C9xx ethernet -re* at pci? # Realtek 8169/8169S/8110S -rl* at pci? # Realtek 81[23]9 ethernet -hme* at pci? # Sun Happy Meal -gem* at pci? # Sun 'gem' ethernet -cas* at pci? # Sun Cassini 100/Gigabit -skc* at pci? # SysKonnect GEnesis 984x -sk* at skc? # each port of above -mskc* at pci? # Marvell Yukon-2 -msk* at mskc? # each port of above -bge* at pci? # Broadcom BCM570x (aka Tigon3) -vge* at pci? # VIA VT612x -bnx* at pci? # Broadcom BCM5706/5708 GigE -sis* at pci? # SiS 900/7016 ethernet - -exphy* at mii? # 3Com internal PHYs -inphy* at mii? # Intel 82555 PHYs -iophy* at mii? # Intel 82553 PHYs -icsphy* at mii? # ICS 1890 PHYs -lxtphy* at mii? # Level1 LXT970 PHYs -nsphy* at mii? # NS and compatible PHYs -nsphyter* at mii? # NS and compatible PHYs -qsphy* at mii? # Quality Semi QS6612 PHYs -sqphy* at mii? # Seeq 8x220 PHYs -luphy* at mii? # Lucent LU6612 PHY -rlphy* at mii? # Realtek 8139 internal PHYs -mtdphy* at mii? # Myson MTD972 PHYs -dcphy* at mii? # Digital Clone PHYs -acphy* at mii? # Altima AC101 PHYs -amphy* at mii? # AMD 79C873 PHYs -tqphy* at mii? # TDK 78Q212x PHYs -bmtphy* at mii? # Broadcom 10/100 PHYs -brgphy* at mii? # Broadcom Gigabit PHYs -ciphy* at mii? # Cicada CS8201 10/100/1000 copper PHY -eephy* at mii? # Marvell 88E1000 series PHY -xmphy* at mii? # XaQti XMAC-II PHYs -nsgphy* at mii? # NS gigabit PHYs -urlphy* at mii? # Realtek RTL8150L internal PHY -rgephy* at mii? # Realtek 8169S/8110S PHY -ipgphy* at mii? # IC Plus IP1000A PHYs -gentbi* at mii? # Generic 1000BASE-X ten-bit PHY -ukphy* at mii? # "unknown" PHYs - -wsdisplay* at gbe? -pckbd* at mkbc? -wskbd* at pckbd? console ? - -scsibus* at scsi? -sd* at scsibus? -st* at scsibus? -cd* at scsibus? - -pseudo-device loop 1 -pseudo-device bpfilter 1 -pseudo-device rd 1 -pseudo-device bio 1 diff --git a/sys/arch/sgi/conf/files.sgi b/sys/arch/sgi/conf/files.sgi deleted file mode 100644 index d07bd820d87..00000000000 --- a/sys/arch/sgi/conf/files.sgi +++ /dev/null @@ -1,246 +0,0 @@ -# $OpenBSD: files.sgi,v 1.56 2017/06/08 11:47:24 visa Exp $ -# -# maxpartitions must be first item in files.${ARCH} -# -maxpartitions 16 - -maxusers 2 8 64 - -# Required files - -file dev/cninit.c -file arch/sgi/sgi/autoconf.c -file arch/sgi/sgi/bus_dma.c -file arch/sgi/sgi/conf.c -file arch/sgi/sgi/disksubr.c disk -file arch/sgi/sgi/ip22_machdep.c tgt_indigo | tgt_indigo2 | - tgt_indy -file arch/sgi/sgi/ip27_machdep.c tgt_origin -file arch/sgi/sgi/ip30_machdep.c tgt_octane -file arch/sgi/sgi/ip30_nmi.S tgt_octane & ddb -file arch/sgi/sgi/ip32_machdep.c tgt_o2 -file arch/sgi/sgi/l1.c tgt_origin -file arch/sgi/sgi/locore.S -file arch/sgi/sgi/machdep.c -file arch/sgi/sgi/mainbus.c -file arch/sgi/sgi/sginode.c tgt_origin -file arch/sgi/sgi/wscons_machdep.c wsdisplay - -# RAM disk for boot -major {rd = 8} - -# -# Media Indepedent Interface (mii) -# -include "dev/mii/files.mii" - -# -# Machine-independent ATAPI drivers -# - -include "dev/atapiscsi/files.atapiscsi" -include "dev/ata/files.ata" - -include "dev/pckbc/files.pckbc" - -# -# System BUS types -# -define mainbus {[nasid = -1]} -device mainbus -attach mainbus at root - -# Our CPU configurator -device cpu -attach cpu at mainbus - -# Clock device -device clock -attach clock at mainbus - -# Impact/ImpactSR common code -device impact: wsemuldisplaydev, rasops32 -file arch/sgi/dev/impact.c impact | - impact_gio | - impact_xbow needs-flag - -# -# IP20/22/24/26/28 specific devices -# -define giobus {} -device imc: giobus, eisabus -attach imc at mainbus -file arch/sgi/localbus/imc.c imc - -device int -attach int at mainbus -file arch/sgi/localbus/int.c int - -device tcc -attach tcc at mainbus -file arch/sgi/localbus/tcc.c tcc needs-flag - -include "arch/sgi/gio/files.gio" -include "arch/sgi/hpc/files.hpc" - -# -# O2 MACE localbus autoconfiguration devices -# -define macebus {[base = -1]} -device macebus -attach macebus at mainbus -file arch/sgi/localbus/macebus.c macebus - -# -# Origin200/Origin2000 node configuration enumerator, and -# Octane XBOW mux bridge -# -include "arch/sgi/xbow/files.xbow" - -include "dev/onewire/files.onewire" - -# -# PCI Bus bridges -# - -device macepcibr {} : pcibus -attach macepcibr at macebus -file arch/sgi/pci/macepcibridge.c macepcibr - -# Use machine independent SCSI driver routines -include "scsi/files.scsi" -major {sd = 0} -major {cd = 3} - -# -# EISA Bus support -# - -include "dev/eisa/files.eisa" -file arch/sgi/sgi/eisa_machdep.c eisa - -# -# PCI Bus support -# - -include "dev/pci/files.pci" -file arch/sgi/pci/pci_machdep.c pci - -# Sun HME Ethernet controllers -device hme: ether, ifnet, mii, ifmedia -file dev/ic/hme.c hme -attach hme at pci with hme_pci -file dev/pci/if_hme_pci.c hme_pci - -# IOC3 -define ioc {[base = -1]} -device ioc: onewirebus -attach ioc at pci -file arch/sgi/pci/ioc.c ioc - -# IOC4 -define iof {[base = -1]} -device iof -attach iof at pci -file arch/sgi/pci/iof.c iof - -# IOC3/4 serial ports -attach com at ioc with com_ioc -file arch/sgi/dev/com_ioc.c com_ioc -attach com at iof with com_iof -file arch/sgi/dev/com_iof.c com_iof - -# IOC3 onboard Ethernet -device iec: ether, ifnet, ifmedia, mii -attach iec at ioc -file arch/sgi/dev/if_iec.c iec - -# IOC3/4 PS/2 controller -device iockbc: pckbcslot -attach iockbc at ioc with iockbc_ioc -attach iockbc at iof with iockbc_iof -file arch/sgi/dev/iockbc.c iockbc | - iockbc_ioc | iockbc_iof - needs-flag - -# DS1687 Time-Of-Day calendar device -device dsrtc -attach dsrtc at ioc with dsrtc_ioc -attach dsrtc at iof with dsrtc_iof -attach dsrtc at macebus with dsrtc_macebus -file arch/sgi/dev/dsrtc.c dsrtc - -# GBE framebuffer -device gbe: wsemuldisplaydev, rasops8, rasops16, rasops32 -attach gbe at mainbus -file arch/sgi/dev/gbe.c gbe needs-flag - -# 16[45]50-based "com" ports on localbus -attach com at macebus with com_macebus -file arch/sgi/localbus/com_lbus.c com_macebus - -# MACE MAC-110 ethernet -device mec: ether, ifnet, ifmedia, mii -attach mec at macebus -file arch/sgi/dev/if_mec.c mec - -# Moosehead A/V Board audio -device mavb: audio -attach mavb at macebus -file arch/sgi/dev/mavb.c mavb - -# MACE PS/2 Controller -device mkbc: pckbcslot -attach mkbc at macebus -file arch/sgi/dev/mkbc.c mkbc needs-flag - -# Power button -device power -attach power at macebus with power_macebus -attach power at mainbus with power_mainbus -file arch/sgi/dev/power.c power | - power_macebus | power_mainbus - needs-flag - -# Raster operations -include "dev/rasops/files.rasops" -include "dev/wsfont/files.wsfont" - -# -# wscons console -# -include "dev/wscons/files.wscons" - -# -# CardBus and PCMCIA bus support -# -include "dev/cardbus/files.cardbus" -include "dev/pcmcia/files.pcmcia" - -# -# Machine-independent HID support -# -include "dev/hid/files.hid" - -# -# Machine-independent USB drivers -# -include "dev/usb/files.usb" - -# -# Number-In-a-Can containers -# -# Ethernet address -device owmac -attach owmac at onewire -file arch/sgi/dev/owmac.c owmac - -# Serial numbers -device owserial -attach owserial at onewire -file arch/sgi/dev/owserial.c owserial -file arch/sgi/dev/owmem_subr.c owmac | owserial - -# IP35 SPD memory information -attach spdmem at mainbus with spdmem_mainbus -file arch/sgi/dev/spdmem_mainbus.c spdmem_mainbus diff --git a/sys/arch/sgi/conf/ld.script b/sys/arch/sgi/conf/ld.script deleted file mode 100644 index 85a74ec1049..00000000000 --- a/sys/arch/sgi/conf/ld.script +++ /dev/null @@ -1,61 +0,0 @@ -/* $OpenBSD: ld.script,v 1.10 2021/02/18 16:27:08 visa Exp $ */ - -OUTPUT_FORMAT("elf64-tradbigmips") -OUTPUT_ARCH(mips) -ENTRY(__start) - -PHDRS -{ - text PT_LOAD; - openbsd_randomize PT_OPENBSD_RANDOMIZE; -} - -SECTIONS -{ - .text : - { - *(.text .text.* .gnu.linkonce.t.*) - } :text - PROVIDE (etext = .); - .rodata : - { - *(.rodata .rodata.* .gnu.linkonce.r.*) - } :text - - . = ALIGN(8); - PROVIDE (__kernel_randomdata = .); - .openbsd.randomdata : - { - __retguard_start = ABSOLUTE(.); - *(.openbsd.randomdata.retguard .openbsd.randomdata.retguard.*) - /* XXX . = ALIGN(0x1000); */ - __retguard_end = ABSOLUTE(.); - *(.openbsd.randomdata .openbsd.randomdata.*) - } :text :openbsd_randomize - . = ALIGN(8); - PROVIDE (__kernel_randomdata_end = .); - - .data : - { - *(.data .data.* .gnu.linkonce.d.*) - } :text - PROVIDE (edata = .); - .sbss : - { - *(.sbss .sbss.* .gnu.linkonce.sb.* .scommon) - } - .bss : - { - *(.bss .bss.* .gnu.linkonce.b.* COMMON) - } - . = ALIGN(8); - PROVIDE (_end = .); - PROVIDE (end = .); - - /DISCARD/ : - { - *(.pdr) - *(.mdebug.abi64) - *(.MIPS.options) - } -} diff --git a/sys/arch/sgi/dev/com_ioc.c b/sys/arch/sgi/dev/com_ioc.c deleted file mode 100644 index cb8adcc79e9..00000000000 --- a/sys/arch/sgi/dev/com_ioc.c +++ /dev/null @@ -1,131 +0,0 @@ -/* $OpenBSD: com_ioc.c,v 1.9 2012/10/03 22:46:09 miod Exp $ */ - -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/tty.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/intr.h> - -#include <dev/ic/comreg.h> -#include <dev/ic/comvar.h> -#include <dev/ic/ns16550reg.h> - -#include <sgi/pci/iocvar.h> - -int com_ioc_probe(struct device *, void *, void *); -void com_ioc_attach(struct device *, struct device *, void *); - -struct cfattach com_ioc_ca = { - sizeof(struct com_softc), com_ioc_probe, com_ioc_attach -}; - -extern struct cfdriver com_cd; - -int -com_ioc_probe(struct device *parent, void *match, void *aux) -{ - struct cfdata *cf = match; - struct ioc_attach_args *iaa = aux; - bus_space_tag_t iot = iaa->iaa_memt; - bus_space_handle_t ioh; - int rv = 0, console = 0; - - if (strcmp(iaa->iaa_name, com_cd.cd_name) != 0) - return 0; - - if (comconsiot != NULL) - console = iaa->iaa_memh + iaa->iaa_base == - comconsiot->bus_base + comconsaddr; - - /* if it's in use as console, it's there. */ - if (!(console && !comconsattached)) { - if (bus_space_subregion(iot, iaa->iaa_memh, - iaa->iaa_base, COM_NPORTS, &ioh) == 0) - rv = comprobe1(iot, ioh); - } else - rv = 1; - - /* make a config stanza with exact locators match over a generic line */ - if (cf->cf_loc[0] != -1) - rv += rv; - - return rv; -} - -void -com_ioc_attach(struct device *parent, struct device *self, void *aux) -{ - struct com_softc *sc = (void *)self; - struct ioc_attach_args *iaa = aux; - bus_space_handle_t ioh; - int console = 0; - - if (comconsiot != NULL) - console = iaa->iaa_memh + iaa->iaa_base == - comconsiot->bus_base + comconsaddr; - - sc->sc_hwflags = 0; - sc->sc_swflags = 0; - sc->sc_frequency = 22000000 / 3; - - /* if it's in use as console, it's there. */ - if (!(console && !comconsattached)) { - sc->sc_iot = iaa->iaa_memt; - sc->sc_iobase = iaa->iaa_base; - - if (bus_space_subregion(iaa->iaa_memt, iaa->iaa_memh, - iaa->iaa_base, COM_NPORTS, &ioh) != 0) { - printf(": can't map registers\n"); - return; - } - } else { - /* - * If we are the console, reuse the existing bus_space - * information, so that comcnattach() invokes bus_space_map() - * with correct parameters. - */ - sc->sc_iot = comconsiot; - sc->sc_iobase = comconsaddr; - - if (comcnattach(sc->sc_iot, sc->sc_iobase, comconsrate, - sc->sc_frequency, (TTYDEF_CFLAG & ~(CSIZE | PARENB)) | CS8)) - panic("can't setup serial console"); - ioh = comconsioh; - } - - sc->sc_ioh = ioh; - - com_attach_subr(sc); - - ioc_intr_establish(parent, iaa->iaa_dev, IPL_TTY, comintr, - (void *)sc, sc->sc_dev.dv_xname); -} diff --git a/sys/arch/sgi/dev/com_iof.c b/sys/arch/sgi/dev/com_iof.c deleted file mode 100644 index 0bbe36fae3d..00000000000 --- a/sys/arch/sgi/dev/com_iof.c +++ /dev/null @@ -1,128 +0,0 @@ -/* $OpenBSD: com_iof.c,v 1.5 2009/10/16 00:15:46 miod Exp $ */ - -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/tty.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <dev/ic/comreg.h> -#include <dev/ic/comvar.h> -#include <dev/ic/ns16550reg.h> - -#include <sgi/pci/iofvar.h> - -int com_iof_probe(struct device *, void *, void *); -void com_iof_attach(struct device *, struct device *, void *); - -struct cfattach com_iof_ca = { - sizeof(struct com_softc), com_iof_probe, com_iof_attach -}; - -extern struct cfdriver com_cd; - -int -com_iof_probe(struct device *parent, void *match, void *aux) -{ - struct cfdata *cf = match; - struct iof_attach_args *iaa = aux; - bus_space_tag_t iot = iaa->iaa_memt; - bus_space_handle_t ioh; - int rv = 0, console; - - if (strcmp(iaa->iaa_name, com_cd.cd_name) != 0) - return 0; - - console = iaa->iaa_memh + iaa->iaa_base == - comconsiot->bus_base + comconsaddr; - - /* if it's in use as console, it's there. */ - if (!(console && !comconsattached)) { - if (bus_space_subregion(iot, iaa->iaa_memh, - iaa->iaa_base, COM_NPORTS, &ioh) == 0) - rv = comprobe1(iot, ioh); - } else - rv = 1; - - /* make a config stanza with exact locators match over a generic line */ - if (cf->cf_loc[0] != -1) - rv += rv; - - return rv; -} - -void -com_iof_attach(struct device *parent, struct device *self, void *aux) -{ - struct com_softc *sc = (void *)self; - struct iof_attach_args *iaa = aux; - bus_space_handle_t ioh; - int console; - - console = iaa->iaa_memh + iaa->iaa_base == - comconsiot->bus_base + comconsaddr; - - sc->sc_hwflags = 0; - sc->sc_swflags = 0; - sc->sc_frequency = iaa->iaa_clock; - - /* if it's in use as console, it's there. */ - if (!(console && !comconsattached)) { - sc->sc_iot = iaa->iaa_memt; - sc->sc_iobase = iaa->iaa_base; - - if (bus_space_subregion(iaa->iaa_memt, iaa->iaa_memh, - iaa->iaa_base, COM_NPORTS, &ioh) != 0) { - printf(": can't map registers\n"); - return; - } - } else { - /* - * If we are the console, reuse the existing bus_space - * information, so that comcnattach() invokes bus_space_map() - * with correct parameters. - */ - sc->sc_iot = comconsiot; - sc->sc_iobase = comconsaddr; - - if (comcnattach(sc->sc_iot, sc->sc_iobase, comconsrate, - sc->sc_frequency, (TTYDEF_CFLAG & ~(CSIZE | PARENB)) | CS8)) - panic("can't setup serial console"); - ioh = comconsioh; - } - - sc->sc_ioh = ioh; - - com_attach_subr(sc); - - iof_intr_establish(parent, iaa->iaa_dev, IPL_TTY, comintr, - (void *)sc, sc->sc_dev.dv_xname); -} diff --git a/sys/arch/sgi/dev/dsrtc.c b/sys/arch/sgi/dev/dsrtc.c deleted file mode 100644 index 722c647e599..00000000000 --- a/sys/arch/sgi/dev/dsrtc.c +++ /dev/null @@ -1,461 +0,0 @@ -/* $OpenBSD: dsrtc.c,v 1.14 2020/05/21 01:48:43 visa Exp $ */ - -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#include <sys/param.h> -#include <sys/kernel.h> -#include <sys/systm.h> -#include <sys/device.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <dev/clock_subr.h> -#include <dev/ic/ds1687reg.h> -#include <dev/ic/mk48txxreg.h> - -#include <mips64/archtype.h> - -#include <sgi/dev/dsrtcvar.h> -#include <sgi/localbus/macebusvar.h> -#include <sgi/pci/iocreg.h> -#include <sgi/pci/iocvar.h> -#include <sgi/pci/iofvar.h> - -struct dsrtc_softc { - struct device sc_dev; - struct todr_chip_handle sc_todr; - bus_space_tag_t sc_clkt; - bus_space_handle_t sc_clkh, sc_clkh2; - int sc_yrbase; - - int (*read)(struct dsrtc_softc *, int); - void (*write)(struct dsrtc_softc *, int, int); -}; - -int dsrtc_match(struct device *, void *, void *); -void dsrtc_attach_ioc(struct device *, struct device *, void *); -void dsrtc_attach_iof(struct device *, struct device *, void *); -void dsrtc_attach_macebus(struct device *, struct device *, void *); - -struct cfdriver dsrtc_cd = { - NULL, "dsrtc", DV_DULL -}; - -struct cfattach dsrtc_macebus_ca = { - sizeof(struct dsrtc_softc), dsrtc_match, dsrtc_attach_macebus -}; - -struct cfattach dsrtc_ioc_ca = { - sizeof(struct dsrtc_softc), dsrtc_match, dsrtc_attach_ioc -}; - -struct cfattach dsrtc_iof_ca = { - sizeof(struct dsrtc_softc), dsrtc_match, dsrtc_attach_ioc -}; - -int ip32_dsrtc_read(struct dsrtc_softc *, int); -void ip32_dsrtc_write(struct dsrtc_softc *, int, int); -int ioc_ds1687_dsrtc_read(struct dsrtc_softc *, int); -void ioc_ds1687_dsrtc_write(struct dsrtc_softc *, int, int); - -int ds1687_gettime(struct todr_chip_handle *, struct timeval *); -int ds1687_settime(struct todr_chip_handle *, struct timeval *); -int ds1742_gettime(struct todr_chip_handle *, struct timeval *); -int ds1742_settime(struct todr_chip_handle *, struct timeval *); - -static inline int frombcd(int, int); -static inline int tobcd(int, int); -static inline int -frombcd(int x, int binary) -{ - return binary ? x : (x >> 4) * 10 + (x & 0xf); -} -static inline int -tobcd(int x, int binary) -{ - return binary ? x : (x / 10 * 16) + (x % 10); -} - -int -dsrtc_match(struct device *parent, void *match, void *aux) -{ - /* - * Depending on what dsrtc attaches to, the actual attach_args - * may be a different struct, but all of them start with the - * same name field. - */ - struct mainbus_attach_args *maa = aux; - - return strcmp(maa->maa_name, dsrtc_cd.cd_name) == 0; -} - -void -dsrtc_attach_ioc(struct device *parent, struct device *self, void *aux) -{ - struct dsrtc_softc *sc = (void *)self; - struct ioc_attach_args *iaa = aux; - bus_space_handle_t ih, ih2; - - /* - * The IOC3 RTC is either a Dallas (now Maxim) DS1397 or compatible - * (likely a more recent DS1687), or a DS1747 or compatible - * (itself being a Mostek MK48T35 clone). - * - * Surprisingly, the chip found on Fuel has a DS1742W label, - * which has much less memory than the DS1747. I guess whatever - * the chip is, it is mapped to the end of the DS1747 address - * space, so that the clock registers always appear at the same - * addresses in memory. - */ - - sc->sc_clkt = iaa->iaa_memt; - - if (iaa->iaa_base != IOC3_BYTEBUS_0) { - /* DS1687 */ - - if (bus_space_subregion(iaa->iaa_memt, iaa->iaa_memh, - IOC3_BYTEBUS_1, 1, &ih) != 0 || - bus_space_subregion(iaa->iaa_memt, iaa->iaa_memh, - IOC3_BYTEBUS_2, 1, &ih2) != 0) - goto fail; - - printf(": DS1687\n"); - - sc->sc_clkh = ih; - sc->sc_clkh2 = ih2; - - sc->read = ioc_ds1687_dsrtc_read; - sc->write = ioc_ds1687_dsrtc_write; - - sc->sc_todr.todr_gettime = ds1687_gettime; - sc->sc_todr.todr_settime = ds1687_settime; - } else { - /* DS1742W */ - - if (bus_space_subregion(iaa->iaa_memt, iaa->iaa_memh, - iaa->iaa_base + MK48T35_CLKOFF, - MK48T35_CLKSZ - MK48T35_CLKOFF, &ih) != 0) - goto fail; - - printf(": DS1742W\n"); - - sc->sc_clkh = ih; - - /* - * For some reason, the base year differs between IP27 - * and IP35. - */ - sc->sc_yrbase = sys_config.system_type == SGI_IP35 ? - POSIX_BASE_YEAR - 2 : POSIX_BASE_YEAR; - - sc->sc_todr.todr_gettime = ds1742_gettime; - sc->sc_todr.todr_settime = ds1742_settime; - } - sc->sc_todr.cookie = self; - todr_attach(&sc->sc_todr); - - return; - -fail: - printf(": can't map registers\n"); -} - -void -dsrtc_attach_iof(struct device *parent, struct device *self, void *aux) -{ - struct dsrtc_softc *sc = (void *)self; - struct iof_attach_args *iaa = aux; - bus_space_handle_t ih; - - /* - * The IOC4 RTC is a DS1747 or compatible (itself being a Mostek - * MK48T35 clone). - */ - - if (bus_space_subregion(iaa->iaa_memt, iaa->iaa_memh, - iaa->iaa_base + MK48T35_CLKOFF, - MK48T35_CLKSZ - MK48T35_CLKOFF, &ih) != 0) - goto fail; - - printf(": DS1742W\n"); - - sc->sc_clkh = ih; - - /* - * For some reason, the base year differs between IP27 - * and IP35. - */ - sc->sc_yrbase = sys_config.system_type == SGI_IP35 ? - POSIX_BASE_YEAR - 2 : POSIX_BASE_YEAR; - - sc->sc_todr.cookie = self; - sc->sc_todr.todr_gettime = ds1742_gettime; - sc->sc_todr.todr_settime = ds1742_settime; - todr_attach(&sc->sc_todr); - - return; - -fail: - printf(": can't map registers\n"); -} - -void -dsrtc_attach_macebus(struct device *parent, struct device *self, void *aux) -{ - struct dsrtc_softc *sc = (void *)self; - struct macebus_attach_args *maa = aux; - - sc->sc_clkt = maa->maa_iot; - if (bus_space_map(sc->sc_clkt, maa->maa_baseaddr, 128 * 256, 0, - &sc->sc_clkh)) { - printf(": can't map registers\n"); - return; - } - - printf(": DS1687\n"); - - sc->read = ip32_dsrtc_read; - sc->write = ip32_dsrtc_write; - - sc->sc_todr.cookie = self; - sc->sc_todr.todr_gettime = ds1687_gettime; - sc->sc_todr.todr_settime = ds1687_settime; - todr_attach(&sc->sc_todr); -} - -int -ip32_dsrtc_read(struct dsrtc_softc *sc, int reg) -{ - return bus_space_read_1(sc->sc_clkt, sc->sc_clkh, reg); -} - -void -ip32_dsrtc_write(struct dsrtc_softc *sc, int reg, int val) -{ - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, reg, val); -} - -int -ioc_ds1687_dsrtc_read(struct dsrtc_softc *sc, int reg) -{ - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, 0, reg); - return bus_space_read_1(sc->sc_clkt, sc->sc_clkh2, 0); -} - -void -ioc_ds1687_dsrtc_write(struct dsrtc_softc *sc, int reg, int val) -{ - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, 0, reg); - bus_space_write_1(sc->sc_clkt, sc->sc_clkh2, 0, val); -} - -/* - * Dallas DS1687 clock driver. - */ - -int -ds1687_gettime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dsrtc_softc *sc = handle->cookie; - int ctrl, dm; - - /* Select bank 1. */ - ctrl = (*sc->read)(sc, DS1687_CTRL_A); - (*sc->write)(sc, DS1687_CTRL_A, ctrl | DS1687_BANK_1); - - /* Figure out which data mode to use. */ - dm = (*sc->read)(sc, DS1687_CTRL_B) & DS1687_DM_1; - - /* Wait for no update in progress. */ - while ((*sc->read)(sc, DS1687_CTRL_A) & DS1687_UIP) - /* Do nothing. */; - - /* Read the RTC. */ - dt.dt_sec = frombcd((*sc->read)(sc, DS1687_SEC), dm); - dt.dt_min = frombcd((*sc->read)(sc, DS1687_MIN), dm); - dt.dt_hour = frombcd((*sc->read)(sc, DS1687_HOUR), dm); - dt.dt_day = frombcd((*sc->read)(sc, DS1687_DAY), dm); - dt.dt_mon = frombcd((*sc->read)(sc, DS1687_MONTH), dm); - dt.dt_year = frombcd((*sc->read)(sc, DS1687_YEAR), dm); - dt.dt_year += frombcd((*sc->read)(sc, DS1687_CENTURY), dm) * 100; - - tv->tv_sec = clock_ymdhms_to_secs(&dt); - tv->tv_usec = 0; - return 0; -} - -int -ds1687_settime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dsrtc_softc *sc = handle->cookie; - int year, century, ctrl, dm; - - clock_secs_to_ymdhms(tv->tv_sec, &dt); - - century = dt.dt_year / 100; - year = dt.dt_year % 100; - - /* Select bank 1. */ - ctrl = (*sc->read)(sc, DS1687_CTRL_A); - (*sc->write)(sc, DS1687_CTRL_A, ctrl | DS1687_BANK_1); - - /* Figure out which data mode to use, and select 24 hour time. */ - ctrl = (*sc->read)(sc, DS1687_CTRL_B); - dm = ctrl & DS1687_DM_1; - (*sc->write)(sc, DS1687_CTRL_B, ctrl | DS1687_24_HR); - - /* Prevent updates. */ - ctrl = (*sc->read)(sc, DS1687_CTRL_B); - (*sc->write)(sc, DS1687_CTRL_B, ctrl | DS1687_SET_CLOCK); - - /* Update the RTC. */ - (*sc->write)(sc, DS1687_SEC, tobcd(dt.dt_sec, dm)); - (*sc->write)(sc, DS1687_MIN, tobcd(dt.dt_min, dm)); - (*sc->write)(sc, DS1687_HOUR, tobcd(dt.dt_hour, dm)); - (*sc->write)(sc, DS1687_DOW, tobcd(dt.dt_wday + 1, dm)); - (*sc->write)(sc, DS1687_DAY, tobcd(dt.dt_day, dm)); - (*sc->write)(sc, DS1687_MONTH, tobcd(dt.dt_mon, dm)); - (*sc->write)(sc, DS1687_YEAR, tobcd(year, dm)); - (*sc->write)(sc, DS1687_CENTURY, tobcd(century, dm)); - - /* Enable updates. */ - (*sc->write)(sc, DS1687_CTRL_B, ctrl); - - return 0; -} - -/* - * Dallas DS1742 clock driver. - */ - -int -ds1742_gettime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dsrtc_softc *sc = handle->cookie; - int csr; - - /* Freeze update. */ - csr = bus_space_read_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR); - csr |= MK48TXX_CSR_READ; - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR, csr); - - /* Read the RTC. */ - dt.dt_sec = frombcd(bus_space_read_1(sc->sc_clkt, sc->sc_clkh, - MK48TXX_ISEC), 0); - dt.dt_min = frombcd(bus_space_read_1(sc->sc_clkt, sc->sc_clkh, - MK48TXX_IMIN), 0); - dt.dt_hour = frombcd(bus_space_read_1(sc->sc_clkt, sc->sc_clkh, - MK48TXX_IHOUR), 0); - dt.dt_day = frombcd(bus_space_read_1(sc->sc_clkt, sc->sc_clkh, - MK48TXX_IDAY), 0); - dt.dt_mon = frombcd(bus_space_read_1(sc->sc_clkt, sc->sc_clkh, - MK48TXX_IMON), 0); - dt.dt_year = frombcd(bus_space_read_1(sc->sc_clkt, sc->sc_clkh, - MK48TXX_IYEAR), 0) + sc->sc_yrbase; - - /* Enable updates again. */ - csr = bus_space_read_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR); - csr &= ~MK48TXX_CSR_READ; - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR, csr); - - tv->tv_sec = clock_ymdhms_to_secs(&dt); - tv->tv_usec = 0; - return 0; -} - -int -ds1742_settime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dsrtc_softc *sc = handle->cookie; - int csr; - - clock_secs_to_ymdhms(tv->tv_sec, &dt); - - /* Enable write. */ - csr = bus_space_read_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR); - csr |= MK48TXX_CSR_WRITE; - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR, csr); - - /* Update the RTC. */ - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ISEC, - tobcd(dt.dt_sec, 0)); - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_IMIN, - tobcd(dt.dt_min, 0)); - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_IHOUR, - tobcd(dt.dt_hour, 0)); - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_IWDAY, - tobcd(dt.dt_wday + 1, 0)); - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_IDAY, - tobcd(dt.dt_day, 0)); - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_IMON, - tobcd(dt.dt_mon, 0)); - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_IYEAR, - tobcd(dt.dt_year - sc->sc_yrbase, 0)); - - /* Load new values. */ - csr = bus_space_read_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR); - csr &= ~MK48TXX_CSR_WRITE; - bus_space_write_1(sc->sc_clkt, sc->sc_clkh, MK48TXX_ICSR, csr); - - return 0; -} - -/* - * Routines allowing external access to the RTC registers, used by - * power(4). - */ - -int -dsrtc_register_read(int reg) -{ - struct dsrtc_softc *sc; - - if (dsrtc_cd.cd_ndevs == 0 || - (sc = (struct dsrtc_softc *)dsrtc_cd.cd_devs[0]) == NULL || - sc->read == NULL) - return -1; - - return (*sc->read)(sc, reg); -} - -void -dsrtc_register_write(int reg, int val) -{ - struct dsrtc_softc *sc; - - if (dsrtc_cd.cd_ndevs == 0 || - (sc = (struct dsrtc_softc *)dsrtc_cd.cd_devs[0]) == NULL || - sc->write == NULL) - return; - - (*sc->write)(sc, reg, val); -} diff --git a/sys/arch/sgi/dev/dsrtcvar.h b/sys/arch/sgi/dev/dsrtcvar.h deleted file mode 100644 index e4bfd6122d3..00000000000 --- a/sys/arch/sgi/dev/dsrtcvar.h +++ /dev/null @@ -1,25 +0,0 @@ -/* $OpenBSD: dsrtcvar.h,v 1.1 2009/05/15 23:03:32 miod Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Routines allowing external access to the RTC registers, used by - * power(4). - */ - -int dsrtc_register_read(int); -void dsrtc_register_write(int, int); diff --git a/sys/arch/sgi/dev/gbe.c b/sys/arch/sgi/dev/gbe.c deleted file mode 100644 index ba8ad0268e6..00000000000 --- a/sys/arch/sgi/dev/gbe.c +++ /dev/null @@ -1,1410 +0,0 @@ -/* $OpenBSD: gbe.c,v 1.23 2020/05/25 09:55:48 jsg Exp $ */ - -/* - * Copyright (c) 2007, 2008, 2009 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Graphics Back End (GBE) Framebuffer for SGI O2. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <uvm/uvm_extern.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <mips64/arcbios.h> - -#include <sgi/dev/gl.h> -#include <sgi/localbus/crimebus.h> -#include <sgi/localbus/macebusvar.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsdisplayvar.h> -#include <dev/rasops/rasops.h> - -#include "gbereg.h" - -/* Amount of memory to allocate for framebuffer. */ -#define GBE_FB_SIZE 8 * 1 << 20 - -/* - * Colourmap data. - */ -struct gbe_cmap { - u_int8_t cm_red[256]; - u_int8_t cm_green[256]; - u_int8_t cm_blue[256]; -}; - -/* - * Screen data. - */ -struct gbe_screen { - struct device *sc; /* Back pointer. */ - - struct rasops_info ri; /* Screen raster display info. */ - struct rasops_info ri_tile; /* Raster info for rasops tile. */ - struct gbe_cmap cmap; /* Display colour map. */ - - int fb_size; /* Size of framebuffer memory. */ - int tm_size; /* Size of tilemap memory. */ - - caddr_t tm; /* Address of tilemap memory. */ - paddr_t tm_phys; /* Physical address of tilemap. */ - caddr_t fb; /* Address of framebuffer memory. */ - paddr_t fb_phys; /* Physical address of framebuffer. */ - caddr_t ro; /* Address of rasops tile. */ - paddr_t ro_phys; /* Physical address of rasops tile. */ - - int width; /* Width in pixels. */ - int height; /* Height in pixels. */ - int depth; /* Colour depth in bits. */ - int mode; /* Display mode. */ - int bufmode; /* Rendering engine buffer mode. */ - int linebytes; /* Bytes per line. */ - int ro_curpos; /* Current position in rasops tile. */ -}; - -/* - * GBE device data. - */ -struct gbe_softc { - struct device sc_dev; - - bus_space_tag_t iot; - bus_space_handle_t ioh; /* GBE registers. */ - bus_space_handle_t re_ioh; /* Rendering engine registers. */ - bus_dma_tag_t dmat; - - int rev; /* Hardware revision. */ - int console; /* Is this the console? */ - int screens; /* No of screens allocated. */ - - struct gbe_screen *curscr; /* Current screen. */ -}; - -/* - * Hardware and device related functions. - */ -void gbe_init_screen(struct gbe_screen *); -void gbe_enable(struct gbe_softc *); -void gbe_disable(struct gbe_softc *); -void gbe_setup(struct gbe_softc *); -void gbe_setcolour(struct gbe_softc *, u_int, u_int8_t, u_int8_t, u_int8_t); -void gbe_wait_re_idle(struct gbe_softc *); - -/* - * Colour map handling for indexed modes. - */ -int gbe_getcmap(struct gbe_cmap *, struct wsdisplay_cmap *); -int gbe_putcmap(struct gbe_cmap *, struct wsdisplay_cmap *); -void gbe_loadcmap(struct gbe_screen *, u_int, u_int); - -/* - * Interfaces for wscons. - */ -int gbe_ioctl(void *, u_long, caddr_t, int, struct proc *); -paddr_t gbe_mmap(void *, off_t, int); -int gbe_alloc_screen(void *, const struct wsscreen_descr *, void **, - int *, int *, uint32_t *); -void gbe_free_screen(void *, void *); -int gbe_show_screen(void *, void *, int, void (*)(void *, int, int), - void *); -int gbe_load_font(void *, void *, struct wsdisplay_font *); -int gbe_list_font(void *, struct wsdisplay_font *); - -/* - * Hardware acceleration for rasops. - */ -void gbe_rop(struct gbe_softc *, int, int, int, int, int); -void gbe_copyrect(struct gbe_softc *, int, int, int, int, int, int, int); -void gbe_fillrect(struct gbe_softc *, int, int, int, int, int); -int gbe_do_cursor(struct rasops_info *); -int gbe_putchar(void *, int, int, u_int, uint32_t); -int gbe_copycols(void *, int, int, int, int); -int gbe_erasecols(void *, int, int, int, uint32_t); -int gbe_copyrows(void *, int, int, int); -int gbe_eraserows(void *, int, int, uint32_t); - -static struct gbe_screen gbe_consdata; -static int gbe_console; - -struct wsscreen_descr gbe_stdscreen = { - "std", /* Screen name. */ -}; - -struct wsdisplay_accessops gbe_accessops = { - .ioctl = gbe_ioctl, - .mmap = gbe_mmap, - .alloc_screen = gbe_alloc_screen, - .free_screen = gbe_free_screen, - .show_screen = gbe_show_screen, - .load_font = gbe_load_font, - .list_font = gbe_list_font -}; - -const struct wsscreen_descr *gbe_scrlist[] = { - &gbe_stdscreen -}; - -struct wsscreen_list gbe_screenlist = { - sizeof(gbe_scrlist) / sizeof(struct wsscreen_descr *), gbe_scrlist -}; - -int gbe_match(struct device *, void *, void *); -void gbe_attach(struct device *, struct device *, void *); -int gbe_activate(struct device *, int); - -struct cfattach gbe_ca = { - sizeof (struct gbe_softc), gbe_match, gbe_attach, - NULL, gbe_activate -}; - -struct cfdriver gbe_cd = { - NULL, "gbe", DV_DULL -}; - -int -gbe_match(struct device *parent, void *cf, void *aux) -{ - struct mainbus_attach_args *maa = aux; - - if (strcmp(maa->maa_name, gbe_cd.cd_name) != 0) - return 0; - - return 1; -} - -void -gbe_attach(struct device *parent, struct device *self, void *aux) -{ - struct gbe_softc *gsc = (void*)self; - struct gbe_screen *screen; - struct wsemuldisplaydev_attach_args waa; - bus_dma_segment_t tm_segs[1]; - bus_dma_segment_t fb_segs[1]; - bus_dma_segment_t ro_segs[1]; - bus_dmamap_t tm_dmamap; - bus_dmamap_t fb_dmamap; - bus_dmamap_t ro_dmamap; - int tm_nsegs; - int fb_nsegs; - int ro_nsegs; - uint32_t val; - uint32_t attr; - - printf(": "); - - /* GBE isn't strictly on the crimebus, but use this for now... */ - gsc->iot = &crimebus_tag; - gsc->dmat = &mace_bus_dma_tag; - gsc->console = gbe_console; - gsc->screens = 0; - - if (gsc->console == 1) { - - /* - * We've already been setup via gbe_cnattach(). - */ - - gsc->ioh = PHYS_TO_XKPHYS(GBE_BASE, CCA_NC); - gsc->re_ioh = PHYS_TO_XKPHYS(RE_BASE, CCA_NC); - - gsc->rev = bus_space_read_4(gsc->iot, gsc->ioh, GBE_CTRL_STAT) - & 0xf; - - gsc->curscr = &gbe_consdata; - gbe_consdata.sc = (void*)self; - - printf("rev %u, %iMB, %dx%d at %d bits\n", gsc->rev, - gbe_consdata.fb_size >> 20, gbe_consdata.width, - gbe_consdata.height, gbe_consdata.depth); - - waa.console = gsc->console; - waa.scrdata = &gbe_screenlist; - waa.accessops = &gbe_accessops; - waa.accesscookie = &gbe_consdata; - waa.defaultscreens = 0; - config_found(self, &waa, wsemuldisplaydevprint); - - return; - } - - /* - * Setup screen data. - */ - gsc->curscr = malloc(sizeof(struct gbe_screen), M_DEVBUF, M_NOWAIT); - if (gsc->curscr == NULL) { - printf("failed to allocate screen memory!\n"); - return; - } - gsc->curscr->sc = (void *)gsc; - screen = gsc->curscr; - - /* - * Setup bus space mappings. - */ - if (bus_space_map(gsc->iot, GBE_BASE - CRIMEBUS_BASE, GBE_REG_SIZE, - BUS_SPACE_MAP_LINEAR, &gsc->ioh)) { - printf("failed to map framebuffer bus space!\n"); - return; - } - - if (bus_space_map(gsc->iot, RE_BASE - CRIMEBUS_BASE, RE_REG_SIZE, - BUS_SPACE_MAP_LINEAR, &gsc->re_ioh)) { - printf("failed to map rendering engine bus space!\n"); - goto fail0; - } - - /* Determine GBE revision. */ - gsc->rev = bus_space_read_4(gsc->iot, gsc->ioh, GBE_CTRL_STAT) & 0xf; - - /* Determine resolution configured by firmware. */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_HCMAP); - screen->width = (val >> GBE_VT_HCMAP_ON_SHIFT) & 0xfff; - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_VCMAP); - screen->height = (val >> GBE_VT_VCMAP_ON_SHIFT) & 0xfff; - - if (screen->width == 0 || screen->height == 0) { - printf("device has not been setup by firmware!\n"); - goto fail1; - } - - /* Setup screen defaults. */ - screen->fb_size = GBE_FB_SIZE; - screen->tm_size = GBE_TLB_SIZE * sizeof(uint16_t); - screen->depth = 8; - screen->linebytes = screen->width * screen->depth / 8; - - /* - * Setup DMA for tilemap. - */ - if (bus_dmamap_create(gsc->dmat, screen->tm_size, 1, screen->tm_size, - 0, BUS_DMA_NOWAIT, &tm_dmamap)) { - printf("failed to create DMA map for tilemap!\n"); - goto fail1; - } - - if (bus_dmamem_alloc(gsc->dmat, screen->tm_size, 65536, 0, tm_segs, 1, - &tm_nsegs, BUS_DMA_NOWAIT)) { - printf("failed to allocate DMA memory for tilemap!\n"); - goto fail2; - } - - if (bus_dmamem_map(gsc->dmat, tm_segs, tm_nsegs, screen->tm_size, - &screen->tm, BUS_DMA_COHERENT)) { - printf("failed to map DMA memory for tilemap!\n"); - goto fail3; - } - - if (bus_dmamap_load(gsc->dmat, tm_dmamap, screen->tm, screen->tm_size, - NULL, BUS_DMA_NOWAIT)){ - printf("failed to load DMA map for tilemap\n"); - goto fail4; - } - - /* - * Setup DMA for framebuffer. - */ - if (bus_dmamap_create(gsc->dmat, screen->fb_size, 1, screen->fb_size, - 0, BUS_DMA_NOWAIT, &fb_dmamap)) { - printf("failed to create DMA map for framebuffer!\n"); - goto fail5; - } - - if (bus_dmamem_alloc(gsc->dmat, screen->fb_size, 65536, 0, fb_segs, - 1, &fb_nsegs, BUS_DMA_NOWAIT)) { - printf("failed to allocate DMA memory for framebuffer!\n"); - goto fail6; - } - - if (bus_dmamem_map(gsc->dmat, fb_segs, fb_nsegs, screen->fb_size, - &screen->fb, BUS_DMA_NOWAIT | BUS_DMA_COHERENT)) { - printf("failed to map DMA memory for framebuffer!\n"); - goto fail7; - } - - if (bus_dmamap_load(gsc->dmat, fb_dmamap, screen->fb, screen->fb_size, - NULL, BUS_DMA_NOWAIT)) { - printf("failed to load DMA map for framebuffer\n"); - goto fail8; - } - - /* - * Setup DMA for rasops tile. - */ - if (bus_dmamap_create(gsc->dmat, GBE_TILE_SIZE, 1, GBE_TILE_SIZE, - 0, BUS_DMA_NOWAIT, &ro_dmamap)) { - printf("failed to create DMA map for rasops tile!\n"); - goto fail9; - } - - if (bus_dmamem_alloc(gsc->dmat, GBE_TILE_SIZE, 65536, 0, ro_segs, - 1, &ro_nsegs, BUS_DMA_NOWAIT)) { - printf("failed to allocate DMA memory for rasops tile!\n"); - goto fail10; - } - - if (bus_dmamem_map(gsc->dmat, ro_segs, ro_nsegs, GBE_TILE_SIZE, - &screen->ro, BUS_DMA_NOWAIT | BUS_DMA_COHERENT)) { - printf("failed to map DMA memory for rasops tile!\n"); - goto fail11; - } - - if (bus_dmamap_load(gsc->dmat, ro_dmamap, screen->ro, GBE_TILE_SIZE, - NULL, BUS_DMA_NOWAIT)) { - printf("failed to load DMA map for rasops tile\n"); - goto fail12; - } - - screen->tm_phys = tm_dmamap->dm_segs[0].ds_addr; - screen->fb_phys = fb_dmamap->dm_segs[0].ds_addr; - screen->ro_phys = ro_dmamap->dm_segs[0].ds_addr; - - gbe_init_screen(screen); - gbe_disable(gsc); - gbe_setup(gsc); - gbe_enable(gsc); - - /* Load colourmap if required. */ - if (screen->depth == 8) - gbe_loadcmap(screen, 0, 255); - - /* Clear framebuffer. */ - gbe_fillrect(gsc, 0, 0, screen->width, screen->height, 0); - - printf("rev %u, %iMB, %dx%d at %d bits\n", gsc->rev, - screen->fb_size >> 20, screen->width, screen->height, - screen->depth); - - /* - * Attach wsdisplay. - */ - - /* Attach as console if necessary. */ - if (strncmp(bios_console, "video", 5) == 0) { - screen->ri.ri_ops.pack_attr(&screen->ri, 0, 0, 0, &attr); - wsdisplay_cnattach(&gbe_stdscreen, &screen->ri, 0, 0, attr); - gsc->console = 1; - } - - waa.console = gsc->console; - waa.scrdata = &gbe_screenlist; - waa.accessops = &gbe_accessops; - waa.accesscookie = screen; - waa.defaultscreens = 0; - config_found(self, &waa, wsemuldisplaydevprint); - - return; - -fail12: - bus_dmamem_unmap(gsc->dmat, screen->ro, GBE_TILE_SIZE); -fail11: - bus_dmamem_free(gsc->dmat, ro_segs, ro_nsegs); -fail10: - bus_dmamap_destroy(gsc->dmat, ro_dmamap); -fail9: - bus_dmamap_unload(gsc->dmat, fb_dmamap); -fail8: - bus_dmamem_unmap(gsc->dmat, screen->fb, screen->fb_size); -fail7: - bus_dmamem_free(gsc->dmat, fb_segs, fb_nsegs); -fail6: - bus_dmamap_destroy(gsc->dmat, fb_dmamap); -fail5: - bus_dmamap_unload(gsc->dmat, tm_dmamap); -fail4: - bus_dmamem_unmap(gsc->dmat, screen->tm, screen->tm_size); -fail3: - bus_dmamem_free(gsc->dmat, tm_segs, tm_nsegs); -fail2: - bus_dmamap_destroy(gsc->dmat, tm_dmamap); -fail1: - bus_space_unmap(gsc->iot, gsc->re_ioh, RE_REG_SIZE); -fail0: - bus_space_unmap(gsc->iot, gsc->ioh, GBE_REG_SIZE); -} - -int -gbe_activate(struct device *self, int act) -{ - struct gbe_softc *gsc = (struct gbe_softc *)self; - int ret = 0; - - switch (act) { - case DVACT_POWERDOWN: - gbe_disable(gsc); - break; - } - - return (ret); -} - -/* - * GBE hardware specific functions. - */ - -void -gbe_init_screen(struct gbe_screen *screen) -{ - uint16_t *tm; - int i; - - /* - * Initialise screen. - */ - screen->mode = WSDISPLAYIO_MODE_EMUL; - - /* Initialise rasops. */ - memset(&screen->ri, 0, sizeof(struct rasops_info)); - - screen->ri.ri_flg = RI_CENTER; - screen->ri.ri_depth = screen->depth; - screen->ri.ri_width = screen->width; - screen->ri.ri_height = screen->height; - screen->ri.ri_bits = (void *)screen->fb; - screen->ri.ri_stride = screen->linebytes; - - if (screen->depth == 32) { - screen->ri.ri_rpos = 24; - screen->ri.ri_rnum = 8; - screen->ri.ri_gpos = 16; - screen->ri.ri_gnum = 8; - screen->ri.ri_bpos = 8; - screen->ri.ri_bnum = 8; - } else if (screen->depth == 16) { - screen->ri.ri_rpos = 10; - screen->ri.ri_rnum = 5; - screen->ri.ri_gpos = 5; - screen->ri.ri_gnum = 5; - screen->ri.ri_bpos = 0; - screen->ri.ri_bnum = 5; - } - - rasops_init(&screen->ri, screen->height / 8, screen->width / 8); - - /* Create a rasops instance that can draw into a single tile. */ - memcpy(&screen->ri_tile, &screen->ri, sizeof(struct rasops_info)); - screen->ri_tile.ri_flg = 0; - screen->ri_tile.ri_width = GBE_TILE_WIDTH >> (screen->depth >> 4); - screen->ri_tile.ri_height = GBE_TILE_HEIGHT; - screen->ri_tile.ri_stride = screen->ri_tile.ri_width * - screen->depth / 8; - screen->ri_tile.ri_xorigin = 0; - screen->ri_tile.ri_yorigin = 0; - screen->ri_tile.ri_bits = screen->ro; - screen->ri_tile.ri_origbits = screen->ro; - screen->ro_curpos = 0; - - screen->ri.ri_hw = screen->sc; - - screen->ri.ri_do_cursor = gbe_do_cursor; - screen->ri.ri_ops.putchar = gbe_putchar; - screen->ri.ri_ops.copyrows = gbe_copyrows; - screen->ri.ri_ops.copycols = gbe_copycols; - screen->ri.ri_ops.eraserows = gbe_eraserows; - screen->ri.ri_ops.erasecols = gbe_erasecols; - - gbe_stdscreen.ncols = screen->ri.ri_cols; - gbe_stdscreen.nrows = screen->ri.ri_rows; - gbe_stdscreen.textops = &screen->ri.ri_ops; - gbe_stdscreen.fontwidth = screen->ri.ri_font->fontwidth; - gbe_stdscreen.fontheight = screen->ri.ri_font->fontheight; - gbe_stdscreen.capabilities = screen->ri.ri_caps; - - /* - * Map framebuffer into tilemap. Each entry in the tilemap is 16 bits - * wide. Each tile is 64KB or 2^16 bits, hence the last 16 bits of the - * address will range from 0x0000 to 0xffff. As a result we simply - * discard the lower 16 bits and store bits 17 through 32 as an entry - * in the tilemap. - */ - tm = (void *)screen->tm; - for (i = 0; i < (screen->fb_size >> GBE_TILE_SHIFT) && - i < GBE_TLB_SIZE; i++) - tm[i] = (screen->fb_phys >> GBE_TILE_SHIFT) + i; -} - -void -gbe_enable(struct gbe_softc *gsc) -{ - struct gbe_screen *screen = gsc->curscr; - uint32_t val; - int i; - - /* Enable dot clock. */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_DOTCLOCK); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_DOTCLOCK, - val | GBE_DOTCLOCK_RUN); - for (i = 0; i < 10000; i++) { - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_DOTCLOCK); - if ((val & GBE_DOTCLOCK_RUN) == GBE_DOTCLOCK_RUN) - break; - delay(10); - } - if (i == 10000) - printf("timeout enabling dot clock!\n"); - - /* Unfreeze pixel counter. */ - bus_space_write_4(gsc->iot, gsc->ioh, GBE_VT_XY, 0); - for (i = 0; i < 10000; i++) { - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_XY); - if ((val & GBE_VT_XY_FREEZE) == 0) - break; - delay(10); - } - if (i == 10000) - printf("timeout unfreezing pixel counter!\n"); - - /* Disable sync-on-green. */ - if (strcmp(osloadoptions, "nosog") == 0) - bus_space_write_4(gsc->iot, gsc->ioh, GBE_VT_FLAGS, - GBE_VT_SYNC_LOW); - - /* Provide GBE with address of tilemap and enable DMA. */ - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_CTRL, - ((screen->tm_phys >> 9) << - GBE_FB_CTRL_TILE_PTR_SHIFT) | GBE_FB_CTRL_DMA_ENABLE); -} - -void -gbe_disable(struct gbe_softc *gsc) -{ - uint32_t val; - int i; - - /* Nothing to do if the pixel counter is frozen! */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_XY); - if ((val & GBE_VT_XY_FREEZE) == GBE_VT_XY_FREEZE) - return; - - /* Enable sync-on-green. */ - bus_space_write_4(gsc->iot, gsc->ioh, GBE_VT_FLAGS, 0); - - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_DOTCLOCK); - if ((val & GBE_DOTCLOCK_RUN) == 0) - return; - - /* Disable overlay and turn off hardware cursor. */ - bus_space_write_4(gsc->iot, gsc->ioh, GBE_OVERLAY_TILE, 0); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_CURSOR_CTRL, 0); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_DID_CTRL, 0); - - /* Disable DMA. */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_OVERLAY_CTRL); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_OVERLAY_CTRL, - val & ~GBE_OVERLAY_CTRL_DMA_ENABLE); - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_FB_CTRL); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_CTRL, - val & ~GBE_FB_CTRL_DMA_ENABLE); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_DID_CTRL, 0); - for (i = 0; i < 100000; i++) { - if ((bus_space_read_4(gsc->iot, gsc->ioh, GBE_OVERLAY_HW_CTRL) - & GBE_OVERLAY_CTRL_DMA_ENABLE) == 0 && - (bus_space_read_4(gsc->iot, gsc->ioh, GBE_FB_HW_CTRL) - & GBE_FB_CTRL_DMA_ENABLE) == 0 && - bus_space_read_4(gsc->iot, gsc->ioh, GBE_DID_HW_CTRL) == 0) - break; - delay(10); - } - if (i == 100000) - printf("timeout disabling DMA!\n"); - - /* Wait for the end of pixel refresh. */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_VPIX) - & GBE_VT_VPIX_OFF_MASK; - for (i = 0; i < 100000; i++) { - if (((bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_XY) - & GBE_VT_XY_Y_MASK) >> GBE_VT_XY_Y_SHIFT) < val) - break; - delay(1); - } - if (i == 100000) - printf("timeout waiting for pixel refresh!\n"); - for (i = 0; i < 100000; i++) { - if (((bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_XY) - & GBE_VT_XY_Y_MASK) >> GBE_VT_XY_Y_SHIFT) > val) - break; - delay(1); - } - if (i == 100000) - printf("timeout waiting for pixel refresh!\n"); - - /* Freeze pixel counter. */ - bus_space_write_4(gsc->iot, gsc->ioh, GBE_VT_XY, GBE_VT_XY_FREEZE); - for (i = 0; i < 100000; i++) { - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_XY); - if ((val & GBE_VT_XY_FREEZE) == GBE_VT_XY_FREEZE) - break; - delay(10); - } - if (i == 100000) - printf("timeout freezing pixel counter!\n"); - - /* Disable dot clock. */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_DOTCLOCK); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_DOTCLOCK, - val & ~GBE_DOTCLOCK_RUN); - for (i = 0; i < 100000; i++) { - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_DOTCLOCK); - if ((val & GBE_DOTCLOCK_RUN) == 0) - break; - delay(10); - } - if (i == 100000) - printf("timeout disabling dot clock!\n"); - - /* Reset DMA fifo. */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_FB_SIZE_TILE); - val &= ~(1 << GBE_FB_SIZE_TILE_FIFO_RESET_SHIFT); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_SIZE_TILE, - val | (1 << GBE_FB_SIZE_TILE_FIFO_RESET_SHIFT)); - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_SIZE_TILE, val); -} - -void -gbe_setup(struct gbe_softc *gsc) -{ - struct gbe_screen *screen = gsc->curscr; - int i, t, cmode, tile_width, tiles_x, tiles_y; - u_char *colour; - uint16_t *tm; - uint32_t val; - uint64_t reg; - - /* - * Setup framebuffer. - */ - switch (screen->depth) { - case 32: - cmode = GBE_CMODE_RGB8; - screen->bufmode = COLOUR_DEPTH_32 << BUFMODE_BUFDEPTH_SHIFT | - PIXEL_TYPE_RGB << BUFMODE_PIXTYPE_SHIFT | - COLOUR_DEPTH_32 << BUFMODE_PIXDEPTH_SHIFT; - break; - case 16: - cmode = GBE_CMODE_ARGB5; - screen->bufmode = COLOUR_DEPTH_16 << BUFMODE_BUFDEPTH_SHIFT | - PIXEL_TYPE_RGBA << BUFMODE_PIXTYPE_SHIFT | - COLOUR_DEPTH_16 << BUFMODE_PIXDEPTH_SHIFT; - break; - case 8: - default: - cmode = GBE_CMODE_I8; - screen->bufmode = COLOUR_DEPTH_8 << BUFMODE_BUFDEPTH_SHIFT | - PIXEL_TYPE_CI << BUFMODE_PIXTYPE_SHIFT | - COLOUR_DEPTH_8 << BUFMODE_PIXDEPTH_SHIFT; - break; - } - - /* Calculate tile width in bytes and screen size in tiles. */ - tile_width = GBE_TILE_WIDTH >> (screen->depth >> 4); - tiles_x = (screen->width + tile_width - 1) >> - (GBE_TILE_WIDTH_SHIFT - (screen->depth >> 4)); - tiles_y = (screen->height + GBE_TILE_HEIGHT - 1) >> - GBE_TILE_HEIGHT_SHIFT; - - if (screen->mode != WSDISPLAYIO_MODE_EMUL) { - - /* - * Setup the framebuffer in "linear" mode. We trick the - * framebuffer into linear mode by telling it that it is one - * tile wide and specifying an adjusted framebuffer height. - */ - - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_SIZE_TILE, - ((screen->depth >> 4) << GBE_FB_SIZE_TILE_DEPTH_SHIFT) | - (1 << GBE_FB_SIZE_TILE_WIDTH_SHIFT)); - - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_SIZE_PIXEL, - (screen->width * screen->height / tile_width) << - GBE_FB_SIZE_PIXEL_HEIGHT_SHIFT); - - } else { - - /* - * Setup the framebuffer in tiled mode. Provide the tile - * colour depth, screen width in whole and partial tiles, - * and the framebuffer height in pixels. - */ - - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_SIZE_TILE, - ((screen->depth >> 4) << GBE_FB_SIZE_TILE_DEPTH_SHIFT) | - ((screen->width / tile_width) << - GBE_FB_SIZE_TILE_WIDTH_SHIFT) | - (((screen->width % tile_width) >> (screen->depth >> 4)) / - 32)); - - bus_space_write_4(gsc->iot, gsc->ioh, GBE_FB_SIZE_PIXEL, - screen->height << GBE_FB_SIZE_PIXEL_HEIGHT_SHIFT); - - } - - /* Set colour mode registers. */ - val = (cmode << GBE_WID_MODE_SHIFT) | GBE_BMODE_BOTH; - for (i = 0; i < (32 * 4); i += 4) - bus_space_write_4(gsc->iot, gsc->ioh, GBE_MODE + i, val); - - /* - * Initialise colourmap if required. - */ - if (screen->depth == 8) { - for (i = 0; i < 16; i++) { - colour = (u_char *)&rasops_cmap[i * 3]; - screen->cmap.cm_red[i] = colour[0]; - screen->cmap.cm_green[i] = colour[1]; - screen->cmap.cm_blue[i] = colour[2]; - } - for (i = 240; i < 256; i++) { - colour = (u_char *)&rasops_cmap[i * 3]; - screen->cmap.cm_red[i] = colour[0]; - screen->cmap.cm_green[i] = colour[1]; - screen->cmap.cm_blue[i] = colour[2]; - } - } - - /* - * Setup an alpha ramp. - */ - for (i = 0; i < GBE_GMAP_ENTRIES; i++) - bus_space_write_4(gsc->iot, gsc->ioh, - GBE_GMAP + i * sizeof(u_int32_t), - (i << 24) | (i << 16) | (i << 8)); - - /* - * Initialise the rendering engine. - */ - val = screen->mode | BUF_TYPE_TLB_A << BUFMODE_BUFTYPE_SHIFT; - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_BUFMODE_SRC, val); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_BUFMODE_DST, val); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_CLIPMODE, 0); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_COLOUR_MASK, 0xffffffff); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_PIXEL_XFER_X_STEP, 1); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_PIXEL_XFER_Y_STEP, 1); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_WINOFFSET_DST, 0); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_WINOFFSET_SRC, 0); - - /* - * Load framebuffer tiles into TLB A. Each TLB consists of a 16x16 - * tile array representing 2048x2048 pixels. Each entry in the TLB - * consists of four 16-bit entries which represent bits 17:32 of the - * 64KB tile address. As a result, we can make use of the tilemap - * which already stores tile entries in the same format. - */ - tm = (void *)screen->tm; - for (i = 0, t = 0; i < GBE_TLB_SIZE; i++) { - reg <<= 16; - if (i % 16 < tiles_x) - reg |= (tm[t++] | 0x8000); - if (i % 4 == 3) - bus_space_write_8(gsc->iot, gsc->re_ioh, - RE_TLB_A + (i >> 2) * 8, reg); - } - - /* Load single tile into TLB B for rasops. */ - bus_space_write_8(gsc->iot, gsc->re_ioh, - RE_TLB_B, (screen->ro_phys >> 16 | 0x8000) << 48); -} - -void -gbe_wait_re_idle(struct gbe_softc *gsc) -{ - int i; - - /* Wait until rendering engine is idle. */ - for (i = 0; i < 100000; i++) { - if (bus_space_read_4(gsc->iot, gsc->re_ioh, RE_PP_STATUS) & - RE_PP_STATUS_IDLE) - break; - delay(1); - } - if (i == 100000) - printf("%s: rendering engine did not become idle!\n", - gsc->sc_dev.dv_xname); -} - -/* - * Interfaces for wscons. - */ - -int -gbe_ioctl(void *v, u_long cmd, caddr_t data, int flags, struct proc *p) -{ - struct gbe_screen *screen = (struct gbe_screen *)v; - int rc, mode; - - switch (cmd) { - case WSDISPLAYIO_GTYPE: - *(u_int *)data = WSDISPLAY_TYPE_GBE; - break; - - case WSDISPLAYIO_GINFO: - { - struct wsdisplay_fbinfo *fb = (struct wsdisplay_fbinfo *)data; - - fb->height = screen->height; - fb->width = screen->width; - fb->depth = screen->depth; - fb->cmsize = screen->depth == 8 ? 256 : 0; - } - break; - - case WSDISPLAYIO_LINEBYTES: - *(u_int *)data = screen->linebytes; - break; - - case WSDISPLAYIO_GETCMAP: - if (screen->depth == 8) { - struct wsdisplay_cmap *cm = - (struct wsdisplay_cmap *)data; - - rc = gbe_getcmap(&screen->cmap, cm); - if (rc != 0) - return (rc); - } - break; - - case WSDISPLAYIO_PUTCMAP: - if (screen->depth == 8) { - struct wsdisplay_cmap *cm = - (struct wsdisplay_cmap *)data; - - rc = gbe_putcmap(&screen->cmap, cm); - if (rc != 0) - return (rc); - gbe_loadcmap(screen, cm->index, cm->index + cm->count); - } - break; - - case WSDISPLAYIO_GMODE: - *(u_int *)data = screen->mode; - break; - - case WSDISPLAYIO_SMODE: - mode = *(u_int *)data; - if (mode == WSDISPLAYIO_MODE_EMUL || - mode == WSDISPLAYIO_MODE_MAPPED || - mode == WSDISPLAYIO_MODE_DUMBFB) { - - screen->mode = mode; - - gbe_disable((struct gbe_softc *)screen->sc); - gbe_setup((struct gbe_softc *)screen->sc); - gbe_enable((struct gbe_softc *)screen->sc); - - /* Clear framebuffer if entering emulated mode. */ - if (screen->mode == WSDISPLAYIO_MODE_EMUL) - gbe_fillrect((struct gbe_softc *)screen->sc, - 0, 0, screen->width, screen->height, 0); - } - break; - - case WSDISPLAYIO_GVIDEO: - case WSDISPLAYIO_SVIDEO: - /* Handled by the upper layer. */ - break; - - default: - return (-1); - } - - return (0); -} - -paddr_t -gbe_mmap(void *v, off_t offset, int protection) -{ - struct gbe_screen *screen = (void *)v; - paddr_t pa; - - if (offset >= 0 && offset < screen->fb_size) - pa = screen->fb_phys + offset; - else - pa = -1; - - return (pa); -} - -int -gbe_alloc_screen(void *v, const struct wsscreen_descr *type, void **cookiep, - int *curxp, int *curyp, uint32_t *attrp) -{ - struct gbe_screen *screen = (struct gbe_screen *)v; - struct gbe_softc *gsc = (struct gbe_softc *)screen->sc; - - /* We do not allow multiple consoles at the moment. */ - if (gsc->screens > 0) - return (ENOMEM); - - gsc->screens++; - - /* Return rasops_info via cookie. */ - *cookiep = &screen->ri; - - /* Move cursor to top left of screen. */ - *curxp = 0; - *curyp = 0; - - /* Correct screen attributes. */ - screen->ri.ri_ops.pack_attr(&screen->ri, 0, 0, 0, attrp); - - return (0); -} - -void -gbe_free_screen(void *v, void *cookie) -{ - /* We do not allow multiple consoles at the moment. */ -} - -int -gbe_show_screen(void *v, void *cookie, int waitok, void (*cb)(void *, int, int), - void *cbarg) -{ - /* We do not allow multiple consoles at the moment. */ - return (0); -} - -int -gbe_load_font(void *v, void *emulcookie, struct wsdisplay_font *font) -{ - struct gbe_screen *screen = (struct gbe_screen *)v; - - return rasops_load_font(&screen->ri, emulcookie, font); -} - -int -gbe_list_font(void *v, struct wsdisplay_font *font) -{ - struct gbe_screen *screen = (struct gbe_screen *)v; - - return rasops_list_font(&screen->ri, font); -} - -/* - * Colour map handling for indexed modes. - */ - -void -gbe_setcolour(struct gbe_softc *gsc, u_int index, u_int8_t r, u_int8_t g, - u_int8_t b) -{ - int i; - - /* Wait until the colourmap FIFO has free space. */ - for (i = 0; i < 10000; i++) { - if (bus_space_read_4(gsc->iot, gsc->ioh, GBE_CMAP_FIFO) - < GBE_CMAP_FIFO_ENTRIES) - break; - delay(10); - } - if (i == 10000) - printf("colourmap FIFO has no free space!\n"); - - bus_space_write_4(gsc->iot, gsc->ioh, - GBE_CMAP + index * sizeof(u_int32_t), - ((u_int)r << 24) | ((u_int)g << 16) | ((u_int)b << 8)); -} - -int -gbe_getcmap(struct gbe_cmap *cm, struct wsdisplay_cmap *rcm) -{ - u_int index = rcm->index, count = rcm->count; - int rc; - - if (index >= 256 || count > 256 - index) - return (EINVAL); - - if ((rc = copyout(&cm->cm_red[index], rcm->red, count)) != 0) - return (rc); - if ((rc = copyout(&cm->cm_green[index], rcm->green, count)) != 0) - return (rc); - if ((rc = copyout(&cm->cm_blue[index], rcm->blue, count)) != 0) - return (rc); - - return (0); -} - -int -gbe_putcmap(struct gbe_cmap *cm, struct wsdisplay_cmap *rcm) -{ - u_int index = rcm->index, count = rcm->count; - int rc; - - if (index >= 256 || count > 256 - index) - return (EINVAL); - - if ((rc = copyin(rcm->red, &cm->cm_red[index], count)) != 0) - return (rc); - if ((rc = copyin(rcm->green, &cm->cm_green[index], count)) != 0) - return (rc); - if ((rc = copyin(rcm->blue, &cm->cm_blue[index], count)) != 0) - return (rc); - - return (0); -} - -void -gbe_loadcmap(struct gbe_screen *screen, u_int start, u_int end) -{ - struct gbe_softc *gsc = (void *)screen->sc; - struct gbe_cmap *cm = &screen->cmap; - - for (; start <= end; start++) - gbe_setcolour(gsc, start, - cm->cm_red[start], cm->cm_green[start], cm->cm_blue[start]); -} - -/* - * Hardware accelerated functions for rasops. - */ - -void -gbe_rop(struct gbe_softc *gsc, int x, int y, int w, int h, int op) -{ - gbe_wait_re_idle(gsc); - - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_PRIMITIVE, - PRIMITIVE_RECTANGLE | PRIMITIVE_LRTB); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_DRAWMODE, - DRAWMODE_BITMASK | DRAWMODE_BYTEMASK | DRAWMODE_PIXEL_XFER | - DRAWMODE_LOGIC_OP); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_LOGIC_OP, op); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_PIXEL_XFER_SRC, - (x << 16) | (y & 0xffff)); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_VERTEX_X_0, - (x << 16) | (y & 0xffff)); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_VERTEX_X_1 | RE_START, - ((x + w - 1) << 16) | ((y + h - 1) & 0xffff)); -} - -void -gbe_copyrect(struct gbe_softc *gsc, int src, int sx, int sy, int dx, int dy, - int w, int h) -{ - int direction, x0, y0, x1, y1; - - if (sx >= dx && sy >= dy) { - direction = PRIMITIVE_LRTB; - x0 = dx; - y0 = dy; - x1 = dx + w - 1; - y1 = dy + h - 1; - } else if (sx >= dx && sy < dy) { - direction = PRIMITIVE_LRBT; - sy = sy + h - 1; - x0 = dx; - y0 = dy + h - 1; - x1 = dx + w - 1; - y1 = dy; - } else if (sx < dx && sy >= dy) { - direction = PRIMITIVE_RLTB; - sx = sx + w - 1; - x0 = dx + w - 1; - y0 = dy; - x1 = dx; - y1 = dy + h - 1; - } else if (sx < dx && sy < dy) { - direction = PRIMITIVE_RLBT; - sy = sy + h - 1; - sx = sx + w - 1; - x0 = dx + w - 1; - y0 = dy + h - 1; - x1 = dx; - y1 = dy; - } - - gbe_wait_re_idle(gsc); - - if (src != BUF_TYPE_TLB_A) - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_BUFMODE_SRC, - gsc->curscr->bufmode | (src << BUFMODE_BUFTYPE_SHIFT)); - - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_PRIMITIVE, - PRIMITIVE_RECTANGLE | direction); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_DRAWMODE, - DRAWMODE_BITMASK | DRAWMODE_BYTEMASK | DRAWMODE_PIXEL_XFER); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_PIXEL_XFER_SRC, - (sx << 16) | (sy & 0xffff)); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_VERTEX_X_0, - (x0 << 16) | (y0 & 0xffff)); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_VERTEX_X_1 | RE_START, - (x1 << 16) | (y1 & 0xffff)); - - if (src != BUF_TYPE_TLB_A) { - gbe_wait_re_idle(gsc); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_BUFMODE_SRC, - gsc->curscr->bufmode | - (BUF_TYPE_TLB_A << BUFMODE_BUFTYPE_SHIFT)); - } -} - -void -gbe_fillrect(struct gbe_softc *gsc, int x, int y, int w, int h, int bg) -{ - - gbe_wait_re_idle(gsc); - - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_PRIMITIVE, - PRIMITIVE_RECTANGLE | PRIMITIVE_LRTB); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_DRAWMODE, - DRAWMODE_BITMASK | DRAWMODE_BYTEMASK); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_SHADE_FG_COLOUR, bg); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_VERTEX_X_0, - (x << 16) | (y & 0xffff)); - bus_space_write_4(gsc->iot, gsc->re_ioh, RE_PP_VERTEX_X_1 | RE_START, - ((x + w - 1) << 16) | ((y + h - 1) & 0xffff)); -} - -int -gbe_do_cursor(struct rasops_info *ri) -{ - struct gbe_softc *sc = ri->ri_hw; - int y, x, w, h; - - w = ri->ri_font->fontwidth; - h = ri->ri_font->fontheight; - x = ri->ri_xorigin + ri->ri_ccol * w; - y = ri->ri_yorigin + ri->ri_crow * h; - - gbe_rop(sc, x, y, w, h, OPENGL_LOGIC_OP_COPY_INVERTED); - - return 0; -} - -int -gbe_putchar(void *cookie, int row, int col, u_int uc, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct gbe_softc *gsc = ri->ri_hw; - struct gbe_screen *screen = gsc->curscr; - struct rasops_info *ri_tile = &screen->ri_tile; - int x, y, w, h; - - w = ri->ri_font->fontwidth; - h = ri->ri_font->fontheight; - x = ri->ri_xorigin + col * w; - y = ri->ri_yorigin + row * h; - - ri_tile->ri_ops.putchar(ri_tile, 0, screen->ro_curpos, uc, attr); - - gbe_copyrect(gsc, BUF_TYPE_TLB_B, screen->ro_curpos * w, 0, x, y, w, h); - - screen->ro_curpos++; - if ((screen->ro_curpos + 1) * w > screen->ri_tile.ri_width) - screen->ro_curpos = 0; - - return 0; -} - -int -gbe_copycols(void *cookie, int row, int src, int dst, int num) -{ - struct rasops_info *ri = cookie; - struct gbe_softc *sc = ri->ri_hw; - - num *= ri->ri_font->fontwidth; - src *= ri->ri_font->fontwidth; - dst *= ri->ri_font->fontwidth; - row *= ri->ri_font->fontheight; - - gbe_copyrect(sc, BUF_TYPE_TLB_A, ri->ri_xorigin + src, - ri->ri_yorigin + row, ri->ri_xorigin + dst, ri->ri_yorigin + row, - num, ri->ri_font->fontheight); - - return 0; -} - -int -gbe_erasecols(void *cookie, int row, int col, int num, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct gbe_softc *sc = ri->ri_hw; - int bg, fg; - - ri->ri_ops.unpack_attr(cookie, attr, &fg, &bg, NULL); - - row *= ri->ri_font->fontheight; - col *= ri->ri_font->fontwidth; - num *= ri->ri_font->fontwidth; - - gbe_fillrect(sc, ri->ri_xorigin + col, ri->ri_yorigin + row, - num, ri->ri_font->fontheight, ri->ri_devcmap[bg]); - - return 0; -} - -int -gbe_copyrows(void *cookie, int src, int dst, int num) -{ - struct rasops_info *ri = cookie; - struct gbe_softc *sc = ri->ri_hw; - - num *= ri->ri_font->fontheight; - src *= ri->ri_font->fontheight; - dst *= ri->ri_font->fontheight; - - gbe_copyrect(sc, BUF_TYPE_TLB_A, ri->ri_xorigin, ri->ri_yorigin + src, - ri->ri_xorigin, ri->ri_yorigin + dst, ri->ri_emuwidth, num); - - return 0; -} - -int -gbe_eraserows(void *cookie, int row, int num, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct gbe_softc *sc = ri->ri_hw; - int x, y, w, bg, fg; - - ri->ri_ops.unpack_attr(cookie, attr, &fg, &bg, NULL); - - if ((num == ri->ri_rows) && ISSET(ri->ri_flg, RI_FULLCLEAR)) { - num = ri->ri_height; - x = y = 0; - w = ri->ri_width; - } else { - num *= ri->ri_font->fontheight; - x = ri->ri_xorigin; - y = ri->ri_yorigin + row * ri->ri_font->fontheight; - w = ri->ri_emuwidth; - } - - gbe_fillrect(sc, x, y, w, num, ri->ri_devcmap[bg]); - - return 0; -} - -/* - * Console functions for early display. - */ - -int -gbe_cnprobe(bus_space_tag_t iot, bus_addr_t addr) -{ - bus_space_handle_t ioh; - int val, width, height; - - /* Setup bus space mapping. */ - ioh = PHYS_TO_XKPHYS(addr, CCA_NC); - - /* Determine resolution configured by firmware. */ - val = bus_space_read_4(iot, ioh, GBE_VT_HCMAP); - width = (val >> GBE_VT_HCMAP_ON_SHIFT) & 0xfff; - val = bus_space_read_4(iot, ioh, GBE_VT_VCMAP); - height = (val >> GBE_VT_VCMAP_ON_SHIFT) & 0xfff; - - /* Ensure that the firmware has setup the device. */ - if (width != 0 && height != 0) - return (1); - else - return (0); -} - -int -gbe_cnattach(bus_space_tag_t iot, bus_addr_t addr) -{ - struct gbe_softc *gsc; - uint32_t val; - paddr_t pa; - vaddr_t va; - uint32_t attr; - - /* - * Setup GBE for use as early console. - */ - va = pmap_steal_memory(sizeof(struct gbe_softc), NULL, NULL); - gsc = (struct gbe_softc *)va; - gsc->curscr = &gbe_consdata; - gbe_consdata.sc = (struct device *)gsc; - - /* Setup bus space mapping. */ - gsc->iot = iot; - gsc->ioh = PHYS_TO_XKPHYS(addr, CCA_NC); - gsc->re_ioh = PHYS_TO_XKPHYS(RE_BASE, CCA_NC); - - /* Determine GBE revision. */ - gsc->rev = bus_space_read_4(gsc->iot, gsc->ioh, GBE_CTRL_STAT) & 0xf; - - /* Determine resolution configured by firmware. */ - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_HCMAP); - gbe_consdata.width = (val >> GBE_VT_HCMAP_ON_SHIFT) & 0xfff; - val = bus_space_read_4(gsc->iot, gsc->ioh, GBE_VT_VCMAP); - gbe_consdata.height = (val >> GBE_VT_VCMAP_ON_SHIFT) & 0xfff; - - /* Ensure that the firmware has setup the device. */ - if (gbe_consdata.width == 0 || gbe_consdata.height == 0) - return (ENXIO); - - /* Setup screen defaults. */ - gbe_consdata.fb_size = GBE_FB_SIZE; - gbe_consdata.tm_size = GBE_TLB_SIZE * sizeof(uint16_t); - gbe_consdata.depth = 8; - gbe_consdata.linebytes = gbe_consdata.width * gbe_consdata.depth / 8; - - /* - * Steal memory for tilemap - 64KB aligned and coherent. - */ - va = pmap_steal_memory(gbe_consdata.tm_size + 65536, NULL, NULL); - pmap_extract(pmap_kernel(), va, &pa); - gbe_consdata.tm_phys = ((pa >> 16) + 1) << 16; - gbe_consdata.tm = (caddr_t)PHYS_TO_XKPHYS(gbe_consdata.tm_phys, CCA_NC); - - /* - * Steal memory for framebuffer - 64KB aligned and coherent. - */ - va = pmap_steal_memory(gbe_consdata.fb_size + 65536, NULL, NULL); - pmap_extract(pmap_kernel(), va, &pa); - gbe_consdata.fb_phys = ((pa >> 16) + 1) << 16; - gbe_consdata.fb = (caddr_t)PHYS_TO_XKPHYS(gbe_consdata.fb_phys, CCA_NC); - - /* - * Steal memory for rasops tile - 64KB aligned and coherent. - */ - va = pmap_steal_memory(GBE_TILE_SIZE + 65536, NULL, NULL); - pmap_extract(pmap_kernel(), va, &pa); - gbe_consdata.ro_phys = ((pa >> 16) + 1) << 16; - gbe_consdata.ro = (caddr_t)PHYS_TO_XKPHYS(gbe_consdata.ro_phys, CCA_NC); - - /* - * Setup GBE hardware. - */ - gbe_init_screen(&gbe_consdata); - gbe_disable(gsc); - gbe_setup(gsc); - gbe_enable(gsc); - - /* Load colourmap if required. */ - if (gbe_consdata.depth == 8) - gbe_loadcmap(&gbe_consdata, 0, 255); - - /* Clear framebuffer. */ - gbe_fillrect(gsc, 0, 0, gbe_consdata.width, gbe_consdata.height, 0); - - /* - * Attach wsdisplay. - */ - gbe_consdata.ri.ri_ops.pack_attr(&gbe_consdata.ri, 0, 0, 0, &attr); - wsdisplay_cnattach(&gbe_stdscreen, &gbe_consdata.ri, 0, 0, attr); - gbe_console = 1; - - return (0); -} diff --git a/sys/arch/sgi/dev/gbereg.h b/sys/arch/sgi/dev/gbereg.h deleted file mode 100644 index c20007fa3c5..00000000000 --- a/sys/arch/sgi/dev/gbereg.h +++ /dev/null @@ -1,206 +0,0 @@ -/* $OpenBSD: gbereg.h,v 1.6 2012/05/29 17:37:09 mikeb Exp $ */ - -/* - * Copyright (c) 2007, Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * GBE Framebuffer for SGI O2. - */ - -#define GBE_BASE 0x16000000 -#define GBE_REG_SIZE 0x100000 -#define GBE_TLB_SIZE 128 - -#define GBE_TILE_SHIFT 16 -#define GBE_TILE_SIZE (1 << GBE_TILE_SHIFT) - -#define GBE_TILE_WIDTH 512 /* Width of tile in bytes. */ -#define GBE_TILE_WIDTH_SHIFT 9 -#define GBE_TILE_HEIGHT 128 /* Height of tile in bytes. */ -#define GBE_TILE_HEIGHT_SHIFT 7 - -/* - * GBE Registers. - */ - -#define GBE_CTRL_STAT 0x00000000 /* General control/status */ -#define GBE_CURSOR_ON 0x00000001 -#define GBE_DOTCLOCK 0x00000004 /* Dotclock */ -#define GBE_DOTCLOCK_RUN 0x00100000 /* Enable dotclock */ -#define GBE_VT_XY 0x00010000 /* Current dot coordinates */ -#define GBE_VT_XY_X_SHIFT 0 -#define GBE_VT_XY_X_MASK 0x00000fff -#define GBE_VT_XY_Y_SHIFT 12 -#define GBE_VT_XY_Y_MASK 0x00fff000 -#define GBE_VT_XY_FREEZE 0x80000000 /* Freeze pixel counter */ -#define GBE_VT_MAXXY 0x00010004 /* */ -#define GBE_VT_VSYNC 0x00010008 /* Vertical sync on/off */ -#define GBE_VT_HSYNC 0x0001000c /* Horizontal sync on/off */ -#define GBE_VT_VBLANK 0x00010010 /* Vertical blanking */ -#define GBE_VT_HBLANK 0x00010014 /* Horizontal blanking */ -#define GBE_VT_FLAGS 0x00010018 /* Video timing flags */ -#define GBE_VT_SYNC_LOW 0x00000020 /* Sync on green */ -#define GBE_VT_HPIX 0x00010034 /* Horizontal pixel on/off */ -#define GBE_VT_VPIX 0x00010038 /* Vertical pixel on/off */ -#define GBE_VT_VPIX_OFF_MASK 0x00000fff -#define GBE_VT_VPIX_OFF_SHIFT 0 -#define GBE_VT_VPIX_ON_MASK 0x00fff000 -#define GBE_VT_VPIX_ON_SHIFT 12 -#define GBE_VT_HCMAP 0x0001003c /* Horizontal cmap write */ -#define GBE_VT_HCMAP_ON_SHIFT 12 -#define GBE_VT_VCMAP 0x00010040 /* Vertical cmap write */ -#define GBE_VT_VCMAP_ON_SHIFT 12 -#define GBE_VT_DIDSTARTXY 0x00010044 /* DID reset at x/y */ -#define GBE_VT_CRSSTARTXY 0x00010048 /* CRS reset at x/y */ -#define GBE_VT_VCSTARTXY 0x0001004c /* VC reset at x/y */ -#define GBE_OVERLAY_TILE 0x00020000 /* Overlay plane - tile width */ -#define GBE_OVERLAY_HW_CTRL 0x00020004 /* Overlay plane - h/w control */ -#define GBE_OVERLAY_CTRL 0x00020008 /* Overlay plane - control */ -#define GBE_OVERLAY_CTRL_DMA_ENABLE 0x00000001 -#define GBE_FB_SIZE_TILE 0x00030000 /* Framebuffer - tile size */ -#define GBE_FB_SIZE_TILE_WIDTH_SHIFT 5 -#define GBE_FB_SIZE_TILE_DEPTH_SHIFT 13 -#define GBE_FB_SIZE_TILE_FIFO_RESET_SHIFT 15 -#define GBE_FB_SIZE_PIXEL 0x00030004 /* Framebuffer - pixel size */ -#define GBE_FB_SIZE_PIXEL_HEIGHT_SHIFT 16 -#define GBE_FB_HW_CTRL 0x00030008 /* Framebuffer - hardware control */ -#define GBE_FB_CTRL 0x0003000c /* Framebuffer - control */ -#define GBE_FB_CTRL_TILE_PTR_SHIFT 9 -#define GBE_FB_CTRL_DMA_ENABLE 0x00000001 -#define GBE_DID_HW_CTRL 0x00040000 /* DID hardware control */ -#define GBE_DID_CTRL 0x00040004 /* DID control */ -#define GBE_MODE 0x00048000 /* Colour mode */ -#define GBE_WID_MODE_SHIFT 2 -#define GBE_CMAP 0x050000 /* Colourmap */ -#define GBE_CMAP_ENTRIES 6144 -#define GBE_CMAP_FIFO 0x058000 /* Colourmap FIFO status */ -#define GBE_CMAP_FIFO_ENTRIES 63 -#define GBE_GMAP 0x060000 /* Gammamap */ -#define GBE_GMAP_ENTRIES 256 -#define GBE_CURSOR_POS 0x00070000 /* Cursor position */ -#define GBE_CURSOR_CTRL 0x00070004 /* Cursor control */ - -/* - * GBE Constants. - */ - -#define GBE_FB_DEPTH_8 0 -#define GBE_FB_DEPTH_16 1 -#define GBE_FB_DEPTH_32 2 - -#define GBE_CMODE_I8 0 /* 8 bit indexed */ -#define GBE_CMODE_I12 1 /* 12 bit indexed */ -#define GBE_CMODE_RG3B2 2 /* 3:3:2 direct */ -#define GBE_CMODE_RGB4 3 /* 4:4:4 direct */ -#define GBE_CMODE_ARGB5 4 /* 1:5:5:5 direct */ -#define GBE_CMODE_RGB8 5 /* 8:8:8 direct */ -#define GBE_CMODE_RGBA5 6 /* 5:5:5:5 direct */ -#define GBE_CMODE_RGB10 7 /* 10:10:10 direct */ - -#define GBE_BMODE_BOTH 3 - -/* - * Rendering Engine Registers. - */ - -#define RE_BASE 0x15000000 -#define RE_REG_SIZE 0x5000 -#define RE_START 0x00000800 /* Start rendering operation. */ - -/* TLB Registers. */ -#define RE_TLB_A 0x00001000 /* 256 16-bit tile entries. */ -#define RE_TLB_B 0x00001200 -#define RE_TLB_C 0x00001400 -#define RE_TLB_TEX 0x00001600 -#define RE_TLB_CLIP_ID 0x000016e0 -#define RE_TLB_LINEAR_A 0x00001700 -#define RE_TLB_LINEAR_B 0x00001780 - -/* Pixel Pipeline Registers. */ -#define RE_PP_BUFMODE_SRC 0x00002000 -#define RE_PP_BUFMODE_DST 0x00002008 -#define RE_PP_CLIPMODE 0x00002010 -#define RE_PP_DRAWMODE 0x00002018 -#define DRAWMODE_STENCIL 0x1 << 0 -#define DRAWMODE_DEPTH_MASK 0x1 << 1 -#define DRAWMODE_DEPTH_TEST 0x1 << 2 -#define DRAWMODE_BYTEMASK 0xf << 3 -#define DRAWMODE_BITMASK 0x1 << 7 -#define DRAWMODE_DITHER 0x1 << 8 -#define DRAWMODE_LOGIC_OP 0x1 << 9 -#define DRAWMODE_ALPHA_BLEND 0x1 << 10 -#define DRAWMODE_PIXEL_XFER 0x1 << 21 -#define RE_PP_WINOFFSET_SRC 0x00002050 -#define RE_PP_WINOFFSET_DST 0x00002058 -#define RE_PP_PRIMITIVE 0x00002060 /* Drawing primitive. */ -#define PRIMITIVE_POINT 0x0 << 24 -#define PRIMITIVE_LINE 0x1 << 24 -#define PRIMITIVE_TRIANGLE 0x2 << 24 -#define PRIMITIVE_RECTANGLE 0x3 << 24 -#define PRIMITIVE_LRBT 0x0 << 16 -#define PRIMITIVE_RLBT 0x1 << 16 -#define PRIMITIVE_LRTB 0x2 << 16 -#define PRIMITIVE_RLTB 0x3 << 16 -#define RE_PP_VERTEX_X_0 0x00002070 /* (x0,y0) vertex. */ -#define RE_PP_VERTEX_X_1 0x00002074 /* (x1,y1) vertex. */ -#define RE_PP_VERTEX_X_2 0x00002078 /* (x2,y2) vertex. */ -#define RE_PP_PIXEL_XFER_SRC 0x000020a0 /* Pixel transfer source. */ -#define RE_PP_PIXEL_XFER_X_STEP 0x000020a8 -#define RE_PP_PIXEL_XFER_Y_STEP 0x000020ac -#define RE_PP_STIPPLE_MODE 0x000020c0 -#define RE_PP_STIPPLE_PATTERN 0x000020c4 -#define RE_PP_SHADE_FG_COLOUR 0x000020d0 -#define RE_PP_SHADE_BG_COLOUR 0x000020d8 -#define RE_PP_LOGIC_OP 0x000021b0 /* Logic operation. */ -#define RE_PP_COLOUR_MASK 0x000021b8 /* Colour buffer plane mask. */ -#define COLOUR_MASK_NONE 0xffffffff -#define RE_PP_NULL 0x000021f0 -#define RE_PP_FLUSH 0x000021f8 - -#define BUFMODE_PIXDEPTH_SHIFT 2 /* Pixel colour depth. */ -#define BUFMODE_PIXTYPE_SHIFT 4 /* Pixel format. */ -#define BUFMODE_BUFDEPTH_SHIFT 8 /* Buffer colour depth. */ -#define BUFMODE_BUFTYPE_SHIFT 10 /* Source or destination. */ - -/* Status Registers. */ -#define RE_PP_STATUS 0x00004000 -#define RE_PP_STATUS_IDLE 0x10000000 -#define RE_PP_STATUS_READY 0x02000000 - -/* - * Rendering Engine Constants. - */ - -#define COLOUR_DEPTH_8 0x0 -#define COLOUR_DEPTH_16 0x1 -#define COLOUR_DEPTH_32 0x2 - -#define PIXEL_TYPE_CI 0x0 -#define PIXEL_TYPE_RGB 0x1 -#define PIXEL_TYPE_RGBA 0x2 -#define PIXEL_TYPE_ABGR 0x3 - -#define BUF_TYPE_TLB_A 0x0 -#define BUF_TYPE_TLB_B 0x1 -#define BUF_TYPE_TLB_C 0x2 -#define BUF_TYPE_LINEAR_A 0x4 -#define BUF_TYPE_LINEAR_B 0x5 - -/* - * Console functions. - */ -int gbe_cnprobe(bus_space_tag_t, bus_addr_t addr); -int gbe_cnattach(bus_space_tag_t, bus_addr_t addr); diff --git a/sys/arch/sgi/dev/gl.h b/sys/arch/sgi/dev/gl.h deleted file mode 100644 index 9cbf88cc12b..00000000000 --- a/sys/arch/sgi/dev/gl.h +++ /dev/null @@ -1,39 +0,0 @@ -/* $OpenBSD: gl.h,v 1.1 2012/04/16 22:17:13 miod Exp $ */ -/* - * Copyright (c) 2009, 2010 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * OpenGL defines - */ - -/* Logic Operations. */ -#define OPENGL_LOGIC_OP_CLEAR 0 -#define OPENGL_LOGIC_OP_AND 1 -#define OPENGL_LOGIC_OP_AND_REVERSE 2 -#define OPENGL_LOGIC_OP_COPY 3 -#define OPENGL_LOGIC_OP_AND_INVERTED 4 -#define OPENGL_LOGIC_OP_NOOP 5 -#define OPENGL_LOGIC_OP_XOR 6 -#define OPENGL_LOGIC_OP_OR 7 -#define OPENGL_LOGIC_OP_NOR 8 -#define OPENGL_LOGIC_OP_EQUIV 9 -#define OPENGL_LOGIC_OP_INVERT 10 -#define OPENGL_LOGIC_OP_OR_REVERSE 11 -#define OPENGL_LOGIC_OP_COPY_INVERTED 12 -#define OPENGL_LOGIC_OP_OR_INVERTED 13 -#define OPENGL_LOGIC_OP_NAND 14 -#define OPENGL_LOGIC_OP_SET 15 - diff --git a/sys/arch/sgi/dev/if_iec.c b/sys/arch/sgi/dev/if_iec.c deleted file mode 100644 index 44c58f42de8..00000000000 --- a/sys/arch/sgi/dev/if_iec.c +++ /dev/null @@ -1,1401 +0,0 @@ -/* $OpenBSD: if_iec.c,v 1.27 2020/07/10 13:26:36 patrick Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Heavily based upon if_mec.c with the following license terms: - * - * OpenBSD: if_mec.c,v 1.22 2009/10/26 18:00:06 miod Exp - * - * Copyright (c) 2004 Izumi Tsutsui. - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * Copyright (c) 2003 Christopher SEKIYA - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * IOC3 Ethernet driver - */ - -#include "bpfilter.h" - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/timeout.h> -#include <sys/mbuf.h> -#include <sys/malloc.h> -#include <sys/kernel.h> -#include <sys/socket.h> -#include <sys/ioctl.h> -#include <sys/errno.h> - -#include <net/if.h> -#include <net/if_media.h> - -#if NBPFILTER > 0 -#include <net/bpf.h> -#endif - -#include <netinet/in.h> -#include <netinet/if_ether.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/intr.h> - -#include <dev/mii/mii.h> -#include <dev/mii/miivar.h> - -#include <sgi/dev/if_iecreg.h> -#include <sgi/dev/owmacvar.h> -#include <sgi/pci/iocreg.h> -#include <sgi/pci/iocvar.h> - -#ifdef IEC_DEBUG -#define IEC_DEBUG_RESET 0x01 -#define IEC_DEBUG_START 0x02 -#define IEC_DEBUG_STOP 0x04 -#define IEC_DEBUG_INTR 0x08 -#define IEC_DEBUG_RXINTR 0x10 -#define IEC_DEBUG_TXINTR 0x20 -#define IEC_DEBUG_MII 0x40 -uint32_t iec_debug = 0xffffffff; -#define DPRINTF(x, y) if (iec_debug & (x)) printf y -#else -#define DPRINTF(x, y) /* nothing */ -#endif - -/* - * Transmit descriptor list size. - */ -#define IEC_NTXDESC IEC_NTXDESC_MAX -#define IEC_NEXTTX(x) (((x) + 1) % IEC_NTXDESC_MAX) - -/* - * Software state for TX. - */ -struct iec_txsoft { - struct mbuf *txs_mbuf; /* Head of our mbuf chain. */ - bus_dmamap_t txs_dmamap; /* Our DMA map. */ - uint32_t txs_flags; -}; - -/* - * Receive buffer management. - * - * The RX buffers chip register points to a contiguous array of - * 512 8-bit pointers to the RX buffers themselves. - */ - -/* - * Receive descriptor list sizes (these depend on the size of the SSRAM). - */ -#define IEC_NRXDESC_SMALL 64 -#define IEC_NRXDESC_LARGE 128 - -/* - * In addition to the receive descriptor themselves, we'll need an array - * of 512 RX descriptor pointers (regardless of how many real descriptors - * we use), aligned on a 4KB boundary. - */ - -/* - * Control structures for DMA ops. - */ -struct iec_control_data { - /* - * TX descriptors and buffers. - */ - struct iec_txdesc icd_txdesc[IEC_NTXDESC_MAX]; - - /* - * RX descriptors and buffers. - */ - struct iec_rxdesc icd_rxdesc[1]; -}; - -/* - * Alignment restrictions (found by trial and error, might be slightly - * pessimistic). - * - base address of rx desc pointer array should be aligned on a - * 16KB boundary. - * - base address of rx and tx desc array should be aligned on - * 16KB boundaries (note layout of struct iec_control_data makes sure - * the rx desc array starts 16KB after the tx desc array). - * - each txdesc should be 128 byte aligned (this is also enforced by - * struct iec_control_data layout). - * - each rxdesc should be aligned on a 4KB boundary (this is enforced by - * struct iec_control_data and struct icd_rxdesc layouts). - */ -#define IEC_DMA_BOUNDARY 0x4000 - -#define IEC_CDOFF(x) offsetof(struct iec_control_data, x) -#define IEC_CDTXOFF(x) IEC_CDOFF(icd_txdesc[(x)]) -#define IEC_CDRXOFF(x) IEC_CDOFF(icd_rxdesc[(x)]) - -/* - * Software state per device. - */ -struct iec_softc { - struct device sc_dev; /* Generic device structures. */ - struct arpcom sc_ac; /* Ethernet common part. */ - - bus_space_tag_t sc_st; /* bus_space tag. */ - bus_space_handle_t sc_sh; /* bus_space handle. */ - bus_dma_tag_t sc_dmat; /* bus_dma tag. */ - - struct mii_data sc_mii; /* MII/media information. */ - int sc_phyaddr; /* MII address. */ - struct timeout sc_tick; /* Tick timeout. */ - - uint64_t *sc_rxarr; /* kva for rx pointers array. */ - bus_dmamap_t sc_rxarrmap; /* bus_dma map for rx pointers array. */ -#define sc_rxptrdma sc_rxarrmap->dm_segs[0].ds_addr - - bus_dmamap_t sc_cddmamap; /* bus_dma map for control data. */ -#define sc_cddma sc_cddmamap->dm_segs[0].ds_addr - - /* Pointer to allocated control data. */ - struct iec_control_data *sc_control_data; -#define sc_txdesc sc_control_data->icd_txdesc -#define sc_rxdesc sc_control_data->icd_rxdesc - - /* Software state for TX descs. */ - struct iec_txsoft sc_txsoft[IEC_NTXDESC]; - - int sc_txpending; /* Number of TX requests pending. */ - int sc_txdirty; /* First dirty TX descriptor. */ - int sc_txlast; /* Last used TX descriptor. */ - - uint32_t sc_rxci; /* Saved RX consumer index. */ - uint32_t sc_rxpi; /* Saved RX producer index. */ - uint32_t sc_nrxdesc; /* Amount of RX descriptors. */ - - uint32_t sc_mcr; /* Current MCR value. */ -}; - -#define IEC_CDTXADDR(sc, x) ((sc)->sc_cddma + IEC_CDTXOFF(x)) -#define IEC_CDRXADDR(sc, x) ((sc)->sc_cddma + IEC_CDRXOFF(x)) - -#define IEC_TXDESCSYNC(sc, x, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - IEC_CDTXOFF(x), IEC_TXDESCSIZE, (ops)) -#define IEC_TXCMDSYNC(sc, x, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - IEC_CDTXOFF(x), 2 * sizeof(uint32_t), (ops)) - -#define IEC_RXSTATSYNC(sc, x, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - IEC_CDRXOFF(x), 2 * sizeof(uint32_t), (ops)) -#define IEC_RXBUFSYNC(sc, x, len, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - IEC_CDRXOFF(x) + IEC_RXD_BUFOFFSET, (len), (ops)) - -/* XXX these values should be moved to <net/if_ether.h> ? */ -#define ETHER_PAD_LEN (ETHER_MIN_LEN - ETHER_CRC_LEN) - -struct cfdriver iec_cd = { - NULL, "iec", DV_IFNET -}; - -#define DEVNAME(sc) ((sc)->sc_dev.dv_xname) - -int iec_match(struct device *, void *, void *); -void iec_attach(struct device *, struct device *, void *); - -struct cfattach iec_ca = { - sizeof(struct iec_softc), iec_match, iec_attach -}; - -int iec_mii_readreg(struct device *, int, int); -void iec_mii_writereg(struct device *, int, int, int); -int iec_mii_wait(struct iec_softc *); -void iec_statchg(struct device *); -void iec_mediastatus(struct ifnet *, struct ifmediareq *); -int iec_mediachange(struct ifnet *); - -int iec_alloc_physical(struct iec_softc *, bus_dmamap_t *, - bus_dma_segment_t *, vaddr_t *, bus_addr_t, bus_size_t, - const char *); -struct mbuf * - iec_get(struct iec_softc *, uint8_t *, size_t); -void iec_iff(struct iec_softc *); -int iec_init(struct ifnet * ifp); -int iec_intr(void *arg); -int iec_ioctl(struct ifnet *, u_long, caddr_t); -void iec_reset(struct iec_softc *); -void iec_rxintr(struct iec_softc *, uint32_t); -int iec_ssram_probe(struct iec_softc *); -void iec_start(struct ifnet *); -void iec_stop(struct ifnet *); -void iec_tick(void *); -void iec_txintr(struct iec_softc *, uint32_t); -void iec_watchdog(struct ifnet *); - -int -iec_match(struct device *parent, void *match, void *aux) -{ - /* - * We expect ioc NOT to attach us on if there is no Ethernet - * component. - */ - return 1; -} - -void -iec_attach(struct device *parent, struct device *self, void *aux) -{ - struct iec_softc *sc = (void *)self; - struct ioc_attach_args *iaa = aux; - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct mii_softc *child; - bus_dma_segment_t seg1; - bus_dma_segment_t seg2; - bus_size_t control_size; - int i, rc; - - sc->sc_st = iaa->iaa_memt; - sc->sc_sh = iaa->iaa_memh; - sc->sc_dmat = iaa->iaa_dmat; - - /* - * Try and figure out how much SSRAM is available, and decide - * how many RX buffers to use. - */ - i = iec_ssram_probe(sc); - printf(": %dKB SSRAM", i); - - /* - * Allocate a page for RX descriptor pointers, suitable for use - * by the device. - */ - rc = iec_alloc_physical(sc, &sc->sc_rxarrmap, &seg1, - (vaddr_t *)&sc->sc_rxarr, IEC_DMA_BOUNDARY, - IEC_NRXDESC_MAX * sizeof(uint64_t), "rxdesc pointer array"); - if (rc != 0) - return; - - /* - * Allocate the RX and TX descriptors. - */ - control_size = IEC_NTXDESC_MAX * sizeof(struct iec_txdesc) + - sc->sc_nrxdesc * sizeof(struct iec_rxdesc); - rc = iec_alloc_physical(sc, &sc->sc_cddmamap, &seg2, - (vaddr_t *)&sc->sc_control_data, IEC_DMA_BOUNDARY, - control_size, "rx and tx descriptors"); - if (rc != 0) - goto fail_1; - - /* - * Initialize RX pointer array. - */ - - for (i = 0; i < IEC_NRXDESC_MAX; i++) - sc->sc_rxarr[i] = IEC_CDRXADDR(sc, i & (sc->sc_nrxdesc - 1)); - - /* Create TX buffer DMA maps. */ - for (i = 0; i < IEC_NTXDESC; i++) { - if ((rc = bus_dmamap_create(sc->sc_dmat, - MCLBYTES, 1, MCLBYTES, 0, 0, - &sc->sc_txsoft[i].txs_dmamap)) != 0) { - printf(": unable to create tx DMA map %d, error = %d\n", - i, rc); - goto fail_4; - } - } - - timeout_set(&sc->sc_tick, iec_tick, sc); - - bcopy(iaa->iaa_enaddr, sc->sc_ac.ac_enaddr, ETHER_ADDR_LEN); - printf(", address %s\n", ether_sprintf(sc->sc_ac.ac_enaddr)); - - /* Reset device. */ - iec_reset(sc); - - /* Done, now attach everything. */ - - sc->sc_mii.mii_ifp = ifp; - sc->sc_mii.mii_readreg = iec_mii_readreg; - sc->sc_mii.mii_writereg = iec_mii_writereg; - sc->sc_mii.mii_statchg = iec_statchg; - - /* Set up PHY properties. */ - ifmedia_init(&sc->sc_mii.mii_media, 0, iec_mediachange, - iec_mediastatus); - mii_attach(&sc->sc_dev, &sc->sc_mii, 0xffffffff, MII_PHY_ANY, - MII_OFFSET_ANY, 0); - - child = LIST_FIRST(&sc->sc_mii.mii_phys); - if (child == NULL) { - /* No PHY attached. */ - ifmedia_add(&sc->sc_mii.mii_media, IFM_ETHER | IFM_MANUAL, - 0, NULL); - ifmedia_set(&sc->sc_mii.mii_media, IFM_ETHER | IFM_MANUAL); - } else { - ifmedia_set(&sc->sc_mii.mii_media, IFM_ETHER | IFM_AUTO); - sc->sc_phyaddr = child->mii_phy; - } - - bcopy(sc->sc_dev.dv_xname, ifp->if_xname, IFNAMSIZ); - ifp->if_softc = sc; - ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; - ifp->if_ioctl = iec_ioctl; - ifp->if_start = iec_start; - ifp->if_watchdog = iec_watchdog; - - if_attach(ifp); - ifq_set_maxlen(&ifp->if_snd, IEC_NTXDESC - 1); - ether_ifattach(ifp); - - /* Establish interrupt handler. */ - ioc_intr_establish(parent, iaa->iaa_dev, IPL_NET, - iec_intr, sc, sc->sc_dev.dv_xname); - - return; - - /* - * Free any resources we've allocated during the failed attach - * attempt. Do this in reverse order and fall through. - */ -fail_4: - for (i = 0; i < IEC_NTXDESC; i++) { - if (sc->sc_txsoft[i].txs_dmamap != NULL) - bus_dmamap_destroy(sc->sc_dmat, - sc->sc_txsoft[i].txs_dmamap); - } - - bus_dmamap_unload(sc->sc_dmat, sc->sc_cddmamap); - bus_dmamap_destroy(sc->sc_dmat, sc->sc_cddmamap); - bus_dmamem_unmap(sc->sc_dmat, (caddr_t)sc->sc_control_data, - control_size); - bus_dmamem_free(sc->sc_dmat, &seg2, 1); -fail_1: - bus_dmamap_unload(sc->sc_dmat, sc->sc_rxarrmap); - bus_dmamap_destroy(sc->sc_dmat, sc->sc_rxarrmap); - bus_dmamem_unmap(sc->sc_dmat, (caddr_t)sc->sc_rxarr, - IEC_NRXDESC_MAX * sizeof(uint64_t)); - bus_dmamem_free(sc->sc_dmat, &seg1, 1); -} - -/* - * Allocate contiguous physical memory. - */ -int -iec_alloc_physical(struct iec_softc *sc, bus_dmamap_t *dmamap, - bus_dma_segment_t *dmaseg, vaddr_t *va, bus_addr_t alignment, - bus_size_t len, const char *what) -{ - int nseg; - int rc; - - rc = bus_dmamem_alloc(sc->sc_dmat, len, alignment, 0, dmaseg, 1, &nseg, - BUS_DMA_NOWAIT); - if (rc != 0) { - printf("%s: unable to allocate %s memory: error %d\n", - DEVNAME(sc), what, rc); - goto fail1; - } - - rc = bus_dmamem_map(sc->sc_dmat, dmaseg, nseg, len, - (caddr_t *)va, BUS_DMA_NOWAIT | BUS_DMA_COHERENT); - if (rc != 0) { - printf("%s: unable to map %s memory: error %d\n", - DEVNAME(sc), what, rc); - goto fail2; - } - - rc = bus_dmamap_create(sc->sc_dmat, len, 1, len, 0, BUS_DMA_NOWAIT, - dmamap); - if (rc != 0) { - printf("%s: unable to create %s dma map: error %d\n", - DEVNAME(sc), what, rc); - goto fail3; - } - - rc = bus_dmamap_load(sc->sc_dmat, *dmamap, (void *)*va, len, NULL, - BUS_DMA_NOWAIT); - if (rc != 0) { - printf("%s: unable to load %s dma map: error %d\n", - DEVNAME(sc), what, rc); - goto fail4; - } - - memset((caddr_t)*va, 0, len); - return 0; - -fail4: - bus_dmamap_destroy(sc->sc_dmat, *dmamap); -fail3: - bus_dmamem_unmap(sc->sc_dmat, (caddr_t)*va, len); -fail2: - bus_dmamem_free(sc->sc_dmat, dmaseg, 1); -fail1: - return rc; -} - -int -iec_mii_readreg(struct device *self, int phy, int reg) -{ - struct iec_softc *sc = (void *)self; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - - if (iec_mii_wait(sc) != 0) - return 0; - - bus_space_write_4(st, sh, IOC3_ENET_MICR, IOC3_ENET_MICR_READ | - (phy << IOC3_ENET_MICR_PHY_SHIFT) | - (reg & IOC3_ENET_MICR_REG_MASK)); - delay(25); - - if (iec_mii_wait(sc) == 0) - return bus_space_read_4(st, sh, IOC3_ENET_MIDR_R) & - IOC3_ENET_MIDR_MASK; - - DPRINTF(IEC_DEBUG_MII, ("MII timed out reading %x\n", reg)); - return 0; -} - -void -iec_mii_writereg(struct device *self, int phy, int reg, int val) -{ - struct iec_softc *sc = (void *)self; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - - if (iec_mii_wait(sc) != 0) { - DPRINTF(IEC_DEBUG_MII, - ("MII timed out writing %x: %x\n", reg, val)); - return; - } - - bus_space_write_4(st, sh, IOC3_ENET_MIDR_W, val & IOC3_ENET_MIDR_MASK); - delay(60); - bus_space_write_4(st, sh, IOC3_ENET_MICR, - (phy << IOC3_ENET_MICR_PHY_SHIFT) | - (reg & IOC3_ENET_MICR_REG_MASK)); - delay(60); - - iec_mii_wait(sc); -} - -int -iec_mii_wait(struct iec_softc *sc) -{ - uint32_t busy; - int i; - - for (i = 0; i < 100; i++) { - busy = bus_space_read_4(sc->sc_st, sc->sc_sh, IOC3_ENET_MICR); - if ((busy & IOC3_ENET_MICR_BUSY) == 0) - return 0; - delay(30); - } - - printf("%s: MII timed out\n", sc->sc_dev.dv_xname); - return 1; -} - -void -iec_statchg(struct device *self) -{ - struct iec_softc *sc = (void *)self; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint32_t tcsr; - - if ((sc->sc_mii.mii_media_active & IFM_FDX) != 0) { - tcsr = IOC3_ENET_TCSR_FULL_DUPLEX; - sc->sc_mcr |= IOC3_ENET_MCR_DUPLEX; - } else { - tcsr = IOC3_ENET_TCSR_HALF_DUPLEX; - sc->sc_mcr &= ~IOC3_ENET_MCR_DUPLEX; - } - - bus_space_write_4(st, sh, IOC3_ENET_MCR, sc->sc_mcr); - bus_space_write_4(st, sh, IOC3_ENET_TCSR, tcsr); -} - -void -iec_mediastatus(struct ifnet *ifp, struct ifmediareq *ifmr) -{ - struct iec_softc *sc = ifp->if_softc; - - if ((ifp->if_flags & IFF_UP) == 0) - return; - - mii_pollstat(&sc->sc_mii); - ifmr->ifm_status = sc->sc_mii.mii_media_status; - ifmr->ifm_active = sc->sc_mii.mii_media_active; -} - -int -iec_mediachange(struct ifnet *ifp) -{ - struct iec_softc *sc = ifp->if_softc; - - if ((ifp->if_flags & IFF_UP) == 0) - return 0; - - return mii_mediachg(&sc->sc_mii); -} - -int -iec_init(struct ifnet *ifp) -{ - struct iec_softc *sc = ifp->if_softc; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - struct iec_rxdesc *rxd; - int i; - - /* Cancel any pending I/O. */ - iec_stop(ifp); - - /* Reset device. */ - iec_reset(sc); - - /* Setup filter for multicast or promisc mode. */ - iec_iff(sc); - - /* - * Initialize TX ring. - */ - - bus_space_write_4(st, sh, IOC3_ENET_TBR_H, IEC_CDTXADDR(sc, 0) >> 32); - bus_space_write_4(st, sh, IOC3_ENET_TBR_L, - (uint32_t)IEC_CDTXADDR(sc, 0)); - bus_space_write_4(st, sh, IOC3_ENET_TCIR, 0); - bus_space_write_4(st, sh, IOC3_ENET_TPIR, 0); - (void)bus_space_read_4(st, sh, IOC3_ENET_TCIR); - - sc->sc_txpending = 0; - sc->sc_txdirty = 0; - sc->sc_txlast = IEC_NTXDESC - 1; - - /* - * Initialize RX ring. - */ - - /* Point the RX base register to our RX pointers array. */ - bus_space_write_4(st, sh, IOC3_ENET_RBR_H, sc->sc_rxptrdma >> 32); - bus_space_write_4(st, sh, IOC3_ENET_RBR_L, (uint32_t)sc->sc_rxptrdma); - - sc->sc_rxci = 0; - sc->sc_rxpi = sc->sc_nrxdesc + 1; - bus_space_write_4(st, sh, IOC3_ENET_RCIR, - sc->sc_rxci * sizeof(uint64_t)); - bus_space_write_4(st, sh, IOC3_ENET_RPIR, - (sc->sc_rxpi * sizeof(uint64_t)) | IOC3_ENET_PIR_SET); - - /* Interrupt as soon as available RX desc reach this limit */ - bus_space_write_4(st, sh, IOC3_ENET_RCSR, - sc->sc_rxpi - sc->sc_rxci - 1); - /* Set up RX timer to interrupt immediately upon reception. */ - bus_space_write_4(st, sh, IOC3_ENET_RTR, 0); - - /* Initialize RX buffers. */ - for (i = 0; i < sc->sc_nrxdesc; i++) { - rxd = &sc->sc_rxdesc[i]; - rxd->rxd_stat = 0; - IEC_RXSTATSYNC(sc, i, BUS_DMASYNC_PREREAD); - IEC_RXBUFSYNC(sc, i, ETHER_MAX_LEN, BUS_DMASYNC_PREREAD); - } - - /* Enable DMA, and RX and TX interrupts */ - sc->sc_mcr &= IOC3_ENET_MCR_LARGE_SSRAM | IOC3_ENET_MCR_PARITY_ENABLE | - IOC3_ENET_MCR_PADEN; - sc->sc_mcr |= IOC3_ENET_MCR_TX_DMA | IOC3_ENET_MCR_TX | - IOC3_ENET_MCR_RX_DMA | IOC3_ENET_MCR_RX | - ((IEC_RXD_BUFOFFSET >> 1) << IOC3_ENET_MCR_RXOFF_SHIFT); - bus_space_write_4(st, sh, IOC3_ENET_MCR, sc->sc_mcr); - bus_space_write_4(st, sh, IOC3_ENET_IER, - IOC3_ENET_ISR_RX_TIMER | IOC3_ENET_ISR_RX_THRESHOLD | - (IOC3_ENET_ISR_TX_ALL & ~IOC3_ENET_ISR_TX_EMPTY)); - (void)bus_space_read_4(st, sh, IOC3_ENET_IER); - - timeout_add_sec(&sc->sc_tick, 1); - - ifp->if_flags |= IFF_RUNNING; - ifq_clr_oactive(&ifp->if_snd); - - iec_start(ifp); - - mii_mediachg(&sc->sc_mii); - - return 0; -} - -void -iec_reset(struct iec_softc *sc) -{ - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint64_t address; - int i; - - DPRINTF(IEC_DEBUG_RESET, ("iec_reset\n")); - - /* Reset chip. */ - bus_space_write_4(st, sh, IOC3_ENET_MCR, IOC3_ENET_MCR_RESET); - delay(1000); - bus_space_write_4(st, sh, IOC3_ENET_MCR, 0); - delay(1000); - - bus_space_write_4(st, sh, IOC3_ENET_RBAR, 0); - - /* Set Ethernet address. */ - address = 0; - for (i = 0; i < ETHER_ADDR_LEN; i++) { - address <<= 8; - address += sc->sc_ac.ac_enaddr[ETHER_ADDR_LEN - 1 - i]; - } - bus_space_write_4(st, sh, IOC3_ENET_MAR_H, address >> 32); - bus_space_write_4(st, sh, IOC3_ENET_MAR_L, (uint32_t)address); - - /* Default to 100/half and let auto-negotiation work its magic. */ - bus_space_write_4(st, sh, IOC3_ENET_TCSR, IOC3_ENET_TCSR_HALF_DUPLEX); - - /* Reset collisions counter */ - (void)bus_space_read_4(st, sh, IOC3_ENET_TCDC); - - bus_space_write_4(st, sh, IOC3_ENET_RSR, 0x4d696f64); - - bus_space_write_4(st, sh, IOC3_ENET_HAR_H, 0); - bus_space_write_4(st, sh, IOC3_ENET_HAR_L, 0); -} - -void -iec_start(struct ifnet *ifp) -{ - struct iec_softc *sc = ifp->if_softc; - struct mbuf *m0; - struct iec_txdesc *txd; - struct iec_txsoft *txs; - bus_dmamap_t dmamap; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint64_t txdaddr; - int error, firstdirty, nexttx, opending; - int len; - - if (!(ifp->if_flags & IFF_RUNNING) || ifq_is_oactive(&ifp->if_snd)) - return; - - /* - * Remember the previous txpending and the first transmit descriptor. - */ - opending = sc->sc_txpending; - firstdirty = IEC_NEXTTX(sc->sc_txlast); - - DPRINTF(IEC_DEBUG_START, ("iec_start: opending = %d, firstdirty = %d\n", - opending, firstdirty)); - - while (sc->sc_txpending < IEC_NTXDESC - 1) { - /* Grab a packet off the queue. */ - m0 = ifq_dequeue(&ifp->if_snd); - if (m0 == NULL) - break; - - /* - * Get the next available transmit descriptor. - */ - nexttx = IEC_NEXTTX(sc->sc_txlast); - txd = &sc->sc_txdesc[nexttx]; - txs = &sc->sc_txsoft[nexttx]; - - len = m0->m_pkthdr.len; - - DPRINTF(IEC_DEBUG_START, - ("iec_start: len = %d, nexttx = %d\n", len, nexttx)); - - if (len <= IEC_TXD_BUFSIZE) { - /* - * If the packet is small enough, - * just copy it to the buffer in txdesc and - * pad with zeroes. - */ - DPRINTF(IEC_DEBUG_START, ("iec_start: short packet\n")); - - m_copydata(m0, 0, m0->m_pkthdr.len, txd->txd_buf); - if (len < ETHER_PAD_LEN) { - /* - * XXX would IOC3_ENET_MCR_PADEN in MCR do this - * XXX for us? - */ - memset(txd->txd_buf + len, 0, - ETHER_PAD_LEN - len); - len = ETHER_PAD_LEN; - } - - txs->txs_flags = IEC_TXCMD_BUF_V; - } else { - /* - * Although the packet may fit in the txdesc - * itself, we do not make use of this option, - * and use the two data pointers to handle it. - * There are two pointers because each chunk must - * not cross a 16KB boundary. - */ - dmamap = txs->txs_dmamap; - if (bus_dmamap_load_mbuf(sc->sc_dmat, dmamap, m0, - BUS_DMA_WRITE | BUS_DMA_NOWAIT) != 0) { - struct mbuf *m; - - DPRINTF(IEC_DEBUG_START, - ("iec_start: re-allocating mbuf\n")); - MGETHDR(m, M_DONTWAIT, MT_DATA); - if (m == NULL) { - printf("%s: unable to allocate " - "TX mbuf\n", sc->sc_dev.dv_xname); - break; - } - if (len > (MHLEN - ETHER_ALIGN)) { - MCLGET(m, M_DONTWAIT); - if ((m->m_flags & M_EXT) == 0) { - printf("%s: unable to allocate " - "TX cluster\n", - sc->sc_dev.dv_xname); - m_freem(m); - break; - } - } - /* - * Each packet has the Ethernet header, so - * in many cases the header isn't 4-byte aligned - * and data after the header is 4-byte aligned. - * Thus adding 2-byte offset before copying to - * new mbuf avoids unaligned copy and this may - * improve performance. - */ - m->m_data += ETHER_ALIGN; - m_copydata(m0, 0, len, mtod(m, caddr_t)); - m->m_pkthdr.len = m->m_len = len; - m_freem(m0); - m0 = m; - error = bus_dmamap_load_mbuf(sc->sc_dmat, - dmamap, m, BUS_DMA_WRITE | BUS_DMA_NOWAIT); - if (error) { - printf("%s: unable to load TX buffer, " - "error = %d\n", - sc->sc_dev.dv_xname, error); - m_freem(m); - break; - } - } - - txdaddr = dmamap->dm_segs[0].ds_addr; - txs->txs_flags = IEC_TXCMD_PTR0_V; - DPRINTF(IEC_DEBUG_START, - ("iec_start: ds_addr = %p\n", - dmamap->dm_segs[0].ds_addr)); - - DPRINTF(IEC_DEBUG_START, - ("iec_start: txdaddr = %p, len = %d\n", - txdaddr, len)); - - /* - * Sync the DMA map for TX mbuf. - * - * XXX unaligned part doesn't have to be sync'ed, - * but it's harmless... - */ - bus_dmamap_sync(sc->sc_dmat, dmamap, 0, - dmamap->dm_mapsize, BUS_DMASYNC_PREWRITE); - } - -#if NBPFILTER > 0 - /* - * Pass packet to bpf if there is a listener. - */ - if (ifp->if_bpf) - bpf_mtap(ifp->if_bpf, m0, BPF_DIRECTION_OUT); -#endif - - /* - * Setup the transmit descriptor. - * Since there is apparently no way to get status - * information in the TX descriptor after we issue - * it, we have to always ask for interrupts upon - * completion, so that if we get a TX error interrupt, - * we know which descriptor it applies to. - */ - - txd->txd_cmd = IEC_TXCMD_TXINT | txs->txs_flags | - (len & IEC_TXCMD_DATALEN); - - if (txs->txs_flags & IEC_TXCMD_PTR0_V) { - uint32_t r1, r2; - - /* - * The chip DMA engine can not cross 16KB boundaries. - * If our mbuf doesn't fit, use the second pointer. - */ - - r1 = IEC_DMA_BOUNDARY - - (txdaddr & (IEC_DMA_BOUNDARY - 1)); - if (r1 >= len) { - /* only one chunk is necessary */ - r1 = len; - r2 = 0; - } else - r2 = len - r1; - - txd->txd_ptr[0] = txdaddr; - if (r2 != 0) { - txs->txs_flags |= IEC_TXCMD_PTR1_V; - txd->txd_ptr[1] = txdaddr + r1; - } else - txd->txd_ptr[1] = 0; - txd->txd_len = (r1 << IECTX_BUF1_LEN_SHIFT) | - (r2 << IECTX_BUF2_LEN_SHIFT); - - /* - * Store a pointer to the packet so we can - * free it later. - */ - txs->txs_mbuf = m0; - } else { - txd->txd_len = len << IECTX_BUF0_LEN_SHIFT; - txd->txd_ptr[0] = 0; - txd->txd_ptr[1] = 0; - /* - * In this case all data are copied to buffer in txdesc, - * we can free TX mbuf here. - */ - m_freem(m0); - } - - DPRINTF(IEC_DEBUG_START, - ("iec_start: txd_cmd = 0x%08x, txd_ptr = %p\n", - txd->txd_cmd, txd->txd_ptr[0])); - DPRINTF(IEC_DEBUG_START, - ("iec_start: len = %d (0x%04x)\n", len, len)); - - /* Sync TX descriptor. */ - IEC_TXDESCSYNC(sc, nexttx, - BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE); - - /* Advance the TX pointer. */ - sc->sc_txpending++; - sc->sc_txlast = nexttx; - } - - if (sc->sc_txpending >= IEC_NTXDESC - 1) { - /* No more slots; notify upper layer. */ - ifq_set_oactive(&ifp->if_snd); - } - - if (sc->sc_txpending != opending) { - /* Start TX. */ - bus_space_write_4(st, sh, IOC3_ENET_TPIR, - IEC_NEXTTX(sc->sc_txlast) * IEC_TXDESCSIZE); - - /* - * If the transmitter was idle, - * reset the txdirty pointer and re-enable TX interrupt. - */ - if (opending == 0) { - sc->sc_txdirty = firstdirty; - bus_space_write_4(st, sh, IOC3_ENET_IER, - bus_space_read_4(st, sh, IOC3_ENET_IER) | - IOC3_ENET_ISR_TX_EMPTY); - (void)bus_space_read_4(st, sh, IOC3_ENET_IER); - } - - /* Set a watchdog timer in case the chip flakes out. */ - ifp->if_timer = 5; - } -} - -void -iec_stop(struct ifnet *ifp) -{ - struct iec_softc *sc = ifp->if_softc; - struct iec_txsoft *txs; - int i; - - DPRINTF(IEC_DEBUG_STOP, ("iec_stop\n")); - - ifp->if_timer = 0; - ifp->if_flags &= ~IFF_RUNNING; - ifq_clr_oactive(&ifp->if_snd); - - timeout_del(&sc->sc_tick); - mii_down(&sc->sc_mii); - - /* Disable DMA and interrupts. */ - sc->sc_mcr &= ~(IOC3_ENET_MCR_TX_DMA | IOC3_ENET_MCR_RX_DMA); - bus_space_write_4(sc->sc_st, sc->sc_sh, IOC3_ENET_MCR, sc->sc_mcr); - bus_space_write_4(sc->sc_st, sc->sc_sh, IOC3_ENET_IER, 0); - (void)bus_space_read_4(sc->sc_st, sc->sc_sh, IOC3_ENET_IER); - - /* Release any TX buffers. */ - for (i = 0; i < IEC_NTXDESC; i++) { - txs = &sc->sc_txsoft[i]; - if ((txs->txs_flags & IEC_TXCMD_PTR0_V) != 0) { - bus_dmamap_unload(sc->sc_dmat, txs->txs_dmamap); - m_freem(txs->txs_mbuf); - txs->txs_mbuf = NULL; - } - } -} - -int -iec_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) -{ - struct iec_softc *sc = ifp->if_softc; - struct ifreq *ifr = (struct ifreq *)data; - int s, error = 0; - - s = splnet(); - - switch (cmd) { - case SIOCSIFADDR: - ifp->if_flags |= IFF_UP; - if (!(ifp->if_flags & IFF_RUNNING)) - iec_init(ifp); - break; - - case SIOCSIFFLAGS: - if (ifp->if_flags & IFF_UP) { - if (ifp->if_flags & IFF_RUNNING) - error = ENETRESET; - else - iec_init(ifp); - } else { - if (ifp->if_flags & IFF_RUNNING) - iec_stop(ifp); - } - break; - - case SIOCSIFMEDIA: - case SIOCGIFMEDIA: - error = ifmedia_ioctl(ifp, ifr, &sc->sc_mii.mii_media, cmd); - break; - - default: - error = ether_ioctl(ifp, &sc->sc_ac, cmd, data); - } - - if (error == ENETRESET) { - if (ifp->if_flags & IFF_RUNNING) - iec_iff(sc); - error = 0; - } - - splx(s); - return error; -} - -void -iec_watchdog(struct ifnet *ifp) -{ - struct iec_softc *sc = ifp->if_softc; - - printf("%s: device timeout\n", sc->sc_dev.dv_xname); - ifp->if_oerrors++; - - DPRINTF(IEC_DEBUG_INTR, ("iec_watchdog: ISR %08x IER %08x\n", - bus_space_read_4(sc->sc_st, sc->sc_sh, IOC3_ENET_ISR), - bus_space_read_4(sc->sc_st, sc->sc_sh, IOC3_ENET_IER))); - - iec_init(ifp); -} - -void -iec_tick(void *arg) -{ - struct iec_softc *sc = arg; - int s; - - s = splnet(); - mii_tick(&sc->sc_mii); - splx(s); - - timeout_add_sec(&sc->sc_tick, 1); -} - -void -iec_iff(struct iec_softc *sc) -{ - struct arpcom *ac = &sc->sc_ac; - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct ether_multi *enm; - struct ether_multistep step; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint64_t mchash = 0; - uint32_t hash; - - sc->sc_mcr &= ~IOC3_ENET_MCR_PROMISC; - ifp->if_flags &= ~IFF_ALLMULTI; - - if (ifp->if_flags & IFF_PROMISC || ac->ac_multirangecnt > 0) { - ifp->if_flags |= IFF_ALLMULTI; - if (ifp->if_flags & IFF_PROMISC) - sc->sc_mcr |= IOC3_ENET_MCR_PROMISC; - mchash = 0xffffffffffffffffULL; - } else { - ETHER_FIRST_MULTI(step, ac, enm); - while (enm != NULL) { - hash = ether_crc32_be(enm->enm_addrlo, - ETHER_ADDR_LEN) >> 26; - - mchash |= 1 << hash; - - ETHER_NEXT_MULTI(step, enm); - } - } - - bus_space_write_4(st, sh, IOC3_ENET_HAR_H, mchash >> 32); - bus_space_write_4(st, sh, IOC3_ENET_HAR_L, (uint32_t)mchash); - bus_space_write_4(st, sh, IOC3_ENET_MCR, sc->sc_mcr); -} - -struct mbuf * -iec_get(struct iec_softc *sc, uint8_t *data, size_t datalen) -{ - struct mbuf *m, **mp, *head; - size_t len, pad; - - MGETHDR(m, M_DONTWAIT, MT_DATA); - if (m == NULL) { - printf("%s: unable to allocate RX mbuf\n", - sc->sc_dev.dv_xname); - return NULL; - } - - m->m_pkthdr.len = datalen; - - pad = ALIGN(sizeof(struct ether_header)) - sizeof(struct ether_header); - m->m_data += pad; - len = MHLEN - pad; - head = NULL; - mp = &head; - - while (datalen != 0) { - if (head != NULL) { - MGET(m, M_DONTWAIT, MT_DATA); - if (m == NULL) { - printf("%s: unable to allocate RX mbuf\n", - sc->sc_dev.dv_xname); - m_freem(head); - return NULL; - } - len = MHLEN; - } - if (datalen >= MINCLSIZE) { - MCLGET(m, M_DONTWAIT); - if ((m->m_flags & M_EXT) == 0) { - printf("%s: unable to allocate RX cluster\n", - sc->sc_dev.dv_xname); - m_freem(head); - m_freem(m); - return NULL; - } - len = MCLBYTES; - if (head == NULL) { - m->m_data += pad; - len -= pad; - } - } - m->m_len = len = min(datalen, len); - memcpy(mtod(m, caddr_t), data, len); - data += len; - datalen -= len; - *mp = m; - mp = &m->m_next; - } - - return head; -} - -int -iec_intr(void *arg) -{ - struct iec_softc *sc = arg; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - struct ifnet *ifp = &sc->sc_ac.ac_if; - uint32_t statreg, statack; - int handled, sent; - - DPRINTF(IEC_DEBUG_INTR, ("iec_intr: called\n")); - - handled = sent = 0; - - for (;;) { - statreg = bus_space_read_4(st, sh, IOC3_ENET_ISR); - - DPRINTF(IEC_DEBUG_INTR, - ("iec_intr: INT_STAT = 0x%x\n", statreg)); - - statack = statreg & bus_space_read_4(st, sh, IOC3_ENET_IER); - if (statack == 0) - break; - bus_space_write_4(st, sh, IOC3_ENET_ISR, statack); - - handled = 1; - - if (statack & - (IOC3_ENET_ISR_RX_TIMER | IOC3_ENET_ISR_RX_THRESHOLD)) { - iec_rxintr(sc, statreg); - } - - if (statack & IOC3_ENET_ISR_TX_ALL) { - iec_txintr(sc, statreg & IOC3_ENET_ISR_TX_ALL); - sent = 1; - } - } - - if (sent) { - /* Try to get more packets going. */ - iec_start(ifp); - } - - return handled; -} - -void -iec_rxintr(struct iec_softc *sc, uint32_t stat) -{ - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct mbuf_list ml = MBUF_LIST_INITIALIZER(); - struct mbuf *m; - struct iec_rxdesc *rxd; - uint64_t rxstat; - size_t len; - u_int packets; - uint32_t i, ci; - - /* - * Figure out how many RX descriptors are available for processing. - */ - ci = bus_space_read_4(st, sh, IOC3_ENET_RCIR) / sizeof(uint64_t); - packets = (ci + IEC_NRXDESC_MAX - sc->sc_rxci) % IEC_NRXDESC_MAX; - sc->sc_rxpi = (sc->sc_rxpi + packets) % IEC_NRXDESC_MAX; - - DPRINTF(IEC_DEBUG_RXINTR, ("iec_rxintr: rx %d-%d\n", sc->sc_rxci, ci)); - while (packets-- != 0) { - i = (sc->sc_rxci++) & (sc->sc_nrxdesc - 1); - - IEC_RXSTATSYNC(sc, i, BUS_DMASYNC_POSTREAD); - rxd = &sc->sc_rxdesc[i]; - rxstat = rxd->rxd_stat; - - DPRINTF(IEC_DEBUG_RXINTR, - ("iec_rxintr: rxstat = 0x%08x, rxerr = 0x%08x\n", - rxstat, rxd->rxd_err)); - - if ((rxstat & IEC_RXSTAT_VALID) == 0) - goto dropit; - - len = (rxstat & IEC_RXSTAT_LEN_MASK) >> IEC_RXSTAT_LEN_SHIFT; - - if (len < ETHER_MIN_LEN || - len > ETHER_MAX_LEN) { - /* Invalid length packet; drop it. */ - DPRINTF(IEC_DEBUG_RXINTR, - ("iec_rxintr: wrong packet\n")); -dropit: - ifp->if_ierrors++; - rxd->rxd_stat = 0; - IEC_RXSTATSYNC(sc, i, BUS_DMASYNC_PREREAD); - continue; - } - - if (rxd->rxd_err & (IEC_RXERR_BADPACKET | IEC_RXERR_LONGEVENT | - IEC_RXERR_INVPREAMB | IEC_RXERR_CODE | IEC_RXERR_FRAME | - IEC_RXERR_CRC)) { - printf("%s: iec_rxintr: stat = 0x%08llx err = %08x\n", - sc->sc_dev.dv_xname, rxstat, rxd->rxd_err); - goto dropit; - } - - /* - * Now allocate an mbuf (and possibly a cluster) to hold - * the received packet. - */ - len -= ETHER_CRC_LEN; - IEC_RXBUFSYNC(sc, i, len, BUS_DMASYNC_POSTREAD); - m = iec_get(sc, rxd->rxd_buf, len); - IEC_RXBUFSYNC(sc, i, ETHER_MAX_LEN, BUS_DMASYNC_PREREAD); - if (m == NULL) - goto dropit; - - rxd->rxd_stat = 0; - IEC_RXSTATSYNC(sc, i, BUS_DMASYNC_PREREAD); - - ml_enqueue(&ml, m); - } - - /* Update RX index pointers. */ - sc->sc_rxci = ci; - bus_space_write_4(st, sh, IOC3_ENET_RPIR, - (sc->sc_rxpi * sizeof(uint64_t)) | IOC3_ENET_PIR_SET); - DPRINTF(IEC_DEBUG_RXINTR, ("iec_rxintr: new rxci %d rxpi %d\n", - sc->sc_rxci, sc->sc_rxpi)); - - if_input(ifp, &ml); -} - -void -iec_txintr(struct iec_softc *sc, uint32_t stat) -{ - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct iec_txsoft *txs; - bus_dmamap_t dmamap; - uint32_t tcir; - int i, once, last; - - ifq_clr_oactive(&ifp->if_snd); - - tcir = bus_space_read_4(st, sh, IOC3_ENET_TCIR) & ~IOC3_ENET_TCIR_IDLE; - last = (tcir / IEC_TXDESCSIZE) % IEC_NTXDESC_MAX; - - DPRINTF(IEC_DEBUG_TXINTR, ("iec_txintr: dirty %d last %d\n", - sc->sc_txdirty, last)); - once = 0; - for (i = sc->sc_txdirty; i != last && sc->sc_txpending != 0; - i = IEC_NEXTTX(i), sc->sc_txpending--) { - txs = &sc->sc_txsoft[i]; - if ((txs->txs_flags & IEC_TXCMD_PTR0_V) != 0) { - dmamap = txs->txs_dmamap; - bus_dmamap_sync(sc->sc_dmat, dmamap, 0, - dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE); - bus_dmamap_unload(sc->sc_dmat, dmamap); - m_freem(txs->txs_mbuf); - txs->txs_mbuf = NULL; - } - - if ((stat & IOC3_ENET_ISR_TX_EXPLICIT) == 0) { - if (stat == IOC3_ENET_ISR_TX_EMPTY) - continue; - if (once == 0) { - printf("%s: TX error: txstat = %08x\n", - DEVNAME(sc), stat); - once = 1; - } - ifp->if_oerrors++; - } else { - ifp->if_collisions += IOC3_ENET_TCDC_COLLISION_MASK & - bus_space_read_4(st, sh, IOC3_ENET_TCDC); - } - } - - /* Update the dirty TX buffer pointer. */ - sc->sc_txdirty = i; - DPRINTF(IEC_DEBUG_INTR, - ("iec_txintr: sc_txdirty = %2d, sc_txpending = %2d\n", - sc->sc_txdirty, sc->sc_txpending)); - - /* Cancel the watchdog timer if there are no pending TX packets. */ - if (sc->sc_txpending == 0) - ifp->if_timer = 0; - - if (stat & IOC3_ENET_ISR_TX_EMPTY) { - bus_space_write_4(st, sh, IOC3_ENET_IER, - bus_space_read_4(st, sh, IOC3_ENET_IER) & - ~IOC3_ENET_ISR_TX_EMPTY); - (void)bus_space_read_4(st, sh, IOC3_ENET_IER); - } -} - -int -iec_ssram_probe(struct iec_softc *sc) -{ - /* - * Depending on the hardware, there is either 64KB or 128KB of - * 16-bit SSRAM, which is used as internal RX buffers by the chip. - */ - - /* default to large size */ - sc->sc_mcr = IOC3_ENET_MCR_PARITY_ENABLE | IOC3_ENET_MCR_LARGE_SSRAM; - bus_space_write_4(sc->sc_st, sc->sc_sh, IOC3_ENET_MCR, sc->sc_mcr); - - bus_space_write_4(sc->sc_st, sc->sc_sh, - IOC3_SSRAM_BASE, 0x55aa); - bus_space_write_4(sc->sc_st, sc->sc_sh, - IOC3_SSRAM_BASE + IOC3_SSRAM_SMALL_SIZE, 0xffff ^ 0x55aa); - - if ((bus_space_read_4(sc->sc_st, sc->sc_sh, IOC3_SSRAM_BASE) & - IOC3_SSRAM_DATA_MASK) != 0x55aa || - (bus_space_read_4(sc->sc_st, sc->sc_sh, - IOC3_SSRAM_BASE + IOC3_SSRAM_SMALL_SIZE) != (0xffff ^ 0x55aa))) { - sc->sc_mcr &= ~IOC3_ENET_MCR_LARGE_SSRAM; - sc->sc_nrxdesc = IEC_NRXDESC_SMALL; - return IOC3_SSRAM_SMALL_SIZE / 2 / 1024; - } else { - sc->sc_nrxdesc = IEC_NRXDESC_LARGE; - return IOC3_SSRAM_LARGE_SIZE / 2 / 1024; - } -} diff --git a/sys/arch/sgi/dev/if_iecreg.h b/sys/arch/sgi/dev/if_iecreg.h deleted file mode 100644 index d9916472229..00000000000 --- a/sys/arch/sgi/dev/if_iecreg.h +++ /dev/null @@ -1,95 +0,0 @@ -/* $OpenBSD: if_iecreg.h,v 1.4 2021/03/11 11:17:00 jsg Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Ethernet controller part of the IOC3 ASIC. - */ - -/* - * Receive buffer descriptor. - */ - -#define IEC_NRXDESC_MAX 512 - -#define IEC_RXDESCSIZE (4096) -#define IEC_RXD_BUFOFFSET (64 + 2) /* to align Ethernet header */ -#define IEC_RXD_NRXPAD (IEC_RXD_BUFOFFSET - 2 * sizeof(uint32_t)) -#define IEC_RXD_BUFSIZE (IEC_RXDESCSIZE - IEC_RXD_BUFOFFSET) - -/* - * IEC_RXDESCSIZE is the smallest multiple of 128 bytes (hardware requirement) - * able to store ETHER_MAX_DIX_LEN bytes and the rxdesc administrative data. - * - * IEC_RXD_BUFOFFSET is chosen to use a different cache line on the CPU. - * A value of 128 (IOC3 cache line) would be even better, but would not fit - * in the MCR register. - */ - -struct iec_rxdesc { - volatile uint32_t rxd_stat; -#define IEC_RXSTAT_VALID 0x80000000 /* descriptor valid */ -#define IEC_RXSTAT_LEN_MASK 0x07ff0000 -#define IEC_RXSTAT_LEN_SHIFT 16 -#define IEC_RXSTAT_CHECKSUM_MASK 0x0000ffff - uint32_t rxd_err; -#define IEC_RXERR_CRC 0x00000001 /* CRC error */ -#define IEC_RXERR_FRAME 0x00000002 /* Framing error */ -#define IEC_RXERR_CODE 0x00000004 /* Code violation */ -#define IEC_RXERR_INVPREAMB 0x00000008 /* Invalid preamble */ -#define IEC_RXERR_MULTICAST 0x04000000 /* Multicast packet */ -#define IEC_RXERR_BROADCAST 0x08000000 /* Broadcast packet */ -#define IEC_RXERR_LONGEVENT 0x10000000 /* Long packet */ -#define IEC_RXERR_BADPACKET 0x20000000 /* Bad packet */ -#define IEC_RXERR_GOODPACKET 0x40000000 -#define IEC_RXERR_CARRIER 0x80000000 /* Carrier event */ - uint8_t rxd_pad[IEC_RXD_NRXPAD]; - uint8_t rxd_buf[IEC_RXD_BUFSIZE]; -}; - -/* - * Transmit buffer descriptor. - */ - -#define IEC_NTXDESC_MAX 128 - -#define IEC_TXDESCSIZE 128 -#define IEC_NTXPTR 2 -#define IEC_TXD_BUFOFFSET \ - (2 * sizeof(uint32_t) + IEC_NTXPTR * sizeof(uint64_t)) -#define IEC_TXD_BUFSIZE (IEC_TXDESCSIZE - IEC_TXD_BUFOFFSET) - -struct iec_txdesc { - uint32_t txd_cmd; -#define IEC_TXCMD_DATALEN 0x000007ff -#define IEC_TXCMD_TXINT 0x00001000 /* interrupt after TX */ -#define IEC_TXCMD_BUF_V 0x00010000 /* txd_buf valid */ -#define IEC_TXCMD_PTR0_V 0x00020000 /* tx_ptr[0] valid */ -#define IEC_TXCMD_PTR1_V 0x00040000 /* tx_ptr[1] valid */ -#define IEC_TXCMD_HWCHECKSUM 0x00080000 /* perform hw cksum */ -#define IEC_TXCMD_CHECKSUM_POS_MASK 0x07f00000 /* hw cksum byte pos */ -#define IEC_TXCMD_CHECKSUM_POS_SHIFT 20 - uint32_t txd_len; -#define IECTX_BUF0_LEN_MASK 0x0000007f -#define IECTX_BUF0_LEN_SHIFT 0 -#define IECTX_BUF1_LEN_MASK 0x0007ff00 -#define IECTX_BUF1_LEN_SHIFT 8 -#define IECTX_BUF2_LEN_MASK 0x7ff00000 -#define IECTX_BUF2_LEN_SHIFT 20 - uint64_t txd_ptr[IEC_NTXPTR]; - uint8_t txd_buf[IEC_TXD_BUFSIZE]; -}; diff --git a/sys/arch/sgi/dev/if_mec.c b/sys/arch/sgi/dev/if_mec.c deleted file mode 100644 index f9a2e4876c1..00000000000 --- a/sys/arch/sgi/dev/if_mec.c +++ /dev/null @@ -1,1409 +0,0 @@ -/* $OpenBSD: if_mec.c,v 1.41 2020/07/10 13:26:36 patrick Exp $ */ -/* $NetBSD: if_mec_mace.c,v 1.5 2004/08/01 06:36:36 tsutsui Exp $ */ - -/* - * Copyright (c) 2004 Izumi Tsutsui. - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * Copyright (c) 2003 Christopher SEKIYA - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * MACE MAC-110 Ethernet driver. - */ - -#include "bpfilter.h" - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/timeout.h> -#include <sys/mbuf.h> -#include <sys/malloc.h> -#include <sys/kernel.h> -#include <sys/socket.h> -#include <sys/ioctl.h> -#include <sys/errno.h> - -#include <net/if.h> -#include <net/if_media.h> - -#if NBPFILTER > 0 -#include <net/bpf.h> -#endif - -#include <netinet/in.h> -#include <netinet/if_ether.h> - -#include <machine/bus.h> -#include <machine/intr.h> -#include <machine/autoconf.h> - -#include <dev/mii/mii.h> -#include <dev/mii/miivar.h> - -#include <mips64/arcbios.h> -#include <sgi/dev/if_mecreg.h> - -#include <sgi/localbus/macebusvar.h> - -#ifdef MEC_DEBUG -#define MEC_DEBUG_RESET 0x01 -#define MEC_DEBUG_START 0x02 -#define MEC_DEBUG_STOP 0x04 -#define MEC_DEBUG_INTR 0x08 -#define MEC_DEBUG_RXINTR 0x10 -#define MEC_DEBUG_TXINTR 0x20 -uint32_t mec_debug = 0xff; -#define DPRINTF(x, y) if (mec_debug & (x)) printf y -#else -#define DPRINTF(x, y) /* nothing */ -#endif - -/* - * Transmit descriptor list size. - */ -#define MEC_NTXDESC 64 -#define MEC_NTXDESC_MASK (MEC_NTXDESC - 1) -#define MEC_NEXTTX(x) (((x) + 1) & MEC_NTXDESC_MASK) - -/* - * Software state for TX. - */ -struct mec_txsoft { - struct mbuf *txs_mbuf; /* Head of our mbuf chain. */ - bus_dmamap_t txs_dmamap; /* Our DMA map. */ - uint32_t txs_flags; -#define MEC_TXS_BUFLEN_MASK 0x0000007f /* Data len in txd_buf. */ -#define MEC_TXS_TXDBUF 0x00000080 /* txd_buf is used. */ -#define MEC_TXS_TXDPTR1 0x00000100 /* txd_ptr[0] is used. */ -}; - -/* - * Transmit buffer descriptor. - */ -#define MEC_TXDESCSIZE 128 -#define MEC_NTXPTR 3 -#define MEC_TXD_BUFOFFSET \ - (sizeof(uint64_t) + MEC_NTXPTR * sizeof(uint64_t)) -#define MEC_TXD_BUFSIZE (MEC_TXDESCSIZE - MEC_TXD_BUFOFFSET) -#define MEC_TXD_BUFSTART(len) (MEC_TXD_BUFSIZE - (len)) -#define MEC_TXD_ALIGN 8 -#define MEC_TXD_ROUNDUP(addr) \ - (((addr) + (MEC_TXD_ALIGN - 1)) & ~((uint64_t)MEC_TXD_ALIGN - 1)) - -struct mec_txdesc { - volatile uint64_t txd_cmd; -#define MEC_TXCMD_DATALEN 0x000000000000ffff /* Data length. */ -#define MEC_TXCMD_BUFSTART 0x00000000007f0000 /* Start byte offset. */ -#define TXCMD_BUFSTART(x) ((x) << 16) -#define MEC_TXCMD_TERMDMA 0x0000000000800000 /* Stop DMA on abort. */ -#define MEC_TXCMD_TXINT 0x0000000001000000 /* INT after TX done. */ -#define MEC_TXCMD_PTR1 0x0000000002000000 /* Valid 1st txd_ptr. */ -#define MEC_TXCMD_PTR2 0x0000000004000000 /* Valid 2nd txd_ptr. */ -#define MEC_TXCMD_PTR3 0x0000000008000000 /* Valid 3rd txd_ptr. */ -#define MEC_TXCMD_UNUSED 0xfffffffff0000000ULL /* Should be zero. */ - -#define txd_stat txd_cmd -#define MEC_TXSTAT_LEN 0x000000000000ffff /* TX length. */ -#define MEC_TXSTAT_COLCNT 0x00000000000f0000 /* Collision count. */ -#define MEC_TXSTAT_COLCNT_SHIFT 16 -#define MEC_TXSTAT_LATE_COL 0x0000000000100000 /* Late collision. */ -#define MEC_TXSTAT_CRCERROR 0x0000000000200000 /* */ -#define MEC_TXSTAT_DEFERRED 0x0000000000400000 /* */ -#define MEC_TXSTAT_SUCCESS 0x0000000000800000 /* TX complete. */ -#define MEC_TXSTAT_TOOBIG 0x0000000001000000 /* */ -#define MEC_TXSTAT_UNDERRUN 0x0000000002000000 /* */ -#define MEC_TXSTAT_COLLISIONS 0x0000000004000000 /* */ -#define MEC_TXSTAT_EXDEFERRAL 0x0000000008000000 /* */ -#define MEC_TXSTAT_COLLIDED 0x0000000010000000 /* */ -#define MEC_TXSTAT_UNUSED 0x7fffffffe0000000ULL /* Should be zero. */ -#define MEC_TXSTAT_SENT 0x8000000000000000ULL /* Packet sent. */ - - uint64_t txd_ptr[MEC_NTXPTR]; -#define MEC_TXPTR_UNUSED2 0x0000000000000007 /* Should be zero. */ -#define MEC_TXPTR_DMAADDR 0x00000000fffffff8 /* TX DMA address. */ -#define MEC_TXPTR_LEN 0x0000ffff00000000ULL /* Buffer length. */ -#define TXPTR_LEN(x) ((uint64_t)(x) << 32) -#define MEC_TXPTR_UNUSED1 0xffff000000000000ULL /* Should be zero. */ - - uint8_t txd_buf[MEC_TXD_BUFSIZE]; -}; - -/* - * Receive buffer size. - */ -#define MEC_NRXDESC 16 -#define MEC_NRXDESC_MASK (MEC_NRXDESC - 1) -#define MEC_NEXTRX(x) (((x) + 1) & MEC_NRXDESC_MASK) - -/* - * Receive buffer description. - */ -#define MEC_RXDESCSIZE 4096 /* Umm, should be 4kbyte aligned. */ -#define MEC_RXD_NRXPAD 3 -#define MEC_RXD_DMAOFFSET (1 + MEC_RXD_NRXPAD) -#define MEC_RXD_BUFOFFSET (MEC_RXD_DMAOFFSET * sizeof(uint64_t)) -#define MEC_RXD_BUFSIZE (MEC_RXDESCSIZE - MEC_RXD_BUFOFFSET) - -struct mec_rxdesc { - volatile uint64_t rxd_stat; -#define MEC_RXSTAT_LEN 0x000000000000ffff /* Data length. */ -#define MEC_RXSTAT_VIOLATION 0x0000000000010000 /* Code violation (?). */ -#define MEC_RXSTAT_UNUSED2 0x0000000000020000 /* Unknown (?). */ -#define MEC_RXSTAT_CRCERROR 0x0000000000040000 /* CRC error. */ -#define MEC_RXSTAT_MULTICAST 0x0000000000080000 /* Multicast packet. */ -#define MEC_RXSTAT_BROADCAST 0x0000000000100000 /* Broadcast packet. */ -#define MEC_RXSTAT_INVALID 0x0000000000200000 /* Invalid preamble. */ -#define MEC_RXSTAT_LONGEVENT 0x0000000000400000 /* Long packet. */ -#define MEC_RXSTAT_BADPACKET 0x0000000000800000 /* Bad packet. */ -#define MEC_RXSTAT_CAREVENT 0x0000000001000000 /* Carrier event. */ -#define MEC_RXSTAT_MATCHMCAST 0x0000000002000000 /* Match multicast. */ -#define MEC_RXSTAT_MATCHMAC 0x0000000004000000 /* Match MAC. */ -#define MEC_RXSTAT_SEQNUM 0x00000000f8000000 /* Sequence number. */ -#define MEC_RXSTAT_CKSUM 0x0000ffff00000000ULL /* IP checksum. */ -#define MEC_RXSTAT_UNUSED1 0x7fff000000000000ULL /* Should be zero. */ -#define MEC_RXSTAT_RECEIVED 0x8000000000000000ULL /* Set to 1 on RX. */ - uint64_t rxd_pad1[MEC_RXD_NRXPAD]; - uint8_t rxd_buf[MEC_RXD_BUFSIZE]; -}; - -/* - * Control structures for DMA ops. - */ -struct mec_control_data { - /* - * TX descriptors and buffers. - */ - struct mec_txdesc mcd_txdesc[MEC_NTXDESC]; - - /* - * RX descriptors and buffers. - */ - struct mec_rxdesc mcd_rxdesc[MEC_NRXDESC]; -}; - -/* - * It _seems_ there are some restrictions on descriptor address: - * - * - Base address of txdescs should be 8kbyte aligned - * - Each txdesc should be 128byte aligned - * - Each rxdesc should be 4kbyte aligned - * - * So we should specify 64k align to allocalte txdescs. - * In this case, sizeof(struct mec_txdesc) * MEC_NTXDESC is 8192 - * so rxdescs are also allocated at 4kbyte aligned. - */ -#define MEC_CONTROL_DATA_ALIGN (8 * 1024) - -#define MEC_CDOFF(x) offsetof(struct mec_control_data, x) -#define MEC_CDTXOFF(x) MEC_CDOFF(mcd_txdesc[(x)]) -#define MEC_CDRXOFF(x) MEC_CDOFF(mcd_rxdesc[(x)]) - -/* - * Software state per device. - */ -struct mec_softc { - struct device sc_dev; /* Generic device structures. */ - struct arpcom sc_ac; /* Ethernet common part. */ - - bus_space_tag_t sc_st; /* bus_space tag. */ - bus_space_handle_t sc_sh; /* bus_space handle. */ - bus_dma_tag_t sc_dmat; /* bus_dma tag. */ - - struct mii_data sc_mii; /* MII/media information. */ - struct timeout sc_tick_ch; /* Tick timeout. */ - - bus_dmamap_t sc_cddmamap; /* bus_dma map for control data. */ -#define sc_cddma sc_cddmamap->dm_segs[0].ds_addr - - /* Pointer to allocated control data. */ - struct mec_control_data *sc_control_data; -#define sc_txdesc sc_control_data->mcd_txdesc -#define sc_rxdesc sc_control_data->mcd_rxdesc - - /* Software state for TX descs. */ - struct mec_txsoft sc_txsoft[MEC_NTXDESC]; - - int sc_txpending; /* Number of TX requests pending. */ - int sc_txdirty; /* First dirty TX descriptor. */ - int sc_txlast; /* Last used TX descriptor. */ - - int sc_rxptr; /* Next ready RX buffer. */ -}; - -#define MEC_CDTXADDR(sc, x) ((sc)->sc_cddma + MEC_CDTXOFF(x)) -#define MEC_CDRXADDR(sc, x) ((sc)->sc_cddma + MEC_CDRXOFF(x)) - -#define MEC_TXDESCSYNC(sc, x, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - MEC_CDTXOFF(x), MEC_TXDESCSIZE, (ops)) -#define MEC_TXCMDSYNC(sc, x, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - MEC_CDTXOFF(x), sizeof(uint64_t), (ops)) - -#define MEC_RXSTATSYNC(sc, x, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - MEC_CDRXOFF(x), sizeof(uint64_t), (ops)) -#define MEC_RXBUFSYNC(sc, x, len, ops) \ - bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_cddmamap, \ - MEC_CDRXOFF(x) + MEC_RXD_BUFOFFSET, \ - ETHER_ALIGN + (len), (ops)) - -/* XXX these values should be moved to <net/if_ether.h> ? */ -#define ETHER_PAD_LEN (ETHER_MIN_LEN - ETHER_CRC_LEN) - -struct cfdriver mec_cd = { - NULL, "mec", DV_IFNET -}; - -int mec_match(struct device *, void *, void *); -void mec_attach(struct device *, struct device *, void *); - -struct cfattach mec_ca = { - sizeof(struct mec_softc), mec_match, mec_attach -}; - -int mec_mii_readreg(struct device *, int, int); -void mec_mii_writereg(struct device *, int, int, int); -int mec_mii_wait(struct mec_softc *); -void mec_statchg(struct device *); -void mec_mediastatus(struct ifnet *, struct ifmediareq *); -int mec_mediachange(struct ifnet *); - -int mec_init(struct ifnet * ifp); -void mec_start(struct ifnet *); -void mec_watchdog(struct ifnet *); -void mec_tick(void *); -int mec_ioctl(struct ifnet *, u_long, caddr_t); -void mec_reset(struct mec_softc *, int); -void mec_iff(struct mec_softc *); -int mec_intr(void *arg); -void mec_stop(struct ifnet *); -void mec_rxintr(struct mec_softc *, uint32_t); -void mec_txintr(struct mec_softc *, uint32_t); - -int -mec_match(struct device *parent, void *match, void *aux) -{ - return (1); -} - -void -mec_attach(struct device *parent, struct device *self, void *aux) -{ - struct mec_softc *sc = (void *)self; - struct macebus_attach_args *maa = aux; - struct ifnet *ifp = &sc->sc_ac.ac_if; - uint32_t command; - struct mii_softc *child; - bus_dma_segment_t seg; - int i, err, rseg; - - sc->sc_st = maa->maa_iot; - if (bus_space_map(sc->sc_st, maa->maa_baseaddr, MEC_NREGS, 0, - &sc->sc_sh) != 0) { - printf(": can't map i/o space\n"); - return; - } - - /* Set up DMA structures. */ - sc->sc_dmat = maa->maa_dmat; - - /* - * Allocate the control data structures, and create and load the - * DMA map for it. - */ - if ((err = bus_dmamem_alloc(sc->sc_dmat, - sizeof(struct mec_control_data), MEC_CONTROL_DATA_ALIGN, 0, - &seg, 1, &rseg, BUS_DMA_NOWAIT)) != 0) { - printf(": unable to allocate control data, error = %d\n", err); - goto fail_0; - } - - /* - * XXX needs re-think... - * control data structures contain whole RX data buffer, so - * BUS_DMA_COHERENT (which disables cache) may cause some performance - * issue on copying data from the RX buffer to mbuf on normal memory, - * though we have to make sure all bus_dmamap_sync(9) ops are called - * properly in that case. - */ - if ((err = bus_dmamem_map(sc->sc_dmat, &seg, rseg, - sizeof(struct mec_control_data), - (caddr_t *)&sc->sc_control_data, /*BUS_DMA_COHERENT*/ 0)) != 0) { - printf(": unable to map control data, error = %d\n", err); - goto fail_1; - } - memset(sc->sc_control_data, 0, sizeof(struct mec_control_data)); - - if ((err = bus_dmamap_create(sc->sc_dmat, - sizeof(struct mec_control_data), 1, - sizeof(struct mec_control_data), 0, 0, &sc->sc_cddmamap)) != 0) { - printf(": unable to create control data DMA map, error = %d\n", - err); - goto fail_2; - } - if ((err = bus_dmamap_load(sc->sc_dmat, sc->sc_cddmamap, - sc->sc_control_data, sizeof(struct mec_control_data), NULL, - BUS_DMA_NOWAIT)) != 0) { - printf(": unable to load control data DMA map, error = %d\n", - err); - goto fail_3; - } - - /* Create TX buffer DMA maps. */ - for (i = 0; i < MEC_NTXDESC; i++) { - if ((err = bus_dmamap_create(sc->sc_dmat, - MCLBYTES, 1, MCLBYTES, 0, 0, - &sc->sc_txsoft[i].txs_dmamap)) != 0) { - printf(": unable to create tx DMA map %d, error = %d\n", - i, err); - goto fail_4; - } - } - - timeout_set(&sc->sc_tick_ch, mec_tick, sc); - - /* Use the Ethernet address from the ARCBIOS. */ - enaddr_aton(bios_enaddr, sc->sc_ac.ac_enaddr); - - /* Reset device. */ - mec_reset(sc, 1); - - command = bus_space_read_8(sc->sc_st, sc->sc_sh, MEC_MAC_CONTROL); - - printf(": MAC-110 rev %d, address %s\n", - (command & MEC_MAC_REVISION) >> MEC_MAC_REVISION_SHIFT, - ether_sprintf(sc->sc_ac.ac_enaddr)); - - /* Done, now attach everything. */ - - sc->sc_mii.mii_ifp = ifp; - sc->sc_mii.mii_readreg = mec_mii_readreg; - sc->sc_mii.mii_writereg = mec_mii_writereg; - sc->sc_mii.mii_statchg = mec_statchg; - - /* Set up PHY properties. */ - ifmedia_init(&sc->sc_mii.mii_media, 0, mec_mediachange, - mec_mediastatus); - mii_attach(&sc->sc_dev, &sc->sc_mii, 0xffffffff, MII_PHY_ANY, - MII_OFFSET_ANY, 0); - - child = LIST_FIRST(&sc->sc_mii.mii_phys); - if (child == NULL) { - /* No PHY attached. */ - ifmedia_add(&sc->sc_mii.mii_media, IFM_ETHER | IFM_MANUAL, - 0, NULL); - ifmedia_set(&sc->sc_mii.mii_media, IFM_ETHER | IFM_MANUAL); - } else { - ifmedia_set(&sc->sc_mii.mii_media, IFM_ETHER | IFM_AUTO); - } - - bcopy(sc->sc_dev.dv_xname, ifp->if_xname, IFNAMSIZ); - ifp->if_softc = sc; - ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; - ifp->if_ioctl = mec_ioctl; - ifp->if_start = mec_start; - ifp->if_watchdog = mec_watchdog; - - if_attach(ifp); - ifq_set_maxlen(&ifp->if_snd, MEC_NTXDESC - 1); - ether_ifattach(ifp); - - /* Establish interrupt handler. */ - macebus_intr_establish(maa->maa_intr, maa->maa_mace_intr, - IPL_NET, mec_intr, sc, sc->sc_dev.dv_xname); - - return; - - /* - * Free any resources we've allocated during the failed attach - * attempt. Do this in reverse order and fall though. - */ - fail_4: - for (i = 0; i < MEC_NTXDESC; i++) { - if (sc->sc_txsoft[i].txs_dmamap != NULL) - bus_dmamap_destroy(sc->sc_dmat, - sc->sc_txsoft[i].txs_dmamap); - } - bus_dmamap_unload(sc->sc_dmat, sc->sc_cddmamap); - fail_3: - bus_dmamap_destroy(sc->sc_dmat, sc->sc_cddmamap); - fail_2: - bus_dmamem_unmap(sc->sc_dmat, (caddr_t)sc->sc_control_data, - sizeof(struct mec_control_data)); - fail_1: - bus_dmamem_free(sc->sc_dmat, &seg, rseg); - fail_0: - return; -} - -int -mec_mii_readreg(struct device *self, int phy, int reg) -{ - struct mec_softc *sc = (void *)self; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint64_t val; - int i; - - if (mec_mii_wait(sc) != 0) - return 0; - - bus_space_write_8(st, sh, MEC_PHY_ADDRESS, - (phy << MEC_PHY_ADDR_DEVSHIFT) | (reg & MEC_PHY_ADDR_REGISTER)); - bus_space_write_8(st, sh, MEC_PHY_READ_INITIATE, 1); - - for (i = 0; i < 20; i++) { - delay(25); - val = bus_space_read_8(st, sh, MEC_PHY_DATA); - - if ((val & MEC_PHY_DATA_BUSY) == 0) - return val & MEC_PHY_DATA_VALUE; - } - return 0; -} - -void -mec_mii_writereg(struct device *self, int phy, int reg, int val) -{ - struct mec_softc *sc = (void *)self; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - - if (mec_mii_wait(sc) != 0) { - printf("MII timed out writing %x: %x\n", reg, val); - return; - } - - bus_space_write_8(st, sh, MEC_PHY_ADDRESS, - (phy << MEC_PHY_ADDR_DEVSHIFT) | (reg & MEC_PHY_ADDR_REGISTER)); - bus_space_write_8(st, sh, MEC_PHY_DATA, val & MEC_PHY_DATA_VALUE); - - mec_mii_wait(sc); -} - -int -mec_mii_wait(struct mec_softc *sc) -{ - uint64_t busy; - int i; - - for (i = 0; i < 100; i++) { - busy = bus_space_read_8(sc->sc_st, sc->sc_sh, MEC_PHY_DATA); - if ((busy & MEC_PHY_DATA_BUSY) == 0) - return 0; - delay(30); - } - - printf("%s: MII timed out\n", sc->sc_dev.dv_xname); - return 1; -} - -void -mec_statchg(struct device *self) -{ - struct mec_softc *sc = (void *)self; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint32_t control; - - control = bus_space_read_8(st, sh, MEC_MAC_CONTROL); - control &= ~(MEC_MAC_IPGT | MEC_MAC_IPGR1 | MEC_MAC_IPGR2 | - MEC_MAC_FULL_DUPLEX | MEC_MAC_SPEED_SELECT); - - /* Must also set IPG here for duplex stuff... */ - if ((sc->sc_mii.mii_media_active & IFM_FDX) != 0) { - control |= MEC_MAC_FULL_DUPLEX; - } else { - /* Set IPG. */ - control |= MEC_MAC_IPG_DEFAULT; - } - - bus_space_write_8(st, sh, MEC_MAC_CONTROL, control); -} - -void -mec_mediastatus(struct ifnet *ifp, struct ifmediareq *ifmr) -{ - struct mec_softc *sc = ifp->if_softc; - - if ((ifp->if_flags & IFF_UP) == 0) - return; - - mii_pollstat(&sc->sc_mii); - ifmr->ifm_status = sc->sc_mii.mii_media_status; - ifmr->ifm_active = sc->sc_mii.mii_media_active; -} - -int -mec_mediachange(struct ifnet *ifp) -{ - struct mec_softc *sc = ifp->if_softc; - - if ((ifp->if_flags & IFF_UP) == 0) - return 0; - - return mii_mediachg(&sc->sc_mii); -} - -int -mec_init(struct ifnet *ifp) -{ - struct mec_softc *sc = ifp->if_softc; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - struct mec_rxdesc *rxd; - int i; - - /* Cancel any pending I/O. */ - mec_stop(ifp); - - /* Reset device. */ - mec_reset(sc, 0); - - /* Setup filter for multicast or promisc mode. */ - mec_iff(sc); - - /* Set the TX ring pointer to the base address. */ - bus_space_write_8(st, sh, MEC_TX_RING_BASE, MEC_CDTXADDR(sc, 0)); - - sc->sc_txpending = 0; - sc->sc_txdirty = 0; - sc->sc_txlast = MEC_NTXDESC - 1; - - /* Put RX buffers into FIFO. */ - for (i = 0; i < MEC_NRXDESC; i++) { - rxd = &sc->sc_rxdesc[i]; - rxd->rxd_stat = 0; - MEC_RXSTATSYNC(sc, i, BUS_DMASYNC_PREREAD); - MEC_RXBUFSYNC(sc, i, ETHER_MAX_LEN, BUS_DMASYNC_PREREAD); - bus_space_write_8(st, sh, MEC_MCL_RX_FIFO, MEC_CDRXADDR(sc, i)); - } - sc->sc_rxptr = 0; - -#if 0 /* XXX no info */ - bus_space_write_8(st, sh, MEC_TIMER, 0); -#endif - - /* - * MEC_DMA_TX_INT_ENABLE will be set later otherwise it causes - * spurious interrupts when TX buffers are empty. - */ - bus_space_write_8(st, sh, MEC_DMA_CONTROL, - (MEC_RXD_DMAOFFSET << MEC_DMA_RX_DMA_OFFSET_SHIFT) | - (MEC_NRXDESC << MEC_DMA_RX_INT_THRESH_SHIFT) | - MEC_DMA_TX_DMA_ENABLE | /* MEC_DMA_TX_INT_ENABLE | */ - MEC_DMA_RX_DMA_ENABLE | MEC_DMA_RX_INT_ENABLE); - - timeout_add_sec(&sc->sc_tick_ch, 1); - - ifp->if_flags |= IFF_RUNNING; - ifq_clr_oactive(&ifp->if_snd); - mec_start(ifp); - - mii_mediachg(&sc->sc_mii); - - return 0; -} - -void -mec_reset(struct mec_softc *sc, int firsttime) -{ - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint64_t address; - int i; - - /* Reset chip. */ - bus_space_write_8(st, sh, MEC_MAC_CONTROL, MEC_MAC_CORE_RESET); - delay(1000); - bus_space_write_8(st, sh, MEC_MAC_CONTROL, 0); - delay(1000); - - /* Set Ethernet address. */ - address = 0; - for (i = 0; i < ETHER_ADDR_LEN; i++) { - address = address << 8; - address += sc->sc_ac.ac_enaddr[i]; - } - bus_space_write_8(st, sh, MEC_STATION, address); - - /* Default to 100/half and let auto-negotiation work its magic. */ - bus_space_write_8(st, sh, MEC_MAC_CONTROL, - MEC_MAC_SPEED_SELECT | MEC_MAC_IPG_DEFAULT); - - bus_space_write_8(st, sh, MEC_DMA_CONTROL, 0); - - DPRINTF(MEC_DEBUG_RESET, ("mec: control now %llx\n", - bus_space_read_8(st, sh, MEC_MAC_CONTROL))); - - if (firsttime) { - /* - * After a cold boot, during the initial MII probe, the - * PHY would sometimes answer to addresses 11 or 10, only - * to settle to address 8 shortly after. - * - * Because of this, the PHY driver would attach to the wrong - * address and further link configuration would fail (with PHY - * register reads returning either 0 or FFFF), leading to - * horrible performance and no way to select a proper media. - */ - int i, reg, phyno; - for (phyno = 0; phyno < MII_NPHY; phyno++) { - reg = mec_mii_readreg(&sc->sc_dev, phyno, MII_BMSR); - /* same logic as in mii_attach() */ - if (reg == 0 || reg == 0xffff || - (reg & (BMSR_MEDIAMASK | BMSR_EXTSTAT)) == 0) - continue; - /* inline mii_phy_reset() */ - mec_mii_writereg(&sc->sc_dev, phyno, MII_BMCR, - BMCR_RESET | BMCR_ISO); - delay(500); - for (i = 0; i < 100; i++) { - reg = mec_mii_readreg(&sc->sc_dev, phyno, - MII_BMCR); - if ((reg & BMCR_RESET) == 0) { - mec_mii_writereg(&sc->sc_dev, phyno, - MII_BMCR, reg | BMCR_ISO); - break; - } - delay(1000); - } - } - } -} - -void -mec_start(struct ifnet *ifp) -{ - struct mec_softc *sc = ifp->if_softc; - struct mbuf *m0; - struct mec_txdesc *txd; - struct mec_txsoft *txs; - bus_dmamap_t dmamap; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint64_t txdaddr; - int error, firsttx, nexttx, opending; - int len, bufoff, buflen, unaligned, txdlen; - - if (!(ifp->if_flags & IFF_RUNNING) || ifq_is_oactive(&ifp->if_snd)) - return; - - /* - * Remember the previous txpending and the first transmit descriptor. - */ - opending = sc->sc_txpending; - firsttx = MEC_NEXTTX(sc->sc_txlast); - - DPRINTF(MEC_DEBUG_START, - ("mec_start: opending = %d, firsttx = %d\n", opending, firsttx)); - - for (;;) { - /* Grab a packet off the queue. */ - m0 = ifq_deq_begin(&ifp->if_snd); - if (m0 == NULL) - break; - - if (sc->sc_txpending == MEC_NTXDESC) { - ifq_deq_rollback(&ifp->if_snd, m0); - break; - } - - /* - * Get the next available transmit descriptor. - */ - nexttx = MEC_NEXTTX(sc->sc_txlast); - txd = &sc->sc_txdesc[nexttx]; - txs = &sc->sc_txsoft[nexttx]; - - buflen = 0; - bufoff = 0; - txdaddr = 0; /* XXX gcc */ - txdlen = 0; /* XXX gcc */ - - len = m0->m_pkthdr.len; - - DPRINTF(MEC_DEBUG_START, - ("mec_start: len = %d, nexttx = %d\n", len, nexttx)); - - ifq_deq_commit(&ifp->if_snd, m0); - if (len < ETHER_PAD_LEN) { - /* - * I don't know if MEC chip does auto padding, - * so if the packet is small enough, - * just copy it to the buffer in txdesc. - * Maybe this is the simple way. - */ - DPRINTF(MEC_DEBUG_START, ("mec_start: short packet\n")); - - bufoff = MEC_TXD_BUFSTART(ETHER_PAD_LEN); - m_copydata(m0, 0, m0->m_pkthdr.len, - txd->txd_buf + bufoff); - memset(txd->txd_buf + bufoff + len, 0, - ETHER_PAD_LEN - len); - len = buflen = ETHER_PAD_LEN; - - txs->txs_flags = MEC_TXS_TXDBUF | buflen; - } else { - /* - * If the packet won't fit the buffer in txdesc, - * we have to use concatenate pointer to handle it. - * While MEC can handle up to three segments to - * concatenate, MEC requires that both the second and - * third segments have to be 8 byte aligned. - * Since it's unlikely for mbuf clusters, we use - * only the first concatenate pointer. If the packet - * doesn't fit in one DMA segment, allocate new mbuf - * and copy the packet to it. - * - * Besides, if the start address of the first segments - * is not 8 byte aligned, such part have to be copied - * to the txdesc buffer. (XXX see below comments) - */ - DPRINTF(MEC_DEBUG_START, ("mec_start: long packet\n")); - - dmamap = txs->txs_dmamap; - if (bus_dmamap_load_mbuf(sc->sc_dmat, dmamap, m0, - BUS_DMA_WRITE | BUS_DMA_NOWAIT) != 0) { - struct mbuf *m; - - DPRINTF(MEC_DEBUG_START, - ("mec_start: re-allocating mbuf\n")); - MGETHDR(m, M_DONTWAIT, MT_DATA); - if (m == NULL) { - printf("%s: unable to allocate " - "TX mbuf\n", sc->sc_dev.dv_xname); - break; - } - if (len > (MHLEN - ETHER_ALIGN)) { - MCLGET(m, M_DONTWAIT); - if ((m->m_flags & M_EXT) == 0) { - printf("%s: unable to allocate " - "TX cluster\n", - sc->sc_dev.dv_xname); - m_freem(m); - break; - } - } - /* - * Each packet has the Ethernet header, so - * in many cases the header isn't 4-byte aligned - * and data after the header is 4-byte aligned. - * Thus adding 2-byte offset before copying to - * new mbuf avoids unaligned copy and this may - * improve performance. - * As noted above, unaligned part has to be - * copied to txdesc buffer so this may cause - * extra copy ops, but for now MEC always - * requires some data in txdesc buffer, - * so we always have to copy some data anyway. - */ - m->m_data += ETHER_ALIGN; - m_copydata(m0, 0, len, mtod(m, caddr_t)); - m->m_pkthdr.len = m->m_len = len; - m_freem(m0); - m0 = m; - error = bus_dmamap_load_mbuf(sc->sc_dmat, - dmamap, m, BUS_DMA_WRITE | BUS_DMA_NOWAIT); - if (error) { - printf("%s: unable to load TX buffer, " - "error = %d\n", - sc->sc_dev.dv_xname, error); - m_freem(m); - break; - } - } - - /* Handle unaligned part. */ - txdaddr = MEC_TXD_ROUNDUP(dmamap->dm_segs[0].ds_addr); - txs->txs_flags = MEC_TXS_TXDPTR1; - unaligned = - dmamap->dm_segs[0].ds_addr & (MEC_TXD_ALIGN - 1); - DPRINTF(MEC_DEBUG_START, - ("mec_start: ds_addr = 0x%x, unaligned = %d\n", - (u_int)dmamap->dm_segs[0].ds_addr, unaligned)); - if (unaligned != 0) { - buflen = MEC_TXD_ALIGN - unaligned; - bufoff = MEC_TXD_BUFSTART(buflen); - DPRINTF(MEC_DEBUG_START, - ("mec_start: unaligned, " - "buflen = %d, bufoff = %d\n", - buflen, bufoff)); - memcpy(txd->txd_buf + bufoff, - mtod(m0, caddr_t), buflen); - txs->txs_flags |= MEC_TXS_TXDBUF | buflen; - } -#if 1 - else { - /* - * XXX needs hardware info XXX - * It seems MEC always requires some data - * in txd_buf[] even if buffer is - * 8-byte aligned otherwise DMA abort error - * occurs later... - */ - buflen = MEC_TXD_ALIGN; - bufoff = MEC_TXD_BUFSTART(buflen); - memcpy(txd->txd_buf + bufoff, - mtod(m0, caddr_t), buflen); - DPRINTF(MEC_DEBUG_START, - ("mec_start: aligned, " - "buflen = %d, bufoff = %d\n", - buflen, bufoff)); - txs->txs_flags |= MEC_TXS_TXDBUF | buflen; - txdaddr += MEC_TXD_ALIGN; - } -#endif - txdlen = len - buflen; - DPRINTF(MEC_DEBUG_START, - ("mec_start: txdaddr = 0x%llx, txdlen = %d\n", - txdaddr, txdlen)); - - /* - * Sync the DMA map for TX mbuf. - * - * XXX unaligned part doesn't have to be sync'ed, - * but it's harmless... - */ - bus_dmamap_sync(sc->sc_dmat, dmamap, 0, - dmamap->dm_mapsize, BUS_DMASYNC_PREWRITE); - } - -#if NBPFILTER > 0 - /* - * Pass packet to bpf if there is a listener. - */ - if (ifp->if_bpf) - bpf_mtap(ifp->if_bpf, m0, BPF_DIRECTION_OUT); -#endif - - /* - * Setup the transmit descriptor. - */ - - /* TXINT bit will be set later on the last packet. */ - txd->txd_cmd = (len - 1); - /* But also set TXINT bit on a half of TXDESC. */ - if (sc->sc_txpending == (MEC_NTXDESC / 2)) - txd->txd_cmd |= MEC_TXCMD_TXINT; - - if (txs->txs_flags & MEC_TXS_TXDBUF) - txd->txd_cmd |= TXCMD_BUFSTART(MEC_TXDESCSIZE - buflen); - if (txs->txs_flags & MEC_TXS_TXDPTR1) { - txd->txd_cmd |= MEC_TXCMD_PTR1; - txd->txd_ptr[0] = TXPTR_LEN(txdlen - 1) | txdaddr; - /* - * Store a pointer to the packet so we can - * free it later. - */ - txs->txs_mbuf = m0; - } else { - txd->txd_ptr[0] = 0; - /* - * In this case all data are copied to buffer in txdesc, - * we can free TX mbuf here. - */ - m_freem(m0); - } - - DPRINTF(MEC_DEBUG_START, - ("mec_start: txd_cmd = 0x%llx, txd_ptr = 0x%llx\n", - txd->txd_cmd, txd->txd_ptr[0])); - DPRINTF(MEC_DEBUG_START, - ("mec_start: len = %d (0x%04x), buflen = %d (0x%02x)\n", - len, len, buflen, buflen)); - - /* Sync TX descriptor. */ - MEC_TXDESCSYNC(sc, nexttx, - BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE); - - /* Advance the TX pointer. */ - sc->sc_txpending++; - sc->sc_txlast = nexttx; - } - - if (sc->sc_txpending == MEC_NTXDESC) { - /* No more slots; notify upper layer. */ - ifq_set_oactive(&ifp->if_snd); - } - - if (sc->sc_txpending != opending) { - /* - * Cause a TX interrupt to happen on the last packet - * we enqueued. - */ - sc->sc_txdesc[sc->sc_txlast].txd_cmd |= MEC_TXCMD_TXINT; - MEC_TXCMDSYNC(sc, sc->sc_txlast, - BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE); - - /* Start TX. */ - bus_space_write_8(st, sh, MEC_TX_RING_PTR, - MEC_NEXTTX(sc->sc_txlast)); - - /* - * If the transmitter was idle, - * reset the txdirty pointer and re-enable TX interrupt. - */ - if (opending == 0) { - sc->sc_txdirty = firsttx; - bus_space_write_8(st, sh, MEC_TX_ALIAS, - MEC_TX_ALIAS_INT_ENABLE); - } - - /* Set a watchdog timer in case the chip flakes out. */ - ifp->if_timer = 5; - } -} - -void -mec_stop(struct ifnet *ifp) -{ - struct mec_softc *sc = ifp->if_softc; - struct mec_txsoft *txs; - int i; - - DPRINTF(MEC_DEBUG_STOP, ("mec_stop\n")); - - ifp->if_timer = 0; - ifp->if_flags &= ~IFF_RUNNING; - ifq_clr_oactive(&ifp->if_snd); - - timeout_del(&sc->sc_tick_ch); - mii_down(&sc->sc_mii); - - /* Disable DMA. */ - bus_space_write_8(sc->sc_st, sc->sc_sh, MEC_DMA_CONTROL, 0); - - /* Release any TX buffers. */ - for (i = 0; i < MEC_NTXDESC; i++) { - txs = &sc->sc_txsoft[i]; - if ((txs->txs_flags & MEC_TXS_TXDPTR1) != 0) { - bus_dmamap_unload(sc->sc_dmat, txs->txs_dmamap); - m_freem(txs->txs_mbuf); - txs->txs_mbuf = NULL; - } - } -} - -int -mec_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) -{ - struct mec_softc *sc = ifp->if_softc; - struct ifreq *ifr = (struct ifreq *)data; - int s, error = 0; - - s = splnet(); - - switch (cmd) { - case SIOCSIFADDR: - ifp->if_flags |= IFF_UP; - if (!(ifp->if_flags & IFF_RUNNING)) - mec_init(ifp); - break; - - case SIOCSIFFLAGS: - if (ifp->if_flags & IFF_UP) { - if (ifp->if_flags & IFF_RUNNING) - error = ENETRESET; - else - mec_init(ifp); - } else { - if (ifp->if_flags & IFF_RUNNING) - mec_stop(ifp); - } - break; - - case SIOCSIFMEDIA: - case SIOCGIFMEDIA: - error = ifmedia_ioctl(ifp, ifr, &sc->sc_mii.mii_media, cmd); - break; - - default: - error = ether_ioctl(ifp, &sc->sc_ac, cmd, data); - } - - if (error == ENETRESET) { - if (ifp->if_flags & IFF_RUNNING) - mec_iff(sc); - error = 0; - } - - splx(s); - return error; -} - -void -mec_watchdog(struct ifnet *ifp) -{ - struct mec_softc *sc = ifp->if_softc; - - printf("%s: device timeout\n", sc->sc_dev.dv_xname); - ifp->if_oerrors++; - - mec_init(ifp); -} - -void -mec_tick(void *arg) -{ - struct mec_softc *sc = arg; - int s; - - s = splnet(); - mii_tick(&sc->sc_mii); - splx(s); - - timeout_add_sec(&sc->sc_tick_ch, 1); -} - -void -mec_iff(struct mec_softc *sc) -{ - struct arpcom *ac = &sc->sc_ac; - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct ether_multi *enm; - struct ether_multistep step; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - uint64_t mchash = 0; - uint32_t control, hash; - - control = bus_space_read_8(st, sh, MEC_MAC_CONTROL); - control &= ~MEC_MAC_FILTER_MASK; - ifp->if_flags &= ~IFF_ALLMULTI; - - if (ifp->if_flags & IFF_PROMISC || ac->ac_multirangecnt > 0) { - ifp->if_flags |= IFF_ALLMULTI; - if (ifp->if_flags & IFF_PROMISC) - control |= MEC_MAC_FILTER_PROMISC; - else - control |= MEC_MAC_FILTER_ALLMULTI; - mchash = 0xffffffffffffffffULL; - } else { - ETHER_FIRST_MULTI(step, ac, enm); - while (enm != NULL) { - hash = ether_crc32_be(enm->enm_addrlo, - ETHER_ADDR_LEN) >> 26; - - mchash |= 1 << hash; - - ETHER_NEXT_MULTI(step, enm); - } - - if (ac->ac_multicnt > 0) - control |= MEC_MAC_FILTER_MATCHMULTI; - } - - bus_space_write_8(st, sh, MEC_MULTICAST, mchash); - bus_space_write_8(st, sh, MEC_MAC_CONTROL, control); -} - -int -mec_intr(void *arg) -{ - struct mec_softc *sc = arg; - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - struct ifnet *ifp = &sc->sc_ac.ac_if; - uint32_t statreg, statack, dmac; - int handled, sent; - - DPRINTF(MEC_DEBUG_INTR, ("mec_intr: called\n")); - - handled = sent = 0; - - for (;;) { - statreg = bus_space_read_8(st, sh, MEC_INT_STATUS); - - DPRINTF(MEC_DEBUG_INTR, - ("mec_intr: INT_STAT = 0x%x\n", statreg)); - - statack = statreg & MEC_INT_STATUS_MASK; - if (statack == 0) - break; - bus_space_write_8(st, sh, MEC_INT_STATUS, statack); - - handled = 1; - - if (statack & - (MEC_INT_RX_THRESHOLD | - MEC_INT_RX_FIFO_UNDERFLOW)) { - mec_rxintr(sc, statreg); - } - - dmac = bus_space_read_8(st, sh, MEC_DMA_CONTROL); - DPRINTF(MEC_DEBUG_INTR, - ("mec_intr: DMA_CONT = 0x%x\n", dmac)); - - if (statack & - (MEC_INT_TX_EMPTY | - MEC_INT_TX_PACKET_SENT | - MEC_INT_TX_ABORT)) { - mec_txintr(sc, statreg); - sent = 1; - } - - if (statack & - (MEC_INT_TX_LINK_FAIL | - MEC_INT_TX_MEM_ERROR | - MEC_INT_TX_ABORT | - MEC_INT_RX_DMA_UNDERFLOW)) { - printf("%s: mec_intr: interrupt status = 0x%x\n", - sc->sc_dev.dv_xname, statreg); - } - } - - if (sent) { - /* Try to get more packets going. */ - mec_start(ifp); - } - - return handled; -} - -void -mec_rxintr(struct mec_softc *sc, uint32_t stat) -{ - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct mbuf_list ml = MBUF_LIST_INITIALIZER(); - struct mbuf *m; - struct mec_rxdesc *rxd; - uint64_t rxstat; - u_int len; - int i, last; - - DPRINTF(MEC_DEBUG_RXINTR, ("mec_rxintr: called\n")); - - bus_space_write_8(st, sh, MEC_RX_ALIAS, 0); - - last = (stat & MEC_INT_RX_MCL_FIFO_ALIAS) >> 8; - /* XXX does alias count mod 32 even if 16 descs are set up? */ - last &= MEC_NRXDESC_MASK; - - if (stat & MEC_INT_RX_FIFO_UNDERFLOW) - last = (last - 1) & MEC_NRXDESC_MASK; - - DPRINTF(MEC_DEBUG_RXINTR, ("mec_rxintr: rxptr %d last %d\n", - sc->sc_rxptr, last)); - for (i = sc->sc_rxptr; i != last; i = MEC_NEXTRX(i)) { - - MEC_RXSTATSYNC(sc, i, BUS_DMASYNC_POSTREAD); - rxd = &sc->sc_rxdesc[i]; - rxstat = rxd->rxd_stat; - - DPRINTF(MEC_DEBUG_RXINTR, - ("mec_rxintr: rxstat = 0x%llx, rxptr = %d\n", - rxstat, i)); - DPRINTF(MEC_DEBUG_RXINTR, ("mec_rxintr: rxfifo = 0x%x\n", - (u_int)bus_space_read_8(st, sh, MEC_RX_FIFO))); - - if ((rxstat & MEC_RXSTAT_RECEIVED) == 0) { - /* Status not received but FIFO counted? Drop it! */ - goto dropit; - } - - len = rxstat & MEC_RXSTAT_LEN; - - if (len < ETHER_MIN_LEN || - len > ETHER_MAX_LEN) { - /* Invalid length packet; drop it. */ - DPRINTF(MEC_DEBUG_RXINTR, - ("mec_rxintr: wrong packet\n")); - dropit: - ifp->if_ierrors++; - rxd->rxd_stat = 0; - MEC_RXSTATSYNC(sc, i, BUS_DMASYNC_PREREAD); - bus_space_write_8(st, sh, MEC_MCL_RX_FIFO, - MEC_CDRXADDR(sc, i)); - continue; - } - - if (rxstat & - (MEC_RXSTAT_BADPACKET | - MEC_RXSTAT_LONGEVENT | - MEC_RXSTAT_INVALID | - MEC_RXSTAT_CRCERROR | - MEC_RXSTAT_VIOLATION)) { - printf("%s: mec_rxintr: status = 0x%llx\n", - sc->sc_dev.dv_xname, rxstat); - goto dropit; - } - - /* - * Now allocate an mbuf (and possibly a cluster) to hold - * the received packet. - */ - MGETHDR(m, M_DONTWAIT, MT_DATA); - if (m == NULL) { - printf("%s: unable to allocate RX mbuf\n", - sc->sc_dev.dv_xname); - goto dropit; - } - if (len > (MHLEN - ETHER_ALIGN)) { - MCLGET(m, M_DONTWAIT); - if ((m->m_flags & M_EXT) == 0) { - printf("%s: unable to allocate RX cluster\n", - sc->sc_dev.dv_xname); - m_freem(m); - m = NULL; - goto dropit; - } - } - - /* - * Note MEC chip seems to insert 2 byte padding at the start of - * RX buffer, but we copy whole buffer to avoid unaligned copy. - */ - MEC_RXBUFSYNC(sc, i, len + ETHER_ALIGN, BUS_DMASYNC_POSTREAD); - memcpy(mtod(m, caddr_t), rxd->rxd_buf, - ETHER_ALIGN + len - ETHER_CRC_LEN); - MEC_RXBUFSYNC(sc, i, ETHER_MAX_LEN, BUS_DMASYNC_PREREAD); - m->m_data += ETHER_ALIGN; - - /* Put RX buffer into FIFO again. */ - rxd->rxd_stat = 0; - MEC_RXSTATSYNC(sc, i, BUS_DMASYNC_PREREAD); - bus_space_write_8(st, sh, MEC_MCL_RX_FIFO, MEC_CDRXADDR(sc, i)); - - m->m_pkthdr.len = m->m_len = len - ETHER_CRC_LEN; - - ml_enqueue(&ml, m); - } - - /* Update RX pointer. */ - sc->sc_rxptr = i; - - bus_space_write_8(st, sh, MEC_RX_ALIAS, - (MEC_NRXDESC << MEC_DMA_RX_INT_THRESH_SHIFT) | - MEC_DMA_RX_INT_ENABLE); - - if_input(ifp, &ml); -} - -void -mec_txintr(struct mec_softc *sc, uint32_t stat) -{ - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct mec_txdesc *txd; - struct mec_txsoft *txs; - bus_dmamap_t dmamap; - uint64_t txstat; - int i, last; - u_int col; - - ifq_clr_oactive(&ifp->if_snd); - - DPRINTF(MEC_DEBUG_TXINTR, ("mec_txintr: called\n")); - - bus_space_write_8(sc->sc_st, sc->sc_sh, MEC_TX_ALIAS, 0); - last = (stat & MEC_INT_TX_RING_BUFFER_ALIAS) >> 16; - - DPRINTF(MEC_DEBUG_TXINTR, ("mec_txintr: dirty %d last %d\n", - sc->sc_txdirty, last)); - for (i = sc->sc_txdirty; i != last && sc->sc_txpending != 0; - i = MEC_NEXTTX(i), sc->sc_txpending--) { - txd = &sc->sc_txdesc[i]; - - MEC_TXDESCSYNC(sc, i, - BUS_DMASYNC_POSTREAD|BUS_DMASYNC_POSTWRITE); - - txstat = txd->txd_stat; - DPRINTF(MEC_DEBUG_TXINTR, - ("mec_txintr: dirty = %d, txstat = 0x%llx\n", - i, txstat)); - if ((txstat & MEC_TXSTAT_SENT) == 0) { - MEC_TXCMDSYNC(sc, i, BUS_DMASYNC_PREREAD); - break; - } - - txs = &sc->sc_txsoft[i]; - if ((txs->txs_flags & MEC_TXS_TXDPTR1) != 0) { - dmamap = txs->txs_dmamap; - bus_dmamap_sync(sc->sc_dmat, dmamap, 0, - dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE); - bus_dmamap_unload(sc->sc_dmat, dmamap); - m_freem(txs->txs_mbuf); - txs->txs_mbuf = NULL; - } - - if ((txstat & MEC_TXSTAT_SUCCESS) == 0) { - printf("%s: TX error: txstat = 0x%llx\n", - sc->sc_dev.dv_xname, txstat); - ifp->if_oerrors++; - } else { - col = (txstat & MEC_TXSTAT_COLCNT) >> - MEC_TXSTAT_COLCNT_SHIFT; - ifp->if_collisions += col; - } - } - - /* Update the dirty TX buffer pointer. */ - sc->sc_txdirty = i; - DPRINTF(MEC_DEBUG_INTR, - ("mec_txintr: sc_txdirty = %2d, sc_txpending = %2d\n", - sc->sc_txdirty, sc->sc_txpending)); - - /* Cancel the watchdog timer if there are no pending TX packets. */ - if (sc->sc_txpending == 0) - ifp->if_timer = 0; - else if (!(stat & MEC_INT_TX_EMPTY)) - bus_space_write_8(sc->sc_st, sc->sc_sh, MEC_TX_ALIAS, - MEC_TX_ALIAS_INT_ENABLE); -} diff --git a/sys/arch/sgi/dev/if_mecreg.h b/sys/arch/sgi/dev/if_mecreg.h deleted file mode 100644 index 6cc7933a68d..00000000000 --- a/sys/arch/sgi/dev/if_mecreg.h +++ /dev/null @@ -1,149 +0,0 @@ -/* $OpenBSD: if_mecreg.h,v 1.3 2018/12/10 05:42:34 visa Exp $ */ -/* $NetBSD: if_mecreg.h,v 1.2 2004/07/11 03:13:04 tsutsui Exp $ */ - -/* - * Copyright (c) 2001 Christopher Sekiya - * Copyright (c) 2000 Soren S. Jorvang - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * MACE MAC110 Ethernet register definitions - */ - -#define MEC_MAC_CONTROL 0x00 -#define MEC_MAC_CORE_RESET 0x0000000000000001 /* reset signal */ -#define MEC_MAC_FULL_DUPLEX 0x0000000000000002 /* 1 to enable */ -#define MEC_MAC_INT_LOOPBACK 0x0000000000000004 /* 0 = normal op */ -#define MEC_MAC_SPEED_SELECT 0x0000000000000008 /* 0/1 10/100 */ -#define MEC_MAC_MII_SELECT 0x0000000000000010 /* MII/SIA */ -#define MEC_MAC_FILTER_MASK 0x0000000000000060 -#define MEC_MAC_FILTER_STATION 0x0000000000000000 -#define MEC_MAC_FILTER_MATCHMULTI 0x0000000000000020 -#define MEC_MAC_FILTER_ALLMULTI 0x0000000000000040 -#define MEC_MAC_FILTER_PROMISC 0x0000000000000060 -#define MEC_MAC_LINK_FAILURE 0x0000000000000080 -#define MEC_MAC_IPGT 0x0000000000007f00 /* interpacket gap */ -#define MEC_MAC_IPGT_SHIFT 8 -#define MEC_MAC_IPGR1 0x00000000003f8000 -#define MEC_MAC_IPGR1_SHIFT 15 -#define MEC_MAC_IPGR2 0x000000001fc00000 -#define MEC_MAC_IPGR2_SHIFT 22 -#define MEC_MAC_REVISION 0x00000000e0000000 -#define MEC_MAC_REVISION_SHIFT 29 - -#define MEC_MAC_IPG_DEFAULT \ - (21 << MEC_MAC_IPGT_SHIFT) | \ - (17 << MEC_MAC_IPGR1_SHIFT) | \ - (11 << MEC_MAC_IPGR2_SHIFT) - -#define MEC_INT_STATUS 0x08 -#define MEC_INT_STATUS_MASK 0x00000000000000ff -#define MEC_INT_TX_EMPTY 0x0000000000000001 -#define MEC_INT_TX_PACKET_SENT 0x0000000000000002 -#define MEC_INT_TX_LINK_FAIL 0x0000000000000004 -#define MEC_INT_TX_MEM_ERROR 0x0000000000000008 -#define MEC_INT_TX_ABORT 0x0000000000000010 -#define MEC_INT_RX_THRESHOLD 0x0000000000000020 -#define MEC_INT_RX_FIFO_UNDERFLOW 0x0000000000000040 -#define MEC_INT_RX_DMA_UNDERFLOW 0x0000000000000080 -#define MEC_INT_RX_MCL_FIFO_ALIAS 0x0000000000001f00 -#define MEC_INT_TX_RING_BUFFER_ALIAS 0x0000000001ff0000 -#define MEC_INT_RX_SEQUENCE_NUMBER 0x000000003e000000 -#define MEC_INT_MCAST_HASH_OUTPUT 0x0000000040000000 - -#define MEC_DMA_CONTROL 0x10 -#define MEC_DMA_TX_INT_ENABLE 0x0000000000000001 -#define MEC_DMA_TX_DMA_ENABLE 0x0000000000000002 -#define MEC_DMA_TX_RING_SIZE_MASK 0x000000000000000c -#define MEC_DMA_RX_INT_THRESHOLD 0x00000000000001f0 -#define MEC_DMA_RX_INT_THRESH_SHIFT 4 -#define MEC_DMA_RX_INT_ENABLE 0x0000000000000200 -#define MEC_DMA_RX_RUNT 0x0000000000000400 -#define MEC_DMA_RX_PACKET_GATHER 0x0000000000000800 -#define MEC_DMA_RX_DMA_OFFSET 0x0000000000007000 -#define MEC_DMA_RX_DMA_OFFSET_SHIFT 12 -#define MEC_DMA_RX_DMA_ENABLE 0x0000000000008000 - -#define MEC_TIMER 0x18 -#define MEC_TX_ALIAS 0x20 -#define MEC_TX_ALIAS_INT_ENABLE 0x0000000000000001 - -#define MEC_RX_ALIAS 0x28 -#define MEC_RX_ALIAS_INT_ENABLE 0x0000000000000200 -#define MEC_RX_ALIAS_INT_THRESHOLD 0x00000000000001f0 - -#define MEC_TX_RING_PTR 0x30 -#define MEC_TX_RING_WRITE_PTR 0x00000000000001ff -#define MEC_TX_RING_READ_PTR 0x0000000001ff0000 -#define MEC_TX_RING_PTR_ALIAS 0x38 - -#define MEC_RX_FIFO 0x40 -#define MEC_RX_FIFO_ELEMENT_COUNT 0x000000000000001f -#define MEC_RX_FIFO_READ_PTR 0x0000000000000f00 -#define MEC_RX_FIFO_GEN_NUMBER 0x0000000000001000 -#define MEC_RX_FIFO_WRITE_PTR 0x00000000000f0000 -#define MEC_RX_FIFO_GEN_NUMBER_2 0x0000000000100000 - -#define MEC_RX_FIFO_ALIAS1 0x48 -#define MEC_RX_FIFO_ALIAS2 0x50 -#define MEC_TX_VECTOR 0x58 -#define MEC_IRQ_VECTOR 0x58 - -#define MEC_PHY_DATA 0x60 -#define MEC_PHY_DATA_BUSY 0x00010000 -#define MEC_PHY_DATA_VALUE 0x0000ffff - -#define MEC_PHY_ADDRESS 0x68 -#define MEC_PHY_ADDR_REGISTER 0x0000001f -#define MEC_PHY_ADDR_DEVICE 0x000003e0 -#define MEC_PHY_ADDR_DEVSHIFT 5 - -#define MEC_PHY_READ_INITIATE 0x70 -#define MEC_PHY_BACKOFF 0x78 - -#define MEC_STATION 0xa0 -#define MEC_STATION_ALT 0xa8 -#define MEC_STATION_MASK 0x0000ffffffffffffULL - -#define MEC_MULTICAST 0xb0 -#define MEC_TX_RING_BASE 0xb8 -#define MEC_TX_PKT1_CMD_1 0xc0 -#define MEC_TX_PKT1_BUFFER_1 0xc8 -#define MEC_TX_PKT1_BUFFER_2 0xd0 -#define MEC_TX_PKT1_BUFFER_3 0xd8 -#define MEC_TX_PKT2_CMD_1 0xe0 -#define MEC_TX_PKT2_BUFFER_1 0xe8 -#define MEC_TX_PKT2_BUFFER_2 0xf0 -#define MEC_TX_PKT2_BUFFER_3 0xf8 - -#define MEC_MCL_RX_FIFO 0x100 - -#define MEC_NREGS 0x200 diff --git a/sys/arch/sgi/dev/impact.c b/sys/arch/sgi/dev/impact.c deleted file mode 100644 index 9fc5243cf81..00000000000 --- a/sys/arch/sgi/dev/impact.c +++ /dev/null @@ -1,776 +0,0 @@ -/* $OpenBSD: impact.c,v 1.12 2020/06/06 10:52:30 visa Exp $ */ - -/* - * Copyright (c) 2010, 2012 Miodrag Vallat. - * Copyright (c) 2009, 2010 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Driver for the SGI Impact and ImpactSR graphics board. - */ - -/* - * The details regarding the design and operation of this hardware, along with - * the necessary magic numbers, are only available thanks to the reverse - * engineering work undertaken by Stanislaw Skowronek <skylark@linux-mips.org>. - * - * Differences between ImpactSR and Impact researched by Peter Fuerst - * <post@pfrst.de>. - */ - -/* - * This driver currently lacks support for the HQ3 and HQ4 DMA engines, which - * could be used to speed up rasops `copy' operations a lot by doing - * framebuffer to memory, then memory to framebuffer operations. - * - * Of course, in an ideal world, these operations would be done with - * framebuffer to framebuffer operations, but according to Skowronek, these - * operations are not reliable and IRIX' Xsgi X server does not even try to - * use them. - * - * Thus this driver currently implements rasops `copy' operations by repainting - * affected areas with PIO routines. This is unfortunately slower than DMA, - * but this will work until I have more time to spend on this. -- miod - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <machine/bus.h> - -#include <sgi/dev/gl.h> -#include <sgi/dev/impactreg.h> -#include <sgi/dev/impactvar.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsdisplayvar.h> -#include <dev/rasops/rasops.h> - -struct cfdriver impact_cd = { - NULL, "impact", DV_DULL, -}; - -#define IMPACT_WIDTH 1280 -#define IMPACT_HEIGHT 1024 -#define IMPACT_DEPTH 32 - -struct impact_screen { - struct rasops_info ri; - uint32_t defattr; - struct wsdisplay_charcell *bs; - - struct impact_softc *sc; - int has_hq4; - - bus_addr_t fifo_status; - bus_addr_t cfifo; - - bus_space_tag_t iot; - bus_space_handle_t ioh; - - struct wsscreen_descr wsd; - struct wsscreen_list wsl; - struct wsscreen_descr *scrlist[1]; -}; - -static inline void - impact_cmd_fifo_write(struct impact_screen *, uint64_t, uint32_t, int); -int impact_cmd_fifo_wait(struct impact_screen *); - -void impact_setup(struct impact_screen *, int); -int impact_init_screen(struct impact_screen *); - -/* - * Hardware acceleration (sort of) for rasops. - */ -void impact_rop(struct impact_screen *, int, int, int, int, int, u_int); -void impact_fillrect(struct impact_screen *, int, int, int, int, u_int); -int impact_do_cursor(struct rasops_info *); -int impact_putchar(void *, int, int, u_int, uint32_t); -int impact_copycols(void *, int, int, int, int); -int impact_erasecols(void *, int, int, int, uint32_t); -int impact_copyrows(void *, int, int, int); -int impact_eraserows(void *, int, int, uint32_t); - -/* - * Interfaces for wscons. - */ -int impact_ioctl(void *, u_long, caddr_t, int, struct proc *); -paddr_t impact_mmap(void *, off_t, int); -int impact_alloc_screen(void *, const struct wsscreen_descr *, void **, - int *, int *, uint32_t *); -void impact_free_screen(void *, void *); -int impact_show_screen(void *, void *, int, void (*)(void *, int, int), - void *); -int impact_load_font(void *, void *, struct wsdisplay_font *); -int impact_list_font(void *, struct wsdisplay_font *); - -static struct impact_screen impact_cons; - -struct wsdisplay_accessops impact_accessops = { - .ioctl = impact_ioctl, - .mmap = impact_mmap, - .alloc_screen = impact_alloc_screen, - .free_screen = impact_free_screen, - .show_screen = impact_show_screen, - .load_font = impact_load_font, - .list_font = impact_list_font -}; - -int -impact_attach_common(struct impact_softc *sc, bus_space_tag_t iot, - bus_space_handle_t ioh, int console, int has_hq4) -{ - struct wsemuldisplaydev_attach_args waa; - struct impact_screen *scr; - - if (console) { - /* - * Setup has already been done via impact_cnattach(). - */ - scr = &impact_cons; - scr->sc = sc; - sc->curscr = scr; - sc->console = 1; - } else { - /* - * Setup screen data. - */ - scr = malloc(sizeof(struct impact_screen), M_DEVBUF, - M_NOWAIT | M_ZERO); - if (scr == NULL) { - printf("failed to allocate screen memory!\n"); - return ENOMEM; - } - - scr->iot = iot; - scr->ioh = ioh; - scr->sc = sc; - sc->curscr = scr; - - /* Setup hardware and clear screen. */ - impact_setup(scr, has_hq4); - if (impact_init_screen(scr) != 0) { - printf("failed to allocate memory\n"); - free(scr, M_DEVBUF, sizeof *scr); - return ENOMEM; - } - } - - scr->scrlist[0] = &scr->wsd; - scr->wsl.nscreens = 1; - scr->wsl.screens = (const struct wsscreen_descr **)scr->scrlist; - - waa.console = sc->console; - waa.scrdata = &scr->wsl; - waa.accessops = &impact_accessops; - waa.accesscookie = scr; - waa.defaultscreens = 0; - - config_found(&sc->sc_dev, &waa, wsemuldisplaydevprint); - - return 0; -} - -int -impact_init_screen(struct impact_screen *scr) -{ - struct rasops_info *ri = &scr->ri; - int i; - uint32_t c, r, g, b; - - bzero(ri, sizeof(struct rasops_info)); - - ri->ri_flg = RI_CENTER | RI_FULLCLEAR; - ri->ri_depth = IMPACT_DEPTH; - ri->ri_width = IMPACT_WIDTH; - ri->ri_height = IMPACT_HEIGHT; - ri->ri_stride = IMPACT_WIDTH * IMPACT_DEPTH / 8; - - rasops_init(ri, 160, 160); - - /* - * Allocate backing store to remember character cells, to - * be able to fulfill scrolling requests. - */ - if (scr->bs == NULL) { - scr->bs = mallocarray(ri->ri_rows, - ri->ri_cols * sizeof(struct wsdisplay_charcell), M_DEVBUF, - M_NOWAIT | M_ZERO); - if (scr->bs == NULL) - return ENOMEM; - } - - ri->ri_hw = scr; - - ri->ri_ops.putchar = impact_putchar; - ri->ri_do_cursor = impact_do_cursor; - ri->ri_ops.copyrows = impact_copyrows; - ri->ri_ops.copycols = impact_copycols; - ri->ri_ops.eraserows = impact_eraserows; - ri->ri_ops.erasecols = impact_erasecols; - - /* - * Slightly rework the colormap. impact_putchar() will use a 4:8:4 - * colormap for the background color instead of the 8:8:8 colormap - * used everywhere else, so we need to make sure the low 4 bits of - * all red and blue entries are zero, at least for the entries - * used in emulation mode. - */ - for (i = 0; i < 16; i++) { - c = ri->ri_devcmap[i]; - /* this relies upon the default ri->ri_[bgr]{num,pos} values */ - r = c & 0x000000ff; - g = c & 0x0000ff00; - b = c & 0x00ff0000; - - if (r < (0xf0 << 0) && (r & (0x08 << 0)) != 0) - r += 0x10 << 0; - r &= 0xf0 << 0; - if (b < (0xf0 << 16) && (b & (0x08 << 16)) != 0) - b += 0x10 << 16; - b &= 0xf0 << 16; - - ri->ri_devcmap[i] = b | g | r; - } - - /* clear display */ - impact_fillrect(scr, 0, 0, ri->ri_width, ri->ri_height, - ri->ri_devcmap[WSCOL_BLACK]); - - strlcpy(scr->wsd.name, "std", sizeof(scr->wsd.name)); - scr->wsd.ncols = ri->ri_cols; - scr->wsd.nrows = ri->ri_rows; - scr->wsd.textops = &ri->ri_ops; - scr->wsd.fontwidth = ri->ri_font->fontwidth; - scr->wsd.fontheight = ri->ri_font->fontheight; - scr->wsd.capabilities = ri->ri_caps; - - return 0; -} - -/* - * Hardware initialization. - */ - -void -impact_setup(struct impact_screen *scr, int has_hq4) -{ - bus_addr_t xmap_base; - bus_addr_t vc3_base; - - scr->has_hq4 = has_hq4; - - if (has_hq4) { - xmap_base = IMPACTSR_XMAP_BASE; - vc3_base = IMPACTSR_VC3_BASE; - scr->fifo_status = IMPACTSR_FIFOSTATUS; - scr->cfifo = IMPACTSR_CFIFO; - } else { - xmap_base = IMPACT_XMAP_BASE; - vc3_base = IMPACT_VC3_BASE; - scr->fifo_status = IMPACT_FIFOSTATUS; - scr->cfifo = IMPACT_CFIFO; - } - - if (has_hq4) { - /* HQ4 initialization */ - bus_space_write_4(scr->iot, scr->ioh, IMPACTSR_CFIFO_HW, - 0x00000047); - bus_space_write_4(scr->iot, scr->ioh, IMPACTSR_CFIFO_LW, - 0x00000014); - bus_space_write_4(scr->iot, scr->ioh, IMPACTSR_CFIFO_DELAY, - 0x00000064); - bus_space_write_4(scr->iot, scr->ioh, IMPACTSR_DFIFO_HW, - 0x00000040); - bus_space_write_4(scr->iot, scr->ioh, IMPACTSR_DFIFO_LW, - 0x00000010); - bus_space_write_4(scr->iot, scr->ioh, IMPACTSR_DFIFO_DELAY, - 0x00000000); - } else { - /* HQ3 initialization */ - bus_space_write_4(scr->iot, scr->ioh, IMPACT_CFIFO_HW, - 0x00000020); - bus_space_write_4(scr->iot, scr->ioh, IMPACT_CFIFO_LW, - 0x00000014); - bus_space_write_4(scr->iot, scr->ioh, IMPACT_CFIFO_DELAY, - 0x00000064); - bus_space_write_4(scr->iot, scr->ioh, IMPACT_DFIFO_HW, - 0x00000028); - bus_space_write_4(scr->iot, scr->ioh, IMPACT_DFIFO_LW, - 0x00000014); - bus_space_write_4(scr->iot, scr->ioh, IMPACT_DFIFO_DELAY, - 0x00000fff); - } - - /* VC3 initialization: disable hardware cursor */ - bus_space_write_4(scr->iot, scr->ioh, - vc3_base + IMPACTSR_VC3_INDEXDATA, 0x1d000100); - - /* RSS initialization */ - impact_cmd_fifo_write(scr, IMPACTSR_CMD_COLORMASKLSBSA, 0xffffff, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_COLORMASKLSBSB, 0xffffff, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_COLORMASKMSBS, 0, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_XFRMASKLO, 0xffffff, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_XFRMASKHI, 0xffffff, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_DRBPOINTERS, 0xc8240, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_CONFIG, 0xcac, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_XYWIN, - IMPACTSR_YXCOORDS(0, 0x3ff), 0); - - /* XMAP initialization */ - bus_space_write_1(scr->iot, scr->ioh, - xmap_base + IMPACTSR_XMAP_PP1SELECT, 0x01); - bus_space_write_1(scr->iot, scr->ioh, - xmap_base + IMPACTSR_XMAP_INDEX, 0x00); - bus_space_write_4(scr->iot, scr->ioh, - xmap_base + IMPACTSR_XMAP_MAIN_MODE, 0x000007a4); -} - -/* - * Write to the command FIFO. - */ -static inline void -impact_cmd_fifo_write(struct impact_screen *scr, uint64_t reg, uint32_t val, - int exec) -{ - uint64_t cmd; - - cmd = IMPACTSR_CFIFO_WRITE | (reg << IMPACTSR_CFIFO_REG_SHIFT); - if (exec) - cmd |= IMPACTSR_CFIFO_EXEC; - bus_space_write_8(scr->iot, scr->ioh, scr->cfifo, cmd | val); -} - -/* - * Wait until the command FIFO is empty. - */ -int -impact_cmd_fifo_wait(struct impact_screen *scr) -{ - u_int32_t val, timeout = 1000000; -#ifdef DIAGNOSTIC - struct impact_softc *sc = scr->sc; -#endif - - val = bus_space_read_4(scr->iot, scr->ioh, scr->fifo_status); - while ((val & IMPACTSR_FIFO_MASK) != 0) { - delay(1); - if (--timeout == 0) { -#ifdef DIAGNOSTIC - if (sc != NULL && sc->console == 0) - printf("%s: timeout waiting for command fifo\n", - sc != NULL ? sc->sc_dev.dv_xname : - impact_cd.cd_name); -#endif - return ETIMEDOUT; - } - val = bus_space_read_4(scr->iot, scr->ioh, scr->fifo_status); - } - - return 0; -} - -/* - * Interfaces for wscons. - */ - -int -impact_ioctl(void *v, u_long cmd, caddr_t data, int flags, struct proc *p) -{ - struct impact_screen *scr = (struct impact_screen *)v; - struct rasops_info *ri; - struct wsdisplay_fbinfo *fb; - - switch (cmd) { - case WSDISPLAYIO_GTYPE: - *(u_int *)data = WSDISPLAY_TYPE_IMPACT; - break; - case WSDISPLAYIO_GINFO: - fb = (struct wsdisplay_fbinfo *)data; - ri = &scr->ri; - fb->height = ri->ri_height; - fb->width = ri->ri_width; - fb->depth = ri->ri_depth; - fb->cmsize = 0; - break; -#if 0 - case WSDISPLAYIO_LINEBYTES: - ri = &scr->ri; - *(u_int *)data = ri->ri_stride; - break; -#endif - default: - return -1; - } - - return 0; -} - -paddr_t -impact_mmap(void *v, off_t offset, int prot) -{ - if (offset < 0 || (offset & PAGE_MASK) != 0) - return -1; - - return -1; -} - -int -impact_alloc_screen(void *v, const struct wsscreen_descr *type, - void **cookiep, int *curxp, int *curyp, uint32_t *attrp) -{ - struct impact_screen *scr = (struct impact_screen *)v; - struct rasops_info *ri = &scr->ri; - struct impact_softc *sc = (struct impact_softc *)scr->sc; - - /* We do not allow multiple consoles at the moment. */ - if (sc->nscreens > 0) - return ENOMEM; - - sc->nscreens++; - - *cookiep = ri; - *curxp = 0; - *curyp = 0; - ri->ri_ops.pack_attr(ri, 0, 0, 0, &scr->defattr); - *attrp = scr->defattr; - - return 0; -} - -void -impact_free_screen(void *v, void *cookie) -{ - /* We do not allow multiple consoles at the moment. */ -} - -int -impact_show_screen(void *v, void *cookie, int waitok, - void (*cb)(void *, int, int), void *cbarg) -{ - /* We do not allow multiple consoles at the moment. */ - return 0; -} - -int -impact_load_font(void *v, void *emulcookie, struct wsdisplay_font *font) -{ - struct impact_screen *scr = (struct impact_screen *)v; - struct rasops_info *ri = &scr->ri; - - return rasops_load_font(ri, emulcookie, font); -} - -int -impact_list_font(void *v, struct wsdisplay_font *font) -{ - struct impact_screen *scr = (struct impact_screen *)v; - struct rasops_info *ri = &scr->ri; - - return rasops_list_font(ri, font); -} - -/* - * Hardware accelerated functions. - */ - -void -impact_rop(struct impact_screen *scr, int x, int y, int w, int h, int op, - u_int c) -{ - impact_cmd_fifo_wait(scr); - if (op == OPENGL_LOGIC_OP_COPY) - impact_cmd_fifo_write(scr, IMPACTSR_CMD_PP1FILLMODE, - IMPACTSR_PP1FILLMODE(0x6300, op), 0); - else - impact_cmd_fifo_write(scr, IMPACTSR_CMD_PP1FILLMODE, - IMPACTSR_PP1FILLMODE(0x6304, op), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_FILLMODE, 0, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_PACKEDCOLOR, - c /* & 0x00ffffff */, 0); /* no mask, ri_devcmap is 24 bit */ - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BLOCKXYSTARTI, - IMPACTSR_XYCOORDS(x, y), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BLOCKXYENDI, - IMPACTSR_XYCOORDS(x + w - 1, y + h - 1), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_IR_ALIAS, 0x18, 1); -} - -void -impact_fillrect(struct impact_screen *scr, int x, int y, int w, int h, u_int c) -{ - impact_rop(scr, x, y, w, h, OPENGL_LOGIC_OP_COPY, c); -} - -int -impact_do_cursor(struct rasops_info *ri) -{ - struct impact_screen *scr = ri->ri_hw; - int y, x, w, h, fg, bg; - - w = ri->ri_font->fontwidth; - h = ri->ri_font->fontheight; - x = ri->ri_xorigin + ri->ri_ccol * w; - y = ri->ri_yorigin + ri->ri_crow * h; - - ri->ri_ops.unpack_attr(ri, scr->defattr, &fg, &bg, NULL); - - impact_rop(scr, x, y, w, h, OPENGL_LOGIC_OP_XOR, ri->ri_devcmap[fg]); - impact_cmd_fifo_wait(scr); - - return 0; -} - -int -impact_putchar(void *cookie, int row, int col, u_int uc, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct impact_screen *scr = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int x, y, w, h, bg, fg, ul; - u_int8_t *fontbitmap; - u_int32_t bg484; - u_int chunk; - struct wsdisplay_charcell *cell; - - /* Update backing store. */ - cell = scr->bs + row * ri->ri_cols + col; - cell->uc = uc; - cell->attr = attr; - - w = font->fontwidth; - h = font->fontheight; - x = ri->ri_xorigin + col * w; - y = ri->ri_yorigin + row * h; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, &ul); - - /* Handle spaces with a single fillrect. */ - if ((uc == ' ' || uc == 0) && ul == 0) { - impact_fillrect(scr, x, y, w, h, ri->ri_devcmap[bg]); - return 0; - } - - fontbitmap = (u_int8_t *)(font->data + (uc - font->firstchar) * - ri->ri_fontscale); - - /* - * 1bpp pixel expansion; fast but uses a 4:8:4 background color - * instead of the expected 8:8:8. - */ - bg484 = ri->ri_devcmap[bg]; /* 00BBGGRR */ - bg484 = ((bg484 & 0x00f000f0) >> 4) | /* 00B000R */ - (bg484 & 0x0000ff00); /* 0000GG00 */ - - impact_cmd_fifo_wait(scr); - - impact_cmd_fifo_write(scr, IMPACTSR_CMD_PP1FILLMODE, - IMPACTSR_PP1FILLMODE(0x6300, OPENGL_LOGIC_OP_COPY), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_FILLMODE, - 0x00400018, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_PACKEDCOLOR, - ri->ri_devcmap[fg], 0); - - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BKGRD_RG, - (bg484 & 0x0000ffff) << 8, 0); /* 00 GG0R 00 */ - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BKGRD_BA, - (bg484 & 0x00ff0000) >> 8, 0); /* 00 000B 00 */ - - if (w <= 8) { - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BLOCKXYSTARTI, - IMPACTSR_XYCOORDS(x, y), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BLOCKXYENDI, - IMPACTSR_XYCOORDS(x + w - 1, y + h - 1), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_IR_ALIAS, 0x18, 1); - - for (; h != 0; h--) { - chunk = *fontbitmap; - fontbitmap += font->stride; - - /* Handle underline. */ - if (ul && h == 1) - chunk = 0xff; - - impact_cmd_fifo_wait(scr); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_CHAR_H, - chunk << 24, 1); - } - } else { - for (; h != 0; h--) { - chunk = *(u_int16_t *)fontbitmap; - fontbitmap += font->stride; - - /* Handle underline. */ - if (ul && h == 1) - chunk = 0xffff; - - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BLOCKXYSTARTI, - IMPACTSR_XYCOORDS(x, y), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_BLOCKXYENDI, - IMPACTSR_XYCOORDS(x + w - 1, y + 1 - 1), 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_IR_ALIAS, - 0x18, 1); - - impact_cmd_fifo_wait(scr); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_CHAR_H, - chunk << 16, 0); - impact_cmd_fifo_write(scr, IMPACTSR_CMD_CHAR_L, - chunk << 24, 1); - - y++; - } - } - - return 0; -} - -int -impact_copycols(void *cookie, int row, int src, int dst, int num) -{ - struct rasops_info *ri = cookie; - struct impact_screen *scr = ri->ri_hw; - struct wsdisplay_charcell *cell; - - /* Copy columns in backing store. */ - cell = scr->bs + row * ri->ri_cols; - memmove(cell + dst, cell + src, - num * sizeof(struct wsdisplay_charcell)); - - /* Repaint affected area */ - cell += dst; - for (; num != 0; num--, dst++, cell++) - impact_putchar(cookie, row, dst, cell->uc, cell->attr); - - return 0; -} - -int -impact_erasecols(void *cookie, int row, int col, int num, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct impact_screen *scr = ri->ri_hw; - int bg, fg, i; - struct wsdisplay_charcell *cell; - - /* Erase columns in backing store. */ - cell = scr->bs + row * ri->ri_cols + col; - for (i = num; i != 0; i--, cell++) { - cell->uc = 0; - cell->attr = attr; - } - - ri->ri_ops.unpack_attr(cookie, attr, &fg, &bg, NULL); - - row *= ri->ri_font->fontheight; - col *= ri->ri_font->fontwidth; - num *= ri->ri_font->fontwidth; - - impact_fillrect(scr, ri->ri_xorigin + col, ri->ri_yorigin + row, - num, ri->ri_font->fontheight, ri->ri_devcmap[bg]); - - return 0; -} - -int -impact_copyrows(void *cookie, int src, int dst, int num) -{ - struct rasops_info *ri = cookie; - struct impact_screen *scr = ri->ri_hw; - struct wsdisplay_charcell *cell; - int col; - - /* Copy rows in backing store. */ - cell = scr->bs + dst * ri->ri_cols; - memmove(cell, scr->bs + src * ri->ri_cols, - num * ri->ri_cols * sizeof(struct wsdisplay_charcell)); - - /* Repaint affected area */ - for (; num != 0; num--, dst++) { - for (col = 0; col < ri->ri_cols; col++, cell++) - impact_putchar(cookie, dst, col, cell->uc, cell->attr); - } - - return 0; -} - -int -impact_eraserows(void *cookie, int row, int num, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct impact_screen *scr = ri->ri_hw; - int x, y, w, bg, fg; - struct wsdisplay_charcell *cell; - - /* Erase rows in backing store. */ - cell = scr->bs + row * ri->ri_cols; - for (x = ri->ri_cols; x != 0; x--, cell++) { - cell->uc = 0; - cell->attr = attr; - } - for (y = 1; y < num; y++) - memmove(scr->bs + (row + y) * ri->ri_cols, - scr->bs + row * ri->ri_cols, - ri->ri_cols * sizeof(struct wsdisplay_charcell)); - - ri->ri_ops.unpack_attr(cookie, attr, &fg, &bg, NULL); - - if ((num == ri->ri_rows) && ISSET(ri->ri_flg, RI_FULLCLEAR)) { - num = ri->ri_height; - x = y = 0; - w = ri->ri_width; - } else { - num *= ri->ri_font->fontheight; - x = ri->ri_xorigin; - y = ri->ri_yorigin + row * ri->ri_font->fontheight; - w = ri->ri_emuwidth; - } - - impact_fillrect(scr, x, y, w, num, ri->ri_devcmap[bg]); - impact_cmd_fifo_wait(scr); - - return 0; -} - -/* - * Console support. - */ - -/* console backing store, worst case font selection */ -static struct wsdisplay_charcell - impact_cons_bs[(IMPACT_WIDTH / 8) * (IMPACT_HEIGHT / 16)]; - -int -impact_cnattach_common(bus_space_tag_t iot, bus_space_handle_t ioh, int has_hq4) -{ - struct impact_screen *scr = &impact_cons; - struct rasops_info *ri = &scr->ri; - int rc; - - scr->iot = iot; - scr->ioh = ioh; - impact_setup(scr, has_hq4); - scr->bs = impact_cons_bs; - rc = impact_init_screen(scr); - if (rc != 0) - return rc; - - ri->ri_ops.pack_attr(ri, 0, 0, 0, &scr->defattr); - wsdisplay_cnattach(&scr->wsd, ri, 0, 0, scr->defattr); - - return 0; -} diff --git a/sys/arch/sgi/dev/impactreg.h b/sys/arch/sgi/dev/impactreg.h deleted file mode 100644 index 15b6f909b2d..00000000000 --- a/sys/arch/sgi/dev/impactreg.h +++ /dev/null @@ -1,112 +0,0 @@ -/* $OpenBSD: impactreg.h,v 1.1 2012/04/18 17:28:24 miod Exp $ */ -/* - * Copyright (c) 2010 Miodrag Vallat. - * Copyright (c) 2009, 2010 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Impact and ImpactSR registers - */ - -#define IMPACTSR_STATUS 0x020000 -#define IMPACTSR_FIFOSTATUS 0x020008 -#define IMPACTSR_FIFO_MASK 0x000000ff -#define IMPACTSR_GIOSTATUS 0x020100 -#define IMPACTSR_DMABUSY 0x020200 -#define IMPACTSR_CFIFO 0x020400 - -#define IMPACT_STATUS 0x070000 -#define IMPACT_FIFOSTATUS 0x070004 -#define IMPACT_GIOSTATUS 0x070100 -#define IMPACT_DMABUSY 0x070104 -#define IMPACT_CFIFO 0x070080 - -#define IMPACTSR_CFIFO_HW 0x040000 -#define IMPACTSR_CFIFO_LW 0x040008 -#define IMPACTSR_CFIFO_DELAY 0x040010 -#define IMPACTSR_DFIFO_HW 0x040020 -#define IMPACTSR_DFIFO_LW 0x040028 -#define IMPACTSR_DFIFO_DELAY 0x040030 -#define IMPACT_CFIFO_HW 0x050020 -#define IMPACT_CFIFO_LW 0x050024 -#define IMPACT_CFIFO_DELAY 0x050028 -#define IMPACT_DFIFO_HW 0x05002c -#define IMPACT_DFIFO_LW 0x050030 -#define IMPACT_DFIFO_DELAY 0x050034 - -#define IMPACTSR_XMAP_BASE 0x071c00 -#define IMPACT_XMAP_BASE 0x061c00 - -#define IMPACTSR_XMAP_PP1SELECT 0x000008 -#define IMPACTSR_XMAP_INDEX 0x000088 -#define IMPACTSR_XMAP_CONFIG 0x000100 -#define IMPACTSR_XMAP_CONFIGB 0x000108 -#define IMPACTSR_XMAP_BUF_SELECT 0x000180 -#define IMPACTSR_XMAP_MAIN_MODE 0x000200 -#define IMPACTSR_XMAP_OVERLAY_MODE 0x000280 -#define IMPACTSR_XMAP_DIB 0x000300 -#define IMPACTSR_XMAP_DIB_DW 0x000340 -#define IMPACTSR_XMAP_RE_RAC 0x000380 - -#define IMPACTSR_VC3_BASE 0x072000 -#define IMPACT_VC3_BASE 0x062000 - -#define IMPACTSR_VC3_INDEX 0x000008 -#define IMPACTSR_VC3_INDEXDATA 0x000038 -#define IMPACTSR_VC3_DATA 0x0000b0 -#define IMPACTSR_VC3_RAM 0x000190 - -/* - * Command FIFO instruction encoding - */ - -#define IMPACTSR_CFIFO_WRITE 0x0018000400000000UL -#define IMPACTSR_CFIFO_EXEC 0x0004000000000000UL -#define IMPACTSR_CFIFO_REG_SHIFT 40 - -/* - * Command FIFO registers - */ - -#define IMPACTSR_CMD_GLINE_XSTARTF 0x0c -#define IMPACTSR_CMD_IR_ALIAS 0x45 -#define IMPACTSR_CMD_BLOCKXYSTARTI 0x46 /* XY coords */ -#define IMPACTSR_CMD_BLOCKXYENDI 0x47 /* XY coords */ -#define IMPACTSR_CMD_PACKEDCOLOR 0x5b -#define IMPACTSR_CMD_ALPHA 0x5f -#define IMPACTSR_CMD_CHAR_H 0x70 -#define IMPACTSR_CMD_CHAR_L 0x71 -#define IMPACTSR_CMD_XFRCONTROL 0x102 -#define IMPACTSR_CMD_FILLMODE 0x110 -#define IMPACTSR_CMD_CONFIG 0x112 -#define IMPACTSR_CMD_XYWIN 0x115 /* YX coords */ -#define IMPACTSR_CMD_BKGRD_RG 0x140 -#define IMPACTSR_CMD_BKGRD_BA 0x141 -#define IMPACTSR_CMD_XFRSIZE 0x153 /* YX coords */ -#define IMPACTSR_CMD_XFRMASKLO 0x156 -#define IMPACTSR_CMD_XFRMASKHI 0x157 -#define IMPACTSR_CMD_XFRCOUNTERS 0x158 /* YX coords */ -#define IMPACTSR_CMD_XFRMODE 0x159 -#define IMPACTSR_CMD_RE_TOGGLECNTX 0x15f -#define IMPACTSR_CMD_PP1FILLMODE 0x161 -#define IMPACTSR_CMD_COLORMASKMSBS 0x162 -#define IMPACTSR_CMD_COLORMASKLSBSA 0x163 -#define IMPACTSR_CMD_COLORMASKLSBSB 0x164 -#define IMPACTSR_CMD_DRBPOINTERS 0x16d - -#define IMPACTSR_XYCOORDS(x,y) (((x) << 16) | (y)) -#define IMPACTSR_YXCOORDS(x,y) (((y) << 16) | (x)) - -#define IMPACTSR_PP1FILLMODE(mode,op) ((mode) | ((op) << 26)) diff --git a/sys/arch/sgi/dev/impactvar.h b/sys/arch/sgi/dev/impactvar.h deleted file mode 100644 index cc88b38a44c..00000000000 --- a/sys/arch/sgi/dev/impactvar.h +++ /dev/null @@ -1,36 +0,0 @@ -/* $OpenBSD: impactvar.h,v 1.1 2012/04/18 17:28:24 miod Exp $ */ - -/* - * Copyright (c) 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -struct impact_screen; - -struct impact_softc { - struct device sc_dev; - struct impact_screen *curscr; - int console; - int nscreens; -}; - -int impact_attach_common(struct impact_softc *, bus_space_tag_t, - bus_space_handle_t, int, int); -int impact_cnattach_common(bus_space_tag_t, bus_space_handle_t, int); - -struct gio_attach_args; -int impact_gio_cnprobe(struct gio_attach_args *); -int impact_gio_cnattach(struct gio_attach_args *); -int impact_xbow_cnprobe(void); -int impact_xbow_cnattach(void); diff --git a/sys/arch/sgi/dev/iockbc.c b/sys/arch/sgi/dev/iockbc.c deleted file mode 100644 index 7625be05e55..00000000000 --- a/sys/arch/sgi/dev/iockbc.c +++ /dev/null @@ -1,1277 +0,0 @@ -/* $OpenBSD: iockbc.c,v 1.12 2019/10/17 13:42:15 cheloha Exp $ */ -/* - * Copyright (c) 2013, Miodrag Vallat - * Copyright (c) 2006, 2007, 2009 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Derived from sys/dev/ic/pckbc.c under the following terms: - * $NetBSD: pckbc.c,v 1.5 2000/06/09 04:58:35 soda Exp $ */ - -/* - * Copyright (c) 1998 - * Matthias Drochner. 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 ``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 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. - */ - -/* - * Driver for IOC3 and IOC4 PS/2 Controllers (iockbc) - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> -#include <sys/timeout.h> -#include <sys/kernel.h> -#include <sys/proc.h> -#include <sys/signalvar.h> -#include <sys/errno.h> -#include <sys/queue.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <mips64/archtype.h> - -#include <sgi/pci/iocreg.h> -#include <sgi/pci/iocvar.h> -#include <sgi/pci/iofreg.h> -#include <sgi/pci/iofvar.h> - -#include <dev/ic/i8042reg.h> -#include <dev/ic/pckbcvar.h> -#include <dev/pckbc/pckbdreg.h> -#define KBC_DEVCMD_ACK KBR_ACK -#define KBC_DEVCMD_RESEND KBR_RESEND -#include <dev/pckbc/pckbdvar.h> - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcidevs.h> - -#include <sgi/dev/iockbcreg.h> -#include <sgi/dev/iockbcvar.h> - -#include "iockbc.h" - -const char *iockbc_slot_names[] = { "kbd", "mouse" }; - -/* #define IOCKBC_DEBUG */ -#ifdef IOCKBC_DEBUG -#define DPRINTF(x...) do { printf(x); } while(0) -#else -#define DPRINTF(x...) -#endif - -struct iockbc_reginfo { - bus_addr_t rx; - bus_addr_t tx; - bus_addr_t cs; - uint32_t busy; -}; - -struct iockbc_softc { - struct pckbc_softc sc_pckbc; - bus_space_tag_t iot; - bus_space_handle_t ioh; - const struct iockbc_reginfo *reginfo; - int console; -}; - -int iockbc_match(struct device *, void *, void *); -void iockbc_ioc_attach(struct device *, struct device *, void *); -void iockbc_iof_attach(struct device *, struct device *, void *); - -#if NIOCKBC_IOC > 0 -struct cfattach iockbc_ioc_ca = { - sizeof(struct iockbc_softc), iockbc_match, iockbc_ioc_attach -}; -#endif -#if NIOCKBC_IOF > 0 -struct cfattach iockbc_iof_ca = { - sizeof(struct iockbc_softc), iockbc_match, iockbc_iof_attach -}; -#endif - -struct cfdriver iockbc_cd = { - NULL, "iockbc", DV_DULL -}; - -/* Descriptor for one device command. */ -struct pckbc_devcmd { - TAILQ_ENTRY(pckbc_devcmd) next; - int flags; -#define KBC_CMDFLAG_SYNC 1 /* Give descriptor back to caller. */ -#define KBC_CMDFLAG_SLOW 2 - u_char cmd[4]; - int cmdlen, cmdidx, retries; - u_char response[4]; - int status, responselen, responseidx; -}; - -/* Data per slave device. */ -struct pckbc_slotdata { - int polling; /* Don't read data port in interrupt handler. */ - TAILQ_HEAD(, pckbc_devcmd) cmdqueue; /* Active commands. */ - TAILQ_HEAD(, pckbc_devcmd) freequeue; /* Free commands. */ -#define NCMD 5 - struct pckbc_devcmd cmds[NCMD]; - int rx_queue[3]; - int rx_index; - const struct iockbc_reginfo *reginfo; -}; - -#define CMD_IN_QUEUE(q) (TAILQ_FIRST(&(q)->cmdqueue) != NULL) - -enum iockbc_slottype { EMPTY, KBD, MOUSE }; - -static struct pckbc_internal iockbc_consdata; -static struct pckbc_slotdata iockbc_cons_slotdata; - -int iockbc_is_ioc_console(struct ioc_attach_args *); -int iockbc_is_iof_console(struct iof_attach_args *); -void iockbc_attach_common(struct iockbc_softc *, bus_addr_t, int, - const struct iockbc_reginfo *, const struct iockbc_reginfo *); -void iockbc_start(struct pckbc_internal *, pckbc_slot_t); -int iockbc_attach_slot(struct iockbc_softc *, pckbc_slot_t); -void iockbc_init_slotdata(struct pckbc_slotdata *, - const struct iockbc_reginfo *); -int iockbc_submatch(struct device *, void *, void *); -int iockbcprint(void *, const char *); -int iockbcintr(void *); -int iockbcintr_internal(struct pckbc_internal *, struct pckbc_softc *); -void iockbc_cleanqueue(struct pckbc_slotdata *); -void iockbc_cleanup(void *); -void iockbc_poll(void *); -int iockbc_cmdresponse(struct pckbc_internal *, pckbc_slot_t, u_char); -int iockbc_poll_read(struct pckbc_internal *, pckbc_slot_t); -int iockbc_poll_write(struct pckbc_internal *, pckbc_slot_t, int); -void iockbc_process_input(struct pckbc_softc *, struct pckbc_internal *, - int, uint); -enum iockbc_slottype - iockbc_probe_slot(struct pckbc_internal *, pckbc_slot_t); - -int -iockbc_match(struct device *parent, void *cf, void *aux) -{ - /* - * We expect ioc and iof NOT to attach us if there are no PS/2 ports. - */ - return 1; -} - -#if NIOCKBC_IOC > 0 -/* - * Register assignments - */ - -const struct iockbc_reginfo iockbc_ioc[PCKBC_NSLOTS] = { - [PCKBC_KBD_SLOT] = { - .rx = IOC3_KBC_KBD_RX, - .tx = IOC3_KBC_KBD_TX, - .cs = IOC3_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_KBD_WRITE_PENDING - }, - [PCKBC_AUX_SLOT] = { - .rx = IOC3_KBC_AUX_RX, - .tx = IOC3_KBC_AUX_TX, - .cs = IOC3_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_AUX_WRITE_PENDING - } -}; - -const struct iockbc_reginfo iockbc_ioc_inverted[PCKBC_NSLOTS] = { - [PCKBC_KBD_SLOT] = { - .rx = IOC3_KBC_AUX_RX, - .tx = IOC3_KBC_AUX_TX, - .cs = IOC3_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_AUX_WRITE_PENDING - }, - [PCKBC_AUX_SLOT] = { - .rx = IOC3_KBC_KBD_RX, - .tx = IOC3_KBC_KBD_TX, - .cs = IOC3_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_KBD_WRITE_PENDING - } -}; - -void -iockbc_ioc_attach(struct device *parent, struct device *self, void *aux) -{ - struct iockbc_softc *isc = (void*)self; - struct ioc_attach_args *iaa = aux; - - /* Setup bus space mapping. */ - isc->iot = iaa->iaa_memt; - isc->ioh = iaa->iaa_memh; - - /* Establish interrupt handler. */ - if (ioc_intr_establish(parent, iaa->iaa_dev, IPL_TTY, iockbcintr, - (void *)isc, self->dv_xname)) - printf("\n"); - else - printf(": unable to establish interrupt\n"); - - iockbc_attach_common(isc, iaa->iaa_base, iockbc_is_ioc_console(iaa), - iockbc_ioc, iockbc_ioc_inverted); -} -#endif - -#if NIOCKBC_IOF > 0 -/* - * Register assignments - */ - -const struct iockbc_reginfo iockbc_iof[PCKBC_NSLOTS] = { - [PCKBC_KBD_SLOT] = { - .rx = IOC4_KBC_KBD_RX, - .tx = IOC4_KBC_KBD_TX, - .cs = IOC4_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_KBD_WRITE_PENDING - }, - [PCKBC_AUX_SLOT] = { - .rx = IOC4_KBC_AUX_RX, - .tx = IOC4_KBC_AUX_TX, - .cs = IOC4_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_AUX_WRITE_PENDING - } -}; - -const struct iockbc_reginfo iockbc_iof_inverted[PCKBC_NSLOTS] = { - [PCKBC_KBD_SLOT] = { - .rx = IOC4_KBC_AUX_RX, - .tx = IOC4_KBC_AUX_TX, - .cs = IOC4_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_AUX_WRITE_PENDING - }, - [PCKBC_AUX_SLOT] = { - .rx = IOC4_KBC_KBD_RX, - .tx = IOC4_KBC_KBD_TX, - .cs = IOC4_KBC_CTRL_STATUS, - .busy = IOC3_KBC_STATUS_KBD_WRITE_PENDING - } -}; - -void -iockbc_iof_attach(struct device *parent, struct device *self, void *aux) -{ - struct iockbc_softc *isc = (void*)self; - struct iof_attach_args *iaa = aux; - - /* Setup bus space mapping. */ - isc->iot = iaa->iaa_memt; - isc->ioh = iaa->iaa_memh; - - /* Establish interrupt handler. */ - if (iof_intr_establish(parent, iaa->iaa_dev, IPL_TTY, iockbcintr, - (void *)isc, self->dv_xname)) - printf("\n"); - else - printf(": unable to establish interrupt\n"); - - iockbc_attach_common(isc, iaa->iaa_base, iockbc_is_iof_console(iaa), - iockbc_iof, iockbc_iof_inverted); -} -#endif - -void -iockbc_init_slotdata(struct pckbc_slotdata *q, - const struct iockbc_reginfo *reginfo) -{ - int i; - TAILQ_INIT(&q->cmdqueue); - TAILQ_INIT(&q->freequeue); - - for (i = 0; i < NCMD; i++) - TAILQ_INSERT_TAIL(&q->freequeue, &(q->cmds[i]), next); - - q->polling = 0; - q->rx_index = -1; - - q->reginfo = reginfo; -} - -int -iockbcprint(void *aux, const char *pnp) -{ - struct pckbc_attach_args *pa = aux; - - if (!pnp) - printf(" (%s slot)", iockbc_slot_names[pa->pa_slot]); - - return (QUIET); -} - -int -iockbc_submatch(struct device *parent, void *match, void *aux) -{ - struct cfdata *cf = match; - struct pckbc_attach_args *pa = aux; - - if (cf->cf_loc[PCKBCCF_SLOT] != PCKBCCF_SLOT_DEFAULT && - cf->cf_loc[PCKBCCF_SLOT] != pa->pa_slot) - return (0); - - return ((*cf->cf_attach->ca_match)(parent, cf, pa)); -} - -/* - * Figure out what kind of device is connected to the given slot, if any. - */ -enum iockbc_slottype -iockbc_probe_slot(struct pckbc_internal *t, pckbc_slot_t slot) -{ - int rc, i, tries; - - /* reset device */ - pckbc_flush(t, slot); - for (tries = 0; tries < 5; tries++) { - rc = iockbc_poll_write(t, slot, KBC_RESET); - if (rc < 0) { - DPRINTF(("%s: slot %d write failed\n", __func__, slot)); - return EMPTY; - } - for (i = 10; i != 0; i--) { - rc = iockbc_poll_read(t, slot); - if (rc >= 0) - break; - } - if (rc < 0) { - DPRINTF(("%s: slot %d no answer to reset\n", - __func__, slot)); - return EMPTY; - } - if (rc == KBC_DEVCMD_ACK) - break; - if (rc == KBC_DEVCMD_RESEND) - continue; - DPRINTF(("%s: slot %d bogus reset ack %02x\n", - __func__, slot, rc)); - return EMPTY; - } - - /* get answer byte */ - for (i = 10; i != 0; i--) { - rc = iockbc_poll_read(t, slot); - if (rc >= 0) - break; - } - if (rc < 0) { - DPRINTF(("%s: slot %d no answer to reset after ack\n", - __func__, slot)); - return EMPTY; - } - if (rc != KBR_RSTDONE) { - DPRINTF(("%s: slot %d bogus reset answer %02x\n", - __func__, slot, rc)); - return EMPTY; - } - /* mice send an extra byte */ - (void)iockbc_poll_read(t, slot); - - /* ask for device id */ - for (tries = 0; tries < 5; tries++) { - rc = iockbc_poll_write(t, slot, KBC_READID); - if (rc == -1) { - DPRINTF(("%s: slot %d write failed\n", __func__, slot)); - return EMPTY; - } - for (i = 10; i != 0; i--) { - rc = iockbc_poll_read(t, slot); - if (rc >= 0) - break; - } - if (rc < 0) { - DPRINTF(("%s: slot %d no answer to command\n", - __func__, slot)); - return EMPTY; - } - if (rc == KBC_DEVCMD_ACK) - break; - if (rc == KBC_DEVCMD_RESEND) - continue; - DPRINTF(("%s: slot %d bogus command ack %02x\n", - __func__, slot, rc)); - return EMPTY; - } - - /* get first answer byte */ - for (i = 10; i != 0; i--) { - rc = iockbc_poll_read(t, slot); - if (rc >= 0) - break; - } - if (rc < 0) { - DPRINTF(("%s: slot %d no answer to command after ack\n", - __func__, slot)); - return EMPTY; - } - - switch (rc) { - case KCID_KBD1: /* keyboard */ - /* get second answer byte */ - rc = iockbc_poll_read(t, slot); - if (rc < 0) { - DPRINTF(("%s: slot %d truncated keyboard answer\n", - __func__, slot)); - return EMPTY; - } - if (rc != KCID_KBD2) { - DPRINTF(("%s: slot %d unexpected keyboard answer" - " 0x%02x 0x%02x\n", __func__, slot, KCID_KBD1, rc)); - /* return EMPTY; */ - } - return KBD; - case KCID_MOUSE: /* mouse */ - return MOUSE; - default: - DPRINTF(("%s: slot %d unknown device answer 0x%02x\n", - __func__, slot, rc)); - return EMPTY; - } -} - -int -iockbc_attach_slot(struct iockbc_softc *isc, pckbc_slot_t slot) -{ - struct pckbc_softc *sc = &isc->sc_pckbc; - struct pckbc_internal *t = sc->id; - struct pckbc_attach_args pa; - int found; - - iockbc_init_slotdata(t->t_slotdata[slot], &isc->reginfo[slot]); - - pa.pa_tag = t; - pa.pa_slot = slot; - - found = (config_found_sm((struct device *)sc, &pa, - iockbcprint, iockbc_submatch) != NULL); - - return (found); -} - -void -iockbc_attach_common(struct iockbc_softc *isc, bus_addr_t addr, int console, - const struct iockbc_reginfo *reginfo, - const struct iockbc_reginfo *reginfo_inverted) -{ - struct pckbc_softc *sc = &isc->sc_pckbc; - struct pckbc_internal *t; - bus_addr_t cs; - uint32_t csr; - pckbc_slot_t slot; - - if (console) { - iockbc_consdata.t_sc = sc; - sc->id = t = &iockbc_consdata; - isc->console = 1; - if (®info[PCKBC_KBD_SLOT] == iockbc_cons_slotdata.reginfo) - isc->reginfo = reginfo; - else - isc->reginfo = reginfo_inverted; - } else { - /* - * Setup up controller: do not force pull clock and data lines - * low, clamp clocks after one byte received. - */ - cs = reginfo[PCKBC_KBD_SLOT].cs; - csr = bus_space_read_4(isc->iot, isc->ioh, cs); - csr &= ~(IOC3_KBC_CTRL_KBD_PULL_DATA_LOW | - IOC3_KBC_CTRL_KBD_PULL_CLOCK_LOW | - IOC3_KBC_CTRL_AUX_PULL_DATA_LOW | - IOC3_KBC_CTRL_AUX_PULL_CLOCK_LOW | - IOC3_KBC_CTRL_KBD_CLAMP_3 | IOC3_KBC_CTRL_AUX_CLAMP_3); - csr |= IOC3_KBC_CTRL_KBD_CLAMP_1 | IOC3_KBC_CTRL_AUX_CLAMP_1; - bus_space_write_4(isc->iot, isc->ioh, cs, csr); - - /* Setup pckbc_internal structure. */ - t = malloc(sizeof(struct pckbc_internal), M_DEVBUF, - M_WAITOK | M_ZERO); - t->t_iot = isc->iot; - t->t_ioh_d = isc->ioh; - t->t_ioh_c = isc->ioh; - t->t_addr = addr; - t->t_sc = sc; - sc->id = t; - - timeout_set(&t->t_cleanup, iockbc_cleanup, t); - timeout_set(&t->t_poll, iockbc_poll, t); - - isc->reginfo = reginfo; - } - - for (slot = 0; slot < PCKBC_NSLOTS; slot++) { - if (t->t_slotdata[slot] == NULL) { - t->t_slotdata[slot] = - malloc(sizeof(struct pckbc_slotdata), - M_DEVBUF, M_WAITOK); - } - } - - if (!console) { - enum iockbc_slottype slottype; - int mouse_on_main = 0; - - /* - * Probe for a keyboard. If none is found at the regular - * keyboard port, but one is found at the mouse port, then - * it is likely that this particular system has both ports - * inverted (or incorrect labels on the chassis), unless - * this is a human error. In any case, try to get the - * keyboard to attach to the `keyboard' port and the - * pointing device to the `mouse' port. - */ - - for (slot = 0; slot < PCKBC_NSLOTS; slot++) { - iockbc_init_slotdata(t->t_slotdata[slot], - &isc->reginfo[slot]); - slottype = iockbc_probe_slot(t, slot); - if (slottype == KBD) - break; - if (slottype == MOUSE) - mouse_on_main = slot == PCKBC_KBD_SLOT; - } - if (slot == PCKBC_NSLOTS) { - /* - * We could not identify a keyboard. Let's assume - * none is connected; if a mouse has been found on - * the keyboard port and none on the aux port, the - * ports are likely to be inverted. - */ - if (mouse_on_main) - slot = PCKBC_AUX_SLOT; - else - slot = PCKBC_KBD_SLOT; - } - if (slot == PCKBC_AUX_SLOT) { - /* - * Either human error or inverted wiring; use - * the inverted port settings. - * iockbc_attach_slot() below will call - * iockbc_init_slotdata() again. - */ - isc->reginfo = reginfo_inverted; - } - } - - /* - * Attach "slots". - */ - iockbc_attach_slot(isc, PCKBC_KBD_SLOT); - iockbc_attach_slot(isc, PCKBC_AUX_SLOT); -} - -void -iockbc_poll(void *self) -{ - struct pckbc_internal *t = self; - int s; - - s = spltty(); - (void)iockbcintr_internal(t, t->t_sc); - timeout_add_sec(&t->t_poll, 1); - splx(s); -} - -int -iockbcintr(void *vsc) -{ - struct iockbc_softc *isc = (struct iockbc_softc *)vsc; - struct pckbc_softc *sc = &isc->sc_pckbc; - struct pckbc_internal *t = sc->id; - - return iockbcintr_internal(t, sc); -} - -int -iockbcintr_internal(struct pckbc_internal *t, struct pckbc_softc *sc) -{ - pckbc_slot_t slot; - struct pckbc_slotdata *q; - int served = 0; - uint32_t data; - uint32_t val; - - /* Reschedule timeout further into the idle times. */ - if (timeout_pending(&t->t_poll)) - timeout_add_sec(&t->t_poll, 1); - - /* - * Need to check both "slots" since interrupt could be from - * either controller. - */ - for (slot = 0; slot < PCKBC_NSLOTS; slot++) { - q = t->t_slotdata[slot]; - - for (;;) { - if (!q) { - DPRINTF("iockbcintr: no slot%d data!\n", slot); - break; - } - - if (q->polling) { - served = 1; - break; /* pckbc_poll_data() will get it */ - } - - val = bus_space_read_4(t->t_iot, t->t_ioh_d, - q->reginfo->rx); - if ((val & IOC3_KBC_DATA_VALID) == 0) - break; - - served = 1; - - /* Process received data. */ - if (val & IOC3_KBC_DATA_0_VALID) { - data = (val & IOC3_KBC_DATA_0_MASK) >> - IOC3_KBC_DATA_0_SHIFT; - iockbc_process_input(sc, t, slot, data); - } - - if (val & IOC3_KBC_DATA_1_VALID) { - data = (val & IOC3_KBC_DATA_1_MASK) >> - IOC3_KBC_DATA_1_SHIFT; - iockbc_process_input(sc, t, slot, data); - } - - if (val & IOC3_KBC_DATA_2_VALID) { - data = (val & IOC3_KBC_DATA_2_MASK) >> - IOC3_KBC_DATA_2_SHIFT; - iockbc_process_input(sc, t, slot, data); - } - } - } - - return (served); -} - -void -iockbc_process_input(struct pckbc_softc *sc, struct pckbc_internal *t, - int slot, uint data) -{ - struct pckbc_slotdata *q; - - q = t->t_slotdata[slot]; - if (CMD_IN_QUEUE(q) && iockbc_cmdresponse(t, slot, data)) - return; - - if (sc->inputhandler[slot]) - (*sc->inputhandler[slot])(sc->inputarg[slot], data); - else - DPRINTF("iockbcintr: slot %d lost %d\n", slot, data); -} - -int -iockbc_poll_write(struct pckbc_internal *t, pckbc_slot_t slot, int val) -{ - struct pckbc_slotdata *q = t->t_slotdata[slot]; - bus_space_tag_t iot = t->t_iot; - bus_space_handle_t ioh = t->t_ioh_d; - u_int64_t stat; - int timeout = 10000; - - /* Attempt to write a value to the controller. */ - while (timeout--) { - stat = bus_space_read_4(iot, ioh, q->reginfo->cs); - if ((stat & q->reginfo->busy) == 0) { - bus_space_write_4(iot, ioh, q->reginfo->tx, val & 0xff); - return 0; - } - delay(50); - } - - DPRINTF("iockbc_poll_write: timeout, sts %08x\n", stat); - return -1; -} - -int -iockbc_poll_read(struct pckbc_internal *t, pckbc_slot_t slot) -{ - struct pckbc_slotdata *q = t->t_slotdata[slot]; - int timeout = 10000; - u_int32_t val; - - /* See if we already have bytes queued. */ - if (q->rx_index >= 0) - return q->rx_queue[q->rx_index--]; - - /* Poll input from controller. */ - while (timeout--) { - val = bus_space_read_4(t->t_iot, t->t_ioh_d, q->reginfo->rx); - if (val & IOC3_KBC_DATA_VALID) - break; - delay(50); - } - if ((val & IOC3_KBC_DATA_VALID) == 0) { - DPRINTF("iockbc_poll_read: timeout, wx %08x\n", val); - return -1; - } - - /* Process received data. */ - if (val & IOC3_KBC_DATA_2_VALID) - q->rx_queue[++q->rx_index] = - (val & IOC3_KBC_DATA_2_MASK) >> IOC3_KBC_DATA_2_SHIFT; - - if (val & IOC3_KBC_DATA_1_VALID) - q->rx_queue[++q->rx_index] = - (val & IOC3_KBC_DATA_1_MASK) >> IOC3_KBC_DATA_1_SHIFT; - - if (val & IOC3_KBC_DATA_0_VALID) - q->rx_queue[++q->rx_index] = - (val & IOC3_KBC_DATA_0_MASK) >> IOC3_KBC_DATA_0_SHIFT; - - if (q->rx_index >= 0) - return q->rx_queue[q->rx_index--]; - else - return -1; -} - -/* - * Pass command to device, poll for ACK and data. - * to be called at spltty() - */ -static void -iockbc_poll_cmd(struct pckbc_internal *t, pckbc_slot_t slot, - struct pckbc_devcmd *cmd) -{ - int i, c = 0; - - while (cmd->cmdidx < cmd->cmdlen) { - if (iockbc_poll_write(t, slot, cmd->cmd[cmd->cmdidx]) == -1) { - DPRINTF("iockbc_poll_cmd: send error\n"); - cmd->status = EIO; - return; - } - for (i = 10; i; i--) { /* 1s ??? */ - c = iockbc_poll_read(t, slot); - if (c != -1) - break; - } - if (c == KBC_DEVCMD_ACK) { - cmd->cmdidx++; - continue; - } - if (c == KBC_DEVCMD_RESEND) { - DPRINTF("iockbc_cmd: RESEND\n"); - if (cmd->retries++ < 5) - continue; - else { - DPRINTF("iockbc: cmd failed\n"); - cmd->status = EIO; - return; - } - } - if (c == -1) { - DPRINTF("iockbc_cmd: timeout\n"); - cmd->status = EIO; - return; - } - DPRINTF("iockbc_cmd: lost 0x%x\n", c); - } - - while (cmd->responseidx < cmd->responselen) { - if (cmd->flags & KBC_CMDFLAG_SLOW) - i = 100; /* 10s ??? */ - else - i = 10; /* 1s ??? */ - while (i--) { - c = iockbc_poll_read(t, slot); - if (c != -1) - break; - } - if (c == -1) { - DPRINTF("iockbc_poll_cmd: no data\n"); - cmd->status = ETIMEDOUT; - return; - } else - cmd->response[cmd->responseidx++] = c; - } -} - -/* - * Clean up a command queue, throw away everything. - */ -void -iockbc_cleanqueue(struct pckbc_slotdata *q) -{ - struct pckbc_devcmd *cmd; -#ifdef IOCKBC_DEBUG - int i; -#endif - - while ((cmd = TAILQ_FIRST(&q->cmdqueue))) { - TAILQ_REMOVE(&q->cmdqueue, cmd, next); -#ifdef IOCKBC_DEBUG - printf("iockbc_cleanqueue: removing"); - for (i = 0; i < cmd->cmdlen; i++) - printf(" %02x", cmd->cmd[i]); - printf("\n"); -#endif - TAILQ_INSERT_TAIL(&q->freequeue, cmd, next); - } -} - -/* - * Timeout error handler: clean queues and data port. - * XXX could be less invasive. - */ -void -iockbc_cleanup(void *self) -{ - struct pckbc_internal *t = self; - int s; - - printf("iockbc: command timeout\n"); - - s = spltty(); - - if (t->t_slotdata[PCKBC_KBD_SLOT]) - iockbc_cleanqueue(t->t_slotdata[PCKBC_KBD_SLOT]); - if (t->t_slotdata[PCKBC_AUX_SLOT]) - iockbc_cleanqueue(t->t_slotdata[PCKBC_AUX_SLOT]); - - while (iockbc_poll_read(t, PCKBC_KBD_SLOT) - != -1) ; - while (iockbc_poll_read(t, PCKBC_AUX_SLOT) - != -1) ; - - /* Reset KBC? */ - - splx(s); -} - -/* - * Pass command to device during normal operation. - * to be called at spltty() - */ -void -iockbc_start(struct pckbc_internal *t, pckbc_slot_t slot) -{ - struct pckbc_slotdata *q = t->t_slotdata[slot]; - struct pckbc_devcmd *cmd = TAILQ_FIRST(&q->cmdqueue); - - if (q->polling) { - do { - iockbc_poll_cmd(t, slot, cmd); - if (cmd->status) - printf("iockbc_start: command error\n"); - - TAILQ_REMOVE(&q->cmdqueue, cmd, next); - if (cmd->flags & KBC_CMDFLAG_SYNC) - wakeup(cmd); - else { - timeout_del(&t->t_cleanup); - TAILQ_INSERT_TAIL(&q->freequeue, cmd, next); - } - cmd = TAILQ_FIRST(&q->cmdqueue); - } while (cmd); - return; - } - - if (iockbc_poll_write(t, slot, cmd->cmd[cmd->cmdidx])) { - printf("iockbc_start: send error\n"); - /* XXX what now? */ - return; - } -} - -/* - * Handle command responses coming in asynchronously, - * return nonzero if valid response. - * to be called at spltty() - */ -int -iockbc_cmdresponse(struct pckbc_internal *t, pckbc_slot_t slot, u_char data) -{ - struct pckbc_slotdata *q = t->t_slotdata[slot]; - struct pckbc_devcmd *cmd = TAILQ_FIRST(&q->cmdqueue); -#ifdef DIAGNOSTIC - if (!cmd) - panic("iockbc_cmdresponse: no active command"); -#endif - if (cmd->cmdidx < cmd->cmdlen) { - if (data != KBC_DEVCMD_ACK && data != KBC_DEVCMD_RESEND) - return (0); - - if (data == KBC_DEVCMD_RESEND) { - if (cmd->retries++ < 5) { - /* try again last command */ - goto restart; - } else { - DPRINTF("iockbc: cmd failed\n"); - cmd->status = EIO; - /* dequeue */ - } - } else { - if (++cmd->cmdidx < cmd->cmdlen) - goto restart; - if (cmd->responselen) - return (1); - /* else dequeue */ - } - } else if (cmd->responseidx < cmd->responselen) { - cmd->response[cmd->responseidx++] = data; - if (cmd->responseidx < cmd->responselen) - return (1); - /* else dequeue */ - } else - return (0); - - /* dequeue: */ - TAILQ_REMOVE(&q->cmdqueue, cmd, next); - if (cmd->flags & KBC_CMDFLAG_SYNC) - wakeup(cmd); - else { - timeout_del(&t->t_cleanup); - TAILQ_INSERT_TAIL(&q->freequeue, cmd, next); - } - if (!CMD_IN_QUEUE(q)) - return (1); -restart: - iockbc_start(t, slot); - return (1); -} - -/* - * Interfaces to act like pckbc(4). - */ - -int -pckbc_xt_translation(pckbc_tag_t self) -{ - /* Translation isn't supported... */ - return (-1); -} - -/* For use in autoconfiguration. */ -int -pckbc_poll_cmd(pckbc_tag_t self, pckbc_slot_t slot, u_char *cmd, int len, - int responselen, u_char *respbuf, int slow) -{ - struct pckbc_devcmd nc; - int s; - - if ((len > 4) || (responselen > 4)) - return (EINVAL); - - bzero(&nc, sizeof(nc)); - bcopy(cmd, nc.cmd, len); - nc.cmdlen = len; - nc.responselen = responselen; - nc.flags = (slow ? KBC_CMDFLAG_SLOW : 0); - - s = spltty(); - iockbc_poll_cmd(self, slot, &nc); - splx(s); - - if (nc.status == 0 && respbuf) - bcopy(nc.response, respbuf, responselen); - - return (nc.status); -} - -void -pckbc_flush(pckbc_tag_t self, pckbc_slot_t slot) -{ - /* Read any data and discard. */ - struct pckbc_internal *t = self; - (void) iockbc_poll_read(t, slot); -} - -/* - * Put command into the device's command queue, return zero or errno. - */ -int -pckbc_enqueue_cmd(pckbc_tag_t self, pckbc_slot_t slot, u_char *cmd, int len, - int responselen, int sync, u_char *respbuf) -{ - struct pckbc_internal *t = self; - struct pckbc_slotdata *q = t->t_slotdata[slot]; - struct pckbc_devcmd *nc; - int s, isactive, res = 0; - - if ((len > 4) || (responselen > 4)) - return (EINVAL); - s = spltty(); - nc = TAILQ_FIRST(&q->freequeue); - if (nc) - TAILQ_REMOVE(&q->freequeue, nc, next); - splx(s); - if (!nc) - return (ENOMEM); - - bzero(nc, sizeof(*nc)); - bcopy(cmd, nc->cmd, len); - nc->cmdlen = len; - nc->responselen = responselen; - nc->flags = (sync ? KBC_CMDFLAG_SYNC : 0); - - s = spltty(); - - if (q->polling && sync) { - /* - * XXX We should poll until the queue is empty. - * But we don't come here normally, so make - * it simple and throw away everything. - */ - iockbc_cleanqueue(q); - } - - isactive = CMD_IN_QUEUE(q); - TAILQ_INSERT_TAIL(&q->cmdqueue, nc, next); - if (!isactive) - iockbc_start(t, slot); - - if (q->polling) - res = (sync ? nc->status : 0); - else if (sync) { - if ((res = tsleep_nsec(nc, 0, "kbccmd", SEC_TO_NSEC(1)))) { - TAILQ_REMOVE(&q->cmdqueue, nc, next); - iockbc_cleanup(t); - } else - res = nc->status; - } else - timeout_add_sec(&t->t_cleanup, 1); - - if (sync) { - if (respbuf) - bcopy(nc->response, respbuf, responselen); - TAILQ_INSERT_TAIL(&q->freequeue, nc, next); - } - - splx(s); - - return (res); -} - -int -pckbc_poll_data(pckbc_tag_t self, pckbc_slot_t slot) -{ - struct pckbc_internal *t = self; - struct pckbc_slotdata *q = t->t_slotdata[slot]; - int c; - - c = iockbc_poll_read(t, slot); - if (c != -1 && q && CMD_IN_QUEUE(q)) { - /* We jumped into a running command - try to deliver the - response. */ - if (iockbc_cmdresponse(t, slot, c)) - return (-1); - } - return (c); -} - -void -pckbc_set_inputhandler(pckbc_tag_t self, pckbc_slot_t slot, pckbc_inputfcn func, - void *arg, char *name) -{ - struct pckbc_internal *t = (struct pckbc_internal *)self; - struct pckbc_softc *sc = t->t_sc; - struct iockbc_softc *isc = (struct iockbc_softc *)sc; - - if (slot >= PCKBC_NSLOTS) - panic("iockbc_set_inputhandler: bad slot %d", slot); - - sc->inputhandler[slot] = func; - sc->inputarg[slot] = arg; - sc->subname[slot] = name; - - if ((isc == NULL || isc->console) && slot == PCKBC_KBD_SLOT) - timeout_add_sec(&t->t_poll, 1); -} - -void -pckbc_slot_enable(pckbc_tag_t self, pckbc_slot_t slot, int on) -{ - struct pckbc_internal *t = (struct pckbc_internal *)self; - - if (slot == PCKBC_KBD_SLOT) { - if (on) - timeout_add_sec(&t->t_poll, 1); - else - timeout_del(&t->t_poll); - } -} - -void -pckbc_set_poll(pckbc_tag_t self, pckbc_slot_t slot, int on) -{ - struct pckbc_internal *t = (struct pckbc_internal *)self; - - t->t_slotdata[slot]->polling = on; - - if (!on) { - int s; - - /* - * If disabling polling on a device that's been configured, - * make sure there are no bytes left in the FIFO, holding up - * the interrupt line. Otherwise we won't get any further - * interrupts. - */ - if (t->t_sc) { - s = spltty(); - iockbcintr(t->t_sc); - splx(s); - } - } -} - -/* - * Console support. - */ - -static int iockbc_console; - -int -iockbc_cnattach() -{ - bus_space_tag_t iot = &sys_config.console_io; - bus_space_handle_t ioh = (bus_space_handle_t)iot->bus_base; - struct pckbc_internal *t = &iockbc_consdata; - const struct iockbc_reginfo *reginfo = NULL, *reginfo_inverted; - enum iockbc_slottype slottype; - pckbc_slot_t slot; - uint32_t csr; - int is_ioc; - int rc; - - is_ioc = console_input.specific == - PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3); - if (is_ioc) { -#if NIOCKBC_IOC > 0 - reginfo = iockbc_ioc; - reginfo_inverted = iockbc_ioc_inverted; -#endif - } else { -#if NIOCKBC_IOF > 0 - reginfo = iockbc_iof; - reginfo_inverted = iockbc_iof_inverted; -#endif - } - if (reginfo == NULL) - return ENXIO; - - /* - * Setup up controller: do not force pull clock and data lines - * low, clamp clocks after one byte received. - */ - csr = bus_space_read_4(iot, ioh, reginfo->cs); - csr &= ~(IOC3_KBC_CTRL_KBD_PULL_DATA_LOW | - IOC3_KBC_CTRL_KBD_PULL_CLOCK_LOW | - IOC3_KBC_CTRL_AUX_PULL_DATA_LOW | - IOC3_KBC_CTRL_AUX_PULL_CLOCK_LOW | - IOC3_KBC_CTRL_KBD_CLAMP_3 | IOC3_KBC_CTRL_AUX_CLAMP_3); - csr |= IOC3_KBC_CTRL_KBD_CLAMP_1 | IOC3_KBC_CTRL_AUX_CLAMP_1; - bus_space_write_4(iot, ioh, reginfo->cs, csr); - - /* Setup pckbc_internal structure. */ - t->t_iot = iot; - t->t_ioh_d = (bus_space_handle_t)iot->bus_base; - t->t_addr = 0; /* unused */ - - timeout_set(&t->t_cleanup, iockbc_cleanup, t); - timeout_set(&t->t_poll, iockbc_poll, t); - - /* - * Probe for a keyboard. There must be one connected, for the PROM - * would not have advertized glass console if none had been - * detected. - */ - - for (slot = 0; slot < PCKBC_NSLOTS; slot++) { - iockbc_init_slotdata(&iockbc_cons_slotdata, ®info[slot]); - t->t_slotdata[slot] = &iockbc_cons_slotdata; - slottype = iockbc_probe_slot(t, slot); - t->t_slotdata[slot] = NULL; - if (slottype == KBD) - break; - } - if (slot == PCKBC_NSLOTS) { - /* - * We could not identify a keyboard, but the PROM did; - * let's assume it's a fluke and assume it exists and - * is connected to the first connector. - */ - slot = PCKBC_KBD_SLOT; - /* - * For some reason keyboard and mouse ports are inverted on - * Fuel. They also are inverted on some IO9 boards, but - * we can't tell both IO9 flavour apart, yet. - */ - if (is_ioc && sys_config.system_type == SGI_IP35) - slot = PCKBC_AUX_SLOT; - } - - if (slot == PCKBC_AUX_SLOT) { - /* - * Either human error when plugging the keyboard, or the - * physical connectors on the chassis are inverted. - * Compensate by switching in software (pckbd relies upon - * being at PCKBC_KBD_SLOT). - */ - reginfo = reginfo_inverted; - } - - iockbc_init_slotdata(&iockbc_cons_slotdata, ®info[PCKBC_KBD_SLOT]); - t->t_slotdata[PCKBC_KBD_SLOT] = &iockbc_cons_slotdata; - - rc = pckbd_cnattach(t); - if (rc == 0) - iockbc_console = 1; - - return rc; -} - -#if NIOCKBC_IOC > 0 -int -iockbc_is_ioc_console(struct ioc_attach_args *iaa) -{ - if (iockbc_console == 0) - return 0; - - return location_match(&iaa->iaa_location, &console_input); -} -#endif - -#if NIOCKBC_IOF > 0 -int -iockbc_is_iof_console(struct iof_attach_args *iaa) -{ - if (iockbc_console == 0) - return 0; - - return location_match(&iaa->iaa_location, &console_input); -} -#endif diff --git a/sys/arch/sgi/dev/iockbcreg.h b/sys/arch/sgi/dev/iockbcreg.h deleted file mode 100644 index ecd31c81bcb..00000000000 --- a/sys/arch/sgi/dev/iockbcreg.h +++ /dev/null @@ -1,51 +0,0 @@ -/* $OpenBSD: iockbcreg.h,v 1.1 2009/11/18 19:03:27 miod Exp $ */ - -/* - * Copyright (c) 2008 Joel Sing. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Register definitions for the PS/2 controller part of SGI IOC3 and IOC4 ASICS. - */ - -/* bits in KBC_CTRL_STATUS */ -#define IOC3_KBC_STATUS_KBD_WRITE_PENDING 0x00000001 -#define IOC3_KBC_STATUS_AUX_WRITE_PENDING 0x00000002 -#define IOC3_KBC_STATUS_KBD_DATA 0x00000010 -#define IOC3_KBC_STATUS_KBD_CLOCK 0x00000020 -#define IOC3_KBC_CTRL_KBD_PULL_DATA_LOW 0x00000040 -#define IOC3_KBC_CTRL_KBD_PULL_CLOCK_LOW 0x00000080 -#define IOC3_KBC_STATUS_AUX_DATA 0x00000100 -#define IOC3_KBC_STATUS_AUX_CLOCK 0x00000200 -#define IOC3_KBC_CTRL_AUX_PULL_DATA_LOW 0x00000400 -#define IOC3_KBC_CTRL_AUX_PULL_CLOCK_LOW 0x00000800 -#define IOC3_KBC_CTRL_KBD_CLAMP_1 0x00100000 -#define IOC3_KBC_CTRL_AUX_CLAMP_1 0x00200000 -#define IOC3_KBC_CTRL_KBD_CLAMP_3 0x00400000 -#define IOC3_KBC_CTRL_AUX_CLAMP_3 0x00800000 - -/* bits in KBC_*_RX */ -#define IOC3_KBC_DATA_0_VALID 0x80000000 -#define IOC3_KBC_DATA_1_VALID 0x40000000 -#define IOC3_KBC_DATA_2_VALID 0x20000000 -#define IOC3_KBC_DATA_VALID (IOC3_KBC_DATA_0_VALID | \ - IOC3_KBC_DATA_1_VALID | \ - IOC3_KBC_DATA_2_VALID) -#define IOC3_KBC_DATA_0_MASK 0x00ff0000 -#define IOC3_KBC_DATA_0_SHIFT 16 -#define IOC3_KBC_DATA_1_MASK 0x0000ff00 -#define IOC3_KBC_DATA_1_SHIFT 8 -#define IOC3_KBC_DATA_2_MASK 0x000000ff -#define IOC3_KBC_DATA_2_SHIFT 0 diff --git a/sys/arch/sgi/dev/iockbcvar.h b/sys/arch/sgi/dev/iockbcvar.h deleted file mode 100644 index 5c58581eaed..00000000000 --- a/sys/arch/sgi/dev/iockbcvar.h +++ /dev/null @@ -1,19 +0,0 @@ -/* $OpenBSD: iockbcvar.h,v 1.4 2010/12/04 11:23:43 jsing Exp $ */ - -/* - * Copyright (c) 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -int iockbc_cnattach(void); diff --git a/sys/arch/sgi/dev/mavb.c b/sys/arch/sgi/dev/mavb.c deleted file mode 100644 index e62d908ff38..00000000000 --- a/sys/arch/sgi/dev/mavb.c +++ /dev/null @@ -1,1201 +0,0 @@ -/* $OpenBSD: mavb.c,v 1.22 2021/03/11 11:17:00 jsg Exp $ */ - -/* - * Copyright (c) 2005 Mark Kettenis - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/kernel.h> -#include <sys/timeout.h> - -#include <machine/bus.h> -#include <machine/intr.h> - -#include <sys/audioio.h> -#include <dev/audio_if.h> - -#include <sgi/localbus/macebus.h> -#include <sgi/localbus/macebusvar.h> -#include <sgi/dev/mavbreg.h> - -#include <dev/ic/ad1843reg.h> - -#undef MAVB_DEBUG - -#ifdef MAVB_DEBUG -#define DPRINTF(l,x) do { if (mavb_debug & (l)) printf x; } while (0) -#define MAVB_DEBUG_INTR 0x0100 -int mavb_debug = ~MAVB_DEBUG_INTR; -#else -#define DPRINTF(l,x) /* nothing */ -#endif - -/* Repeat delays for volume buttons. */ -#define MAVB_VOLUME_BUTTON_REPEAT_DEL1 400 /* 400ms to start repeating */ -#define MAVB_VOLUME_BUTTON_REPEAT_DELN 100 /* 100ms between repeats */ - -/* XXX We need access to some of the MACE ISA registers. */ -#define MAVB_ISA_NREGS 0x20 - -#define MAVB_ISA_RING_SIZE 0x4000 /* Mace ISA DMA ring size. */ -#define MAVB_CHAN_RING_SIZE 0x1000 /* DMA buffer size per channel. */ -#define MAVB_CHAN_INTR_SIZE 0x0800 /* Interrupt on 50% buffer transfer. */ -#define MAVB_CHAN_CHUNK_SIZE 0x0400 /* Move data in 25% buffer chunks. */ - - -/* - * AD1843 Mixer. - */ - -enum { - AD1843_RECORD_CLASS, - AD1843_ADC_SOURCE, /* ADC Source Select */ - AD1843_ADC_GAIN, /* ADC Input Gain */ - AD1843_ADC_MIC_GAIN, /* ADC Mic Input Gain */ - - AD1843_INPUT_CLASS, - AD1843_DAC1_GAIN, /* DAC1 Analog/Digital Gain/Attenuation */ - AD1843_DAC1_MUTE, /* DAC1 Analog Mute */ - AD1843_DAC2_GAIN, /* DAC2 Mix Gain */ - AD1843_AUX1_GAIN, /* Auxiliary 1 Mix Gain */ - AD1843_AUX2_GAIN, /* Auxiliary 2 Mix Gain */ - AD1843_AUX3_GAIN, /* Auxiliary 3 Mix Gain */ - AD1843_MIC_GAIN, /* Microphone Mix Gain */ - AD1843_MONO_GAIN, /* Mono Mix Gain */ - AD1843_DAC2_MUTE, /* DAC2 Mix Mute */ - AD1843_AUX1_MUTE, /* Auxiliary 1 Mix Mute */ - AD1843_AUX2_MUTE, /* Auxiliary 2 Mix Mute */ - AD1843_AUX3_MUTE, /* Auxiliary 3 Mix Mute */ - AD1843_MIC_MUTE, /* Microphone Mix Mute */ - AD1843_MONO_MUTE, /* Mono Mix Mute */ - AD1843_SUM_MUTE, /* Sum Mute */ - - AD1843_OUTPUT_CLASS, - AD1843_MNO_MUTE, /* Mono Output Mute */ - AD1843_HPO_MUTE /* Headphone Output Mute */ -}; - -/* ADC Source Select. The order matches the hardware bits. */ -const char *ad1843_source[] = { - AudioNline, - AudioNmicrophone, - AudioNaux "1", - AudioNaux "2", - AudioNaux "3", - AudioNmono, - AudioNdac "1", - AudioNdac "2" -}; - -/* Mix Control. The order matches the hardware register numbering. */ -const char *ad1843_input[] = { - AudioNdac "2", /* AD1843_DAC2__TO_MIXER */ - AudioNaux "1", - AudioNaux "2", - AudioNaux "3", - AudioNmicrophone, - AudioNmono /* AD1843_MISC_SETTINGS */ -}; - -struct mavb_chan { - caddr_t hw_start; - caddr_t sw_start; - caddr_t sw_end; - caddr_t sw_cur; - void (*intr)(void *); - void *intrarg; - u_long rate; - u_int format; - int blksize; -}; - -struct mavb_softc { - struct device sc_dev; - bus_space_tag_t sc_st; - bus_space_handle_t sc_sh; - bus_dma_tag_t sc_dmat; - bus_dmamap_t sc_dmamap; - - /* XXX We need access to some of the MACE ISA registers. */ - bus_space_handle_t sc_isash; - - caddr_t sc_ring; - - struct mavb_chan play; - struct mavb_chan rec; - - struct timeout sc_volume_button_to; -}; - -typedef u_long ad1843_addr_t; - -u_int16_t ad1843_reg_read(struct mavb_softc *, ad1843_addr_t); -u_int16_t ad1843_reg_write(struct mavb_softc *, ad1843_addr_t, u_int16_t); -void ad1843_dump_regs(struct mavb_softc *); - -int mavb_match(struct device *, void *, void *); -void mavb_attach(struct device *, struct device *, void *); - -struct cfattach mavb_ca = { - sizeof(struct mavb_softc), mavb_match, mavb_attach -}; - -struct cfdriver mavb_cd = { - NULL, "mavb", DV_DULL -}; - -int mavb_open(void *, int); -void mavb_close(void *); -int mavb_set_params(void *, int, int, struct audio_params *, - struct audio_params *); -int mavb_round_blocksize(void *hdl, int bs); -int mavb_halt_output(void *); -int mavb_halt_input(void *); -int mavb_set_port(void *, struct mixer_ctrl *); -int mavb_get_port(void *, struct mixer_ctrl *); -int mavb_query_devinfo(void *, struct mixer_devinfo *); -int mavb_get_props(void *); -int mavb_trigger_output(void *, void *, void *, int, void (*)(void *), - void *, struct audio_params *); -int mavb_trigger_input(void *, void *, void *, int, void (*)(void *), - void *, struct audio_params *); - -struct audio_hw_if mavb_sa_hw_if = { - mavb_open, - mavb_close, - mavb_set_params, - mavb_round_blocksize, - 0, - 0, - 0, - 0, - 0, - mavb_halt_output, - mavb_halt_input, - 0, - 0, - mavb_set_port, - mavb_get_port, - mavb_query_devinfo, - 0, - 0, - 0, - mavb_get_props, - mavb_trigger_output, - mavb_trigger_input -}; - -int -mavb_open(void *hdl, int flags) -{ - return (0); -} - -void -mavb_close(void *hdl) -{ -} - -static int -mavb_set_play_rate(struct mavb_softc *sc, u_long sample_rate) -{ - if (sample_rate < 4000 || sample_rate > 48000) - return (EINVAL); - - if (sc->play.rate != sample_rate) { - ad1843_reg_write(sc, AD1843_CLOCK2_SAMPLE_RATE, sample_rate); - sc->play.rate = sample_rate; - } - return (0); -} - -static int -mavb_set_rec_rate(struct mavb_softc *sc, u_long sample_rate) -{ - if (sample_rate < 4000 || sample_rate > 48000) - return (EINVAL); - - if (sc->rec.rate != sample_rate) { - ad1843_reg_write(sc, AD1843_CLOCK1_SAMPLE_RATE, sample_rate); - sc->rec.rate = sample_rate; - } - return (0); -} - -static int -mavb_get_format(u_int encoding, u_int *format) -{ - switch(encoding) { - case AUDIO_ENCODING_ULINEAR_BE: - *format = AD1843_PCM8; - break; - case AUDIO_ENCODING_SLINEAR_BE: - *format = AD1843_PCM16; - break; - case AUDIO_ENCODING_ULAW: - *format = AD1843_ULAW; - break; - case AUDIO_ENCODING_ALAW: - *format = AD1843_ALAW; - break; - default: - return (EINVAL); - } - return (0); -} - -static int -mavb_set_play_format(struct mavb_softc *sc, u_int encoding) -{ - u_int16_t value; - u_int format; - int err; - - err = mavb_get_format(encoding, &format); - if (err) - return (err); - - if (sc->play.format != format) { - value = ad1843_reg_read(sc, AD1843_SERIAL_INTERFACE); - value &= ~AD1843_DA1F_MASK; - value |= (format << AD1843_DA1F_SHIFT); - ad1843_reg_write(sc, AD1843_SERIAL_INTERFACE, value); - sc->play.format = format; - } - return (0); -} - -static int -mavb_set_rec_format(struct mavb_softc *sc, u_int encoding) -{ - u_int16_t value; - u_int format; - int err; - - err = mavb_get_format(encoding, &format); - if (err) - return (err); - - if (sc->rec.format != format) { - value = ad1843_reg_read(sc, AD1843_SERIAL_INTERFACE); - value &= ~(AD1843_ADRF_MASK | AD1843_ADLF_MASK); - value |= (format << AD1843_ADRF_SHIFT) | - (format << AD1843_ADLF_SHIFT); - ad1843_reg_write(sc, AD1843_SERIAL_INTERFACE, value); - sc->rec.format = format; - } - return (0); -} - -int -mavb_set_params(void *hdl, int setmode, int usemode, - struct audio_params *play, struct audio_params *rec) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - int error; - - DPRINTF(1, ("%s: mavb_set_params: sample=%ld precision=%d " - "channels=%d\n", sc->sc_dev.dv_xname, play->sample_rate, - play->precision, play->channels)); - - if (setmode & AUMODE_PLAY) { - play->encoding = AUDIO_ENCODING_SLINEAR_BE; - play->channels = 2; - play->precision = 24; - play->bps = AUDIO_BPS(play->precision); - play->msb = 0; - error = mavb_set_play_rate(sc, play->sample_rate); - if (error) - return (error); - - error = mavb_set_play_format(sc, play->encoding); - if (error) - return (error); - - } - - if (setmode & AUMODE_RECORD) { - rec->encoding = AUDIO_ENCODING_SLINEAR_BE; - rec->channels = 2; - rec->precision = 24; - rec->bps = AUDIO_BPS(rec->precision); - rec->msb = 0; - - error = mavb_set_rec_rate(sc, rec->sample_rate); - if (error) - return (error); - - error = mavb_set_rec_format(sc, rec->encoding); - if (error) - return (error); - } - - return (0); -} - -int -mavb_round_blocksize(void *hdl, int bs) -{ - if (bs == 0) - bs = MAVB_CHAN_INTR_SIZE; - else - bs = (bs + MAVB_CHAN_INTR_SIZE - 1) & - ~(MAVB_CHAN_INTR_SIZE - 1); - return (bs); -} - -int -mavb_halt_output(void *hdl) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - - DPRINTF(1, ("%s: mavb_halt_output called\n", sc->sc_dev.dv_xname)); - mtx_enter(&audio_lock); - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL2_CONTROL, 0); - mtx_leave(&audio_lock); - return (0); -} - -int -mavb_halt_input(void *hdl) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - - DPRINTF(1, ("%s: mavb_halt_input called\n", sc->sc_dev.dv_xname)); - mtx_enter(&audio_lock); - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL1_CONTROL, 0); - mtx_leave(&audio_lock); - return (0); -} - -int -mavb_set_port(void *hdl, struct mixer_ctrl *mc) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - u_char left, right; - ad1843_addr_t reg; - u_int16_t value; - - DPRINTF(1, ("%s: mavb_set_port: dev=%d\n", sc->sc_dev.dv_xname, - mc->dev)); - - switch (mc->dev) { - case AD1843_ADC_SOURCE: - value = ad1843_reg_read(sc, AD1843_ADC_SOURCE_GAIN); - value &= ~(AD1843_LSS_MASK | AD1843_RSS_MASK); - value |= ((mc->un.ord << AD1843_LSS_SHIFT) & AD1843_LSS_MASK); - value |= ((mc->un.ord << AD1843_RSS_SHIFT) & AD1843_RSS_MASK); - ad1843_reg_write(sc, AD1843_ADC_SOURCE_GAIN, value); - break; - case AD1843_ADC_GAIN: - left = mc->un.value.level[AUDIO_MIXER_LEVEL_LEFT]; - right = mc->un.value.level[AUDIO_MIXER_LEVEL_RIGHT]; - value = ad1843_reg_read(sc, AD1843_ADC_SOURCE_GAIN); - value &= ~(AD1843_LIG_MASK | AD1843_RIG_MASK); - value |= ((left >> 4) << AD1843_LIG_SHIFT); - value |= ((right >> 4) << AD1843_RIG_SHIFT); - ad1843_reg_write(sc, AD1843_ADC_SOURCE_GAIN, value); - break; - case AD1843_ADC_MIC_GAIN: - value = ad1843_reg_read(sc, AD1843_ADC_SOURCE_GAIN); - if (mc->un.ord == 0) - value &= ~(AD1843_LMGE | AD1843_RMGE); - else - value |= (AD1843_LMGE | AD1843_RMGE); - ad1843_reg_write(sc, AD1843_ADC_SOURCE_GAIN, value); - break; - - case AD1843_DAC1_GAIN: - left = AUDIO_MAX_GAIN - - mc->un.value.level[AUDIO_MIXER_LEVEL_LEFT]; - right = AUDIO_MAX_GAIN - - mc->un.value.level[AUDIO_MIXER_LEVEL_RIGHT]; - value = ad1843_reg_read(sc, AD1843_DAC1_ANALOG_GAIN); - value &= ~(AD1843_LDA1G_MASK | AD1843_RDA1G_MASK); - value |= ((left >> 2) << AD1843_LDA1G_SHIFT); - value |= ((right >> 2) << AD1843_RDA1G_SHIFT); - ad1843_reg_write(sc, AD1843_DAC1_ANALOG_GAIN, value); - break; - case AD1843_DAC1_MUTE: - value = ad1843_reg_read(sc, AD1843_DAC1_ANALOG_GAIN); - if (mc->un.ord == 0) - value &= ~(AD1843_LDA1GM | AD1843_RDA1GM); - else - value |= (AD1843_LDA1GM | AD1843_RDA1GM); - ad1843_reg_write(sc, AD1843_DAC1_ANALOG_GAIN, value); - break; - - case AD1843_DAC2_GAIN: - case AD1843_AUX1_GAIN: - case AD1843_AUX2_GAIN: - case AD1843_AUX3_GAIN: - case AD1843_MIC_GAIN: - left = AUDIO_MAX_GAIN - - mc->un.value.level[AUDIO_MIXER_LEVEL_LEFT]; - right = AUDIO_MAX_GAIN - - mc->un.value.level[AUDIO_MIXER_LEVEL_RIGHT]; - reg = AD1843_DAC2_TO_MIXER + mc->dev - AD1843_DAC2_GAIN; - value = ad1843_reg_read(sc, reg); - value &= ~(AD1843_LD2M_MASK | AD1843_RD2M_MASK); - value |= ((left >> 3) << AD1843_LD2M_SHIFT); - value |= ((right >> 3) << AD1843_RD2M_SHIFT); - ad1843_reg_write(sc, reg, value); - break; - case AD1843_MONO_GAIN: - left = AUDIO_MAX_GAIN - - mc->un.value.level[AUDIO_MIXER_LEVEL_MONO]; - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - value &= ~AD1843_MNM_MASK; - value |= ((left >> 3) << AD1843_MNM_SHIFT); - ad1843_reg_write(sc, AD1843_MISC_SETTINGS, value); - break; - case AD1843_DAC2_MUTE: - case AD1843_AUX1_MUTE: - case AD1843_AUX2_MUTE: - case AD1843_AUX3_MUTE: - case AD1843_MIC_MUTE: - case AD1843_MONO_MUTE: /* matches left channel */ - reg = AD1843_DAC2_TO_MIXER + mc->dev - AD1843_DAC2_MUTE; - value = ad1843_reg_read(sc, reg); - if (mc->un.ord == 0) - value &= ~(AD1843_LD2MM | AD1843_RD2MM); - else - value |= (AD1843_LD2MM | AD1843_RD2MM); - ad1843_reg_write(sc, reg, value); - break; - - case AD1843_SUM_MUTE: - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - if (mc->un.ord == 0) - value &= ~AD1843_SUMM; - else - value |= AD1843_SUMM; - ad1843_reg_write(sc, AD1843_MISC_SETTINGS, value); - break; - - case AD1843_MNO_MUTE: - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - if (mc->un.ord == 0) - value &= ~AD1843_MNOM; - else - value |= AD1843_MNOM; - ad1843_reg_write(sc, AD1843_MISC_SETTINGS, value); - break; - - case AD1843_HPO_MUTE: - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - if (mc->un.ord == 0) - value &= ~AD1843_HPOM; - else - value |= AD1843_HPOM; - ad1843_reg_write(sc, AD1843_MISC_SETTINGS, value); - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - break; - - default: - return (EINVAL); - } - - return (0); -} - -int -mavb_get_port(void *hdl, struct mixer_ctrl *mc) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - u_char left, right; - ad1843_addr_t reg; - u_int16_t value; - - DPRINTF(1, ("%s: mavb_get_port: dev=%d\n", sc->sc_dev.dv_xname, - mc->dev)); - - switch (mc->dev) { - case AD1843_ADC_SOURCE: - value = ad1843_reg_read(sc, AD1843_ADC_SOURCE_GAIN); - mc->un.ord = (value & AD1843_LSS_MASK) >> AD1843_LSS_SHIFT; - break; - case AD1843_ADC_GAIN: - value = ad1843_reg_read(sc, AD1843_ADC_SOURCE_GAIN); - left = (value & AD1843_LIG_MASK) >> AD1843_LIG_SHIFT; - right = (value & AD1843_RIG_MASK) >> AD1843_RIG_SHIFT; - mc->un.value.level[AUDIO_MIXER_LEVEL_LEFT] = - (left << 4) | left; - mc->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] = - (right << 4) | right; - break; - case AD1843_ADC_MIC_GAIN: - value = ad1843_reg_read(sc, AD1843_ADC_SOURCE_GAIN); - mc->un.ord = (value & AD1843_LMGE) ? 1 : 0; - break; - - case AD1843_DAC1_GAIN: - value = ad1843_reg_read(sc, AD1843_DAC1_ANALOG_GAIN); - left = (value & AD1843_LDA1G_MASK) >> AD1843_LDA1G_SHIFT; - right = (value & AD1843_RDA1G_MASK) >> AD1843_RDA1G_SHIFT; - mc->un.value.level[AUDIO_MIXER_LEVEL_LEFT] = - AUDIO_MAX_GAIN - (left << 2); - mc->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] = - AUDIO_MAX_GAIN - (right << 2); - break; - case AD1843_DAC1_MUTE: - value = ad1843_reg_read(sc, AD1843_DAC1_ANALOG_GAIN); - mc->un.ord = (value & AD1843_LDA1GM) ? 1 : 0; - break; - - case AD1843_DAC2_GAIN: - case AD1843_AUX1_GAIN: - case AD1843_AUX2_GAIN: - case AD1843_AUX3_GAIN: - case AD1843_MIC_GAIN: - reg = AD1843_DAC2_TO_MIXER + mc->dev - AD1843_DAC2_GAIN; - value = ad1843_reg_read(sc, reg); - left = (value & AD1843_LD2M_MASK) >> AD1843_LD2M_SHIFT; - right = (value & AD1843_RD2M_MASK) >> AD1843_RD2M_SHIFT; - mc->un.value.level[AUDIO_MIXER_LEVEL_LEFT] = - AUDIO_MAX_GAIN - (left << 3); - mc->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] = - AUDIO_MAX_GAIN - (right << 3); - break; - case AD1843_MONO_GAIN: - if (mc->un.value.num_channels != 1) - return (EINVAL); - - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - left = (value & AD1843_MNM_MASK) >> AD1843_MNM_SHIFT; - mc->un.value.level[AUDIO_MIXER_LEVEL_MONO] = - AUDIO_MAX_GAIN - (left << 3); - break; - case AD1843_DAC2_MUTE: - case AD1843_AUX1_MUTE: - case AD1843_AUX2_MUTE: - case AD1843_AUX3_MUTE: - case AD1843_MIC_MUTE: - case AD1843_MONO_MUTE: /* matches left channel */ - reg = AD1843_DAC2_TO_MIXER + mc->dev - AD1843_DAC2_MUTE; - value = ad1843_reg_read(sc, reg); - mc->un.ord = (value & AD1843_LD2MM) ? 1 : 0; - break; - - case AD1843_SUM_MUTE: - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - mc->un.ord = (value & AD1843_SUMM) ? 1 : 0; - break; - - case AD1843_MNO_MUTE: - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - mc->un.ord = (value & AD1843_MNOM) ? 1 : 0; - break; - - case AD1843_HPO_MUTE: - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - mc->un.ord = (value & AD1843_HPOM) ? 1 : 0; - break; - - default: - return (EINVAL); - } - - return (0); -} - -int -mavb_query_devinfo(void *hdl, struct mixer_devinfo *di) -{ - int i; - - di->prev = di->next = AUDIO_MIXER_LAST; - - switch (di->index) { - case AD1843_RECORD_CLASS: - di->type = AUDIO_MIXER_CLASS; - di->mixer_class = AD1843_RECORD_CLASS; - strlcpy(di->label.name, AudioCrecord, sizeof di->label.name); - break; - - case AD1843_ADC_SOURCE: - di->type = AUDIO_MIXER_ENUM; - di->mixer_class = AD1843_RECORD_CLASS; - di->next = AD1843_ADC_GAIN; - strlcpy(di->label.name, AudioNsource, sizeof di->label.name); - di->un.e.num_mem = - sizeof ad1843_source / sizeof ad1843_source[1]; - for (i = 0; i < di->un.e.num_mem; i++) { - strlcpy(di->un.e.member[i].label.name, - ad1843_source[i], - sizeof di->un.e.member[0].label.name); - di->un.e.member[i].ord = i; - } - break; - case AD1843_ADC_GAIN: - di->type = AUDIO_MIXER_VALUE; - di->mixer_class = AD1843_RECORD_CLASS; - di->prev = AD1843_ADC_SOURCE; - strlcpy(di->label.name, AudioNvolume, sizeof di->label.name); - di->un.v.num_channels = 2; - strlcpy(di->un.v.units.name, AudioNvolume, - sizeof di->un.v.units.name); - break; - case AD1843_ADC_MIC_GAIN: - di->type = AUDIO_MIXER_ENUM; - di->mixer_class = AD1843_RECORD_CLASS; - strlcpy(di->label.name, AudioNmicrophone "." AudioNpreamp, - sizeof di->label.name); - di->un.e.num_mem = 2; - strlcpy(di->un.e.member[0].label.name, AudioNoff, - sizeof di->un.e.member[0].label.name); - di->un.e.member[0].ord = 0; - strlcpy(di->un.e.member[1].label.name, AudioNon, - sizeof di->un.e.member[1].label.name); - di->un.e.member[1].ord = 1; - break; - - case AD1843_INPUT_CLASS: - di->type = AUDIO_MIXER_CLASS; - di->mixer_class = AD1843_INPUT_CLASS; - strlcpy(di->label.name, AudioCinputs, sizeof di->label.name); - break; - - case AD1843_DAC1_GAIN: - di->type = AUDIO_MIXER_VALUE; - di->mixer_class = AD1843_INPUT_CLASS; - di->next = AD1843_DAC1_MUTE; - strlcpy(di->label.name, AudioNdac "1", sizeof di->label.name); - di->un.v.num_channels = 2; - strlcpy(di->un.v.units.name, AudioNvolume, - sizeof di->un.v.units.name); - break; - case AD1843_DAC1_MUTE: - di->type = AUDIO_MIXER_ENUM; - di->mixer_class = AD1843_INPUT_CLASS; - di->prev = AD1843_DAC1_GAIN; - strlcpy(di->label.name, AudioNmute, sizeof di->label.name); - di->un.e.num_mem = 2; - strlcpy(di->un.e.member[0].label.name, AudioNoff, - sizeof di->un.e.member[0].label.name); - di->un.e.member[0].ord = 0; - strlcpy(di->un.e.member[1].label.name, AudioNon, - sizeof di->un.e.member[1].label.name); - di->un.e.member[1].ord = 1; - break; - - case AD1843_DAC2_GAIN: - case AD1843_AUX1_GAIN: - case AD1843_AUX2_GAIN: - case AD1843_AUX3_GAIN: - case AD1843_MIC_GAIN: - case AD1843_MONO_GAIN: - di->type = AUDIO_MIXER_VALUE; - di->mixer_class = AD1843_INPUT_CLASS; - di->next = di->index + AD1843_DAC2_MUTE - AD1843_DAC2_GAIN; - strlcpy(di->label.name, - ad1843_input[di->index - AD1843_DAC2_GAIN], - sizeof di->label.name); - if (di->index == AD1843_MONO_GAIN) - di->un.v.num_channels = 1; - else - di->un.v.num_channels = 2; - strlcpy(di->un.v.units.name, AudioNvolume, - sizeof di->un.v.units.name); - break; - case AD1843_DAC2_MUTE: - case AD1843_AUX1_MUTE: - case AD1843_AUX2_MUTE: - case AD1843_AUX3_MUTE: - case AD1843_MIC_MUTE: - case AD1843_MONO_MUTE: - di->type = AUDIO_MIXER_ENUM; - di->mixer_class = AD1843_INPUT_CLASS; - di->prev = di->index + AD1843_DAC2_GAIN - AD1843_DAC2_MUTE; - strlcpy(di->label.name, AudioNmute, sizeof di->label.name); - di->un.e.num_mem = 2; - strlcpy(di->un.e.member[0].label.name, AudioNoff, - sizeof di->un.e.member[0].label.name); - di->un.e.member[0].ord = 0; - strlcpy(di->un.e.member[1].label.name, AudioNon, - sizeof di->un.e.member[1].label.name); - di->un.e.member[1].ord = 1; - break; - - case AD1843_SUM_MUTE: - di->type = AUDIO_MIXER_ENUM; - di->mixer_class = AD1843_INPUT_CLASS; - strlcpy(di->label.name, "sum." AudioNmute, - sizeof di->label.name); - di->un.e.num_mem = 2; - strlcpy(di->un.e.member[0].label.name, AudioNoff, - sizeof di->un.e.member[0].label.name); - di->un.e.member[0].ord = 0; - strlcpy(di->un.e.member[1].label.name, AudioNon, - sizeof di->un.e.member[1].label.name); - di->un.e.member[1].ord = 1; - break; - - case AD1843_OUTPUT_CLASS: - di->type = AUDIO_MIXER_CLASS; - di->mixer_class = AD1843_OUTPUT_CLASS; - strlcpy(di->label.name, AudioCoutputs, sizeof di->label.name); - break; - - case AD1843_MNO_MUTE: - di->type = AUDIO_MIXER_ENUM; - di->mixer_class = AD1843_OUTPUT_CLASS; - strlcpy(di->label.name, AudioNmono "." AudioNmute, - sizeof di->label.name); - di->un.e.num_mem = 2; - strlcpy(di->un.e.member[0].label.name, AudioNoff, - sizeof di->un.e.member[0].label.name); - di->un.e.member[0].ord = 0; - strlcpy(di->un.e.member[1].label.name, AudioNon, - sizeof di->un.e.member[1].label.name); - di->un.e.member[1].ord = 1; - break; - - case AD1843_HPO_MUTE: - di->type = AUDIO_MIXER_ENUM; - di->mixer_class = AD1843_OUTPUT_CLASS; - strlcpy(di->label.name, AudioNheadphone "." AudioNmute, - sizeof di->label.name); - di->un.e.num_mem = 2; - strlcpy(di->un.e.member[0].label.name, AudioNoff, - sizeof di->un.e.member[0].label.name); - di->un.e.member[0].ord = 0; - strlcpy(di->un.e.member[1].label.name, AudioNon, - sizeof di->un.e.member[1].label.name); - di->un.e.member[1].ord = 1; - break; - - default: - return (EINVAL); - } - - return (0); -} - -int -mavb_get_props(void *hdl) -{ - return (AUDIO_PROP_FULLDUPLEX | AUDIO_PROP_INDEPENDENT); -} - -static void -mavb_dma_output(struct mavb_softc *sc) -{ - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - u_int64_t write_ptr; - caddr_t src, dst, end; - int count; - - write_ptr = bus_space_read_8(st, sh, MAVB_CHANNEL2_WRITE_PTR); - - end = sc->play.hw_start + MAVB_CHAN_RING_SIZE; - dst = sc->play.hw_start + write_ptr; - src = sc->play.sw_cur; - - if (write_ptr % MAVB_CHAN_CHUNK_SIZE) { - printf("%s: write_ptr=%lld\n", sc->sc_dev.dv_xname, write_ptr); - return; - } - if ((src - sc->play.sw_start) % MAVB_CHAN_CHUNK_SIZE) { - printf("%s: src=%ld\n", sc->sc_dev.dv_xname, - src - sc->play.sw_start); - return; - } - - count = MAVB_CHAN_INTR_SIZE / MAVB_CHAN_CHUNK_SIZE; - while (--count >= 0) { - memcpy(dst, src, MAVB_CHAN_CHUNK_SIZE); - dst += MAVB_CHAN_CHUNK_SIZE; - src += MAVB_CHAN_CHUNK_SIZE; - if (dst >= end) - dst = sc->play.hw_start; - if (src >= sc->play.sw_end) - src = sc->play.sw_start; - if (!((src - sc->play.sw_start) % sc->play.blksize)) { - if (sc->play.intr) - sc->play.intr(sc->play.intrarg); - } - } - write_ptr = dst - sc->play.hw_start; - bus_space_write_8(st, sh, MAVB_CHANNEL2_WRITE_PTR, write_ptr); - sc->play.sw_cur = src; -} - -static void -mavb_dma_input(struct mavb_softc *sc) -{ - bus_space_tag_t st = sc->sc_st; - bus_space_handle_t sh = sc->sc_sh; - u_int64_t read_ptr; - caddr_t src, dst, end; - int count; - - read_ptr = bus_space_read_8(st, sh, MAVB_CHANNEL1_READ_PTR); - - end = sc->rec.hw_start + MAVB_CHAN_RING_SIZE; - src = sc->rec.hw_start + read_ptr; - dst = sc->rec.sw_cur; - - if (read_ptr % MAVB_CHAN_CHUNK_SIZE) { - printf("%s: read_ptr=%lld\n", sc->sc_dev.dv_xname, read_ptr); - return; - } - if ((dst - sc->rec.sw_start) % MAVB_CHAN_CHUNK_SIZE) { - printf("%s: dst=%ld\n", sc->sc_dev.dv_xname, - dst - sc->rec.sw_start); - return; - } - - count = MAVB_CHAN_INTR_SIZE / MAVB_CHAN_CHUNK_SIZE; - while (--count >= 0) { - memcpy(dst, src, MAVB_CHAN_CHUNK_SIZE); - dst += MAVB_CHAN_CHUNK_SIZE; - src += MAVB_CHAN_CHUNK_SIZE; - if (src >= end) - src = sc->rec.hw_start; - if (dst >= sc->rec.sw_end) - dst = sc->rec.sw_start; - if (!((dst - sc->rec.sw_start) % sc->rec.blksize)) { - if (sc->rec.intr) - sc->rec.intr(sc->rec.intrarg); - } - } - read_ptr = src - sc->rec.hw_start; - bus_space_write_8(st, sh, MAVB_CHANNEL1_READ_PTR, read_ptr); - sc->rec.sw_cur = dst; -} - -int -mavb_trigger_output(void *hdl, void *start, void *end, int blksize, - void (*intr)(void *), void *intrarg, struct audio_params *param) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - - DPRINTF(1, ("%s: mavb_trigger_output: start=%p end=%p " - "blksize=%d intr=%p(%p)\n", sc->sc_dev.dv_xname, - start, end, blksize, intr, intrarg)); - - mtx_enter(&audio_lock); - sc->play.blksize = blksize; - sc->play.intr = intr; - sc->play.intrarg = intrarg; - - sc->play.sw_start = sc->play.sw_cur = start; - sc->play.sw_end = end; - - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL2_CONTROL, - MAVB_CHANNEL_RESET); - delay(1000); - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL2_CONTROL, 0); - - /* Fill first 25% of buffer with silence. */ - bzero(sc->play.hw_start, MAVB_CHAN_CHUNK_SIZE); - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL2_WRITE_PTR, - MAVB_CHAN_CHUNK_SIZE); - - /* Fill next 50% of buffer with audio data. */ - mavb_dma_output(sc); - - /* The buffer is now 75% full. Start DMA and get interrupts - * when the buffer is 25% full. The interrupt handler fills - * in 50% of the buffer size, putting it back to 75% full. - */ - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL2_CONTROL, - MAVB_CHANNEL_DMA_ENABLE | MAVB_CHANNEL_INT_25); - mtx_leave(&audio_lock); - return (0); -} - -int -mavb_trigger_input(void *hdl, void *start, void *end, int blksize, - void (*intr)(void *), void *intrarg, struct audio_params *param) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - - DPRINTF(1, ("%s: mavb_trigger_output: start=%p end=%p " - "blksize=%d intr=%p(%p)\n", sc->sc_dev.dv_xname, - start, end, blksize, intr, intrarg)); - - mtx_enter(&audio_lock); - sc->rec.blksize = blksize; - sc->rec.intr = intr; - sc->rec.intrarg = intrarg; - - sc->rec.sw_start = sc->rec.sw_cur = start; - sc->rec.sw_end = end; - - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL1_CONTROL, - MAVB_CHANNEL_RESET); - delay(1000); - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL1_CONTROL, 0); - - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CHANNEL1_CONTROL, - MAVB_CHANNEL_DMA_ENABLE | MAVB_CHANNEL_INT_50); - mtx_leave(&audio_lock); - return (0); -} - -static void -mavb_button_repeat(void *hdl) -{ - struct mavb_softc *sc = (struct mavb_softc *)hdl; - u_int64_t intmask, control; - u_int16_t value, left, right; - - DPRINTF(1, ("%s: mavb_repeat called\n", sc->sc_dev.dv_xname)); - -#define MAVB_CONTROL_VOLUME_BUTTONS \ - (MAVB_CONTROL_VOLUME_BUTTON_UP | MAVB_CONTROL_VOLUME_BUTTON_DOWN) - - control = bus_space_read_8(sc->sc_st, sc->sc_sh, MAVB_CONTROL); - if (control & MAVB_CONTROL_VOLUME_BUTTONS) { - value = ad1843_reg_read(sc, AD1843_DAC1_ANALOG_GAIN); - left = (value & AD1843_LDA1G_MASK) >> AD1843_LDA1G_SHIFT; - right = (value & AD1843_RDA1G_MASK) >> AD1843_RDA1G_SHIFT; - if (control & MAVB_CONTROL_VOLUME_BUTTON_UP) { - control &= ~MAVB_CONTROL_VOLUME_BUTTON_UP; - if (left > 0) - left--; /* attenuation! */ - if (right > 0) - right--; - } - if (control & MAVB_CONTROL_VOLUME_BUTTON_DOWN) { - control &= ~MAVB_CONTROL_VOLUME_BUTTON_DOWN; - if (left < 63) - left++; - if (right < 63) - right++; - } - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CONTROL, control); - - value &= ~(AD1843_LDA1G_MASK | AD1843_RDA1G_MASK); - value |= (left << AD1843_LDA1G_SHIFT); - value |= (right << AD1843_RDA1G_SHIFT); - ad1843_reg_write(sc, AD1843_DAC1_ANALOG_GAIN, value); - - timeout_add_msec(&sc->sc_volume_button_to, - MAVB_VOLUME_BUTTON_REPEAT_DELN); - } else { - /* Enable volume button interrupts again. */ - intmask = bus_space_read_8(sc->sc_st, sc->sc_isash, - MACE_ISA_INT_MASK); - bus_space_write_8(sc->sc_st, sc->sc_isash, MACE_ISA_INT_MASK, - intmask | MACE_ISA_INT_AUDIO_SC); - } -} - -static int -mavb_intr(void *arg) -{ - struct mavb_softc *sc = arg; - u_int64_t intstat, intmask; - - mtx_enter(&audio_lock); - intstat = bus_space_read_8(sc->sc_st, sc->sc_isash, MACE_ISA_INT_STAT); - DPRINTF(MAVB_DEBUG_INTR, ("%s: mavb_intr: intstat = 0x%lx\n", - sc->sc_dev.dv_xname, intstat)); - - if (intstat & MACE_ISA_INT_AUDIO_SC) { - /* Disable volume button interrupts. */ - intmask = bus_space_read_8(sc->sc_st, sc->sc_isash, - MACE_ISA_INT_MASK); - bus_space_write_8(sc->sc_st, sc->sc_isash, MACE_ISA_INT_MASK, - intmask & ~MACE_ISA_INT_AUDIO_SC); - - timeout_add_msec(&sc->sc_volume_button_to, - MAVB_VOLUME_BUTTON_REPEAT_DEL1); - } - - if (intstat & MACE_ISA_INT_AUDIO_DMA1) - mavb_dma_input(sc); - - if (intstat & MACE_ISA_INT_AUDIO_DMA2) - mavb_dma_output(sc); - mtx_leave(&audio_lock); - return 1; -} - -int -mavb_match(struct device *parent, void *match, void *aux) -{ - struct macebus_attach_args *maa = aux; - bus_space_handle_t ioh; - u_int64_t control; - - if (bus_space_map(maa->maa_iot, maa->maa_baseaddr, MAVB_NREGS, 0, - &ioh) != 0) - return (0); - control = bus_space_read_8(maa->maa_iot, ioh, MAVB_CONTROL); - bus_space_unmap(maa->maa_iot, ioh, MAVB_NREGS); - - return ((control & MAVB_CONTROL_CODEC_PRESENT) != 0); -} - -void -mavb_attach(struct device *parent, struct device *self, void *aux) -{ - struct mavb_softc *sc = (void *)self; - struct macebus_attach_args *maa = aux; - bus_dma_segment_t seg; - u_int16_t value; - int rseg; - - sc->sc_st = maa->maa_iot; - if (bus_space_map(sc->sc_st, maa->maa_baseaddr, MAVB_NREGS, 0, - &sc->sc_sh) != 0) { - printf(": can't map i/o space\n"); - return; - } - - /* XXX We need access to some of the MACE ISA registers. */ - extern bus_space_handle_t mace_h; - bus_space_subregion(sc->sc_st, mace_h, 0, MAVB_ISA_NREGS, - &sc->sc_isash); - - /* Set up DMA structures. */ - sc->sc_dmat = maa->maa_dmat; - if (bus_dmamap_create(sc->sc_dmat, MAVB_ISA_RING_SIZE, 1, - MAVB_ISA_RING_SIZE, 0, 0, &sc->sc_dmamap)) { - printf(": can't create MACE ISA DMA map\n"); - return; - } - - if (bus_dmamem_alloc(sc->sc_dmat, MAVB_ISA_RING_SIZE, - MACE_ISA_RING_ALIGN, 0, &seg, 1, &rseg, BUS_DMA_NOWAIT)) { - printf(": can't allocate ring buffer\n"); - return; - } - - if (bus_dmamem_map(sc->sc_dmat, &seg, rseg, MAVB_ISA_RING_SIZE, - &sc->sc_ring, BUS_DMA_COHERENT)) { - printf(": can't map ring buffer\n"); - return; - } - - if (bus_dmamap_load(sc->sc_dmat, sc->sc_dmamap, sc->sc_ring, - MAVB_ISA_RING_SIZE, NULL, BUS_DMA_NOWAIT)) { - printf(": can't load MACE ISA DMA map\n"); - return; - } - - sc->rec.hw_start = sc->sc_ring; - sc->play.hw_start = sc->sc_ring + MAVB_CHAN_RING_SIZE; - - bus_space_write_8(sc->sc_st, sc->sc_isash, MACE_ISA_RING_BASE, - sc->sc_dmamap->dm_segs[0].ds_addr); - - /* Establish interrupt. */ - macebus_intr_establish(maa->maa_intr, maa->maa_mace_intr, - IPL_AUDIO, mavb_intr, sc, sc->sc_dev.dv_xname); - - /* 2. Assert the RESET signal. */ - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CONTROL, - MAVB_CONTROL_RESET); - delay(1); /* at least 100 ns */ - - /* 3. Deassert the RESET signal and enter a wait period to - allow the AD1843 internal clocks and the external - crystal oscillator to stabilize. */ - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CONTROL, 0); - delay(800); /* typically 400 us to 800 us */ - if (ad1843_reg_read(sc, AD1843_CODEC_STATUS) & AD1843_INIT) { - printf(": codec not ready\n"); - return; - } - - /* 4. Put the conversion sources into standby. */ - value = ad1843_reg_read(sc, AD1843_FUNDAMENTAL_SETTINGS); - ad1843_reg_write(sc, AD1843_FUNDAMENTAL_SETTINGS, - value & ~AD1843_PDNI); - delay (500000); /* approximately 474 ms */ - if (ad1843_reg_read(sc, AD1843_CODEC_STATUS) & AD1843_PDNO) { - printf(": can't power up conversion resources\n"); - return; - } - - /* 5. Power up the clock generators and enable clock output pins. */ - value = ad1843_reg_read(sc, AD1843_FUNDAMENTAL_SETTINGS); - ad1843_reg_write(sc, AD1843_FUNDAMENTAL_SETTINGS, - value | AD1843_C1EN | AD1843_C2EN); - - /* 6. Configure conversion resources while they are in standby. */ - value = ad1843_reg_read(sc, AD1843_SERIAL_INTERFACE); - ad1843_reg_write(sc, AD1843_SERIAL_INTERFACE, value | AD1843_ADTLK); - value = ad1843_reg_read(sc, AD1843_CHANNEL_SAMPLE_RATE); - ad1843_reg_write(sc, AD1843_CHANNEL_SAMPLE_RATE, - value | (2 << AD1843_DA1C_SHIFT) | - (1 << AD1843_ADRC_SHIFT) | (1 << AD1843_ADLC_SHIFT)); - - /* 7. Enable conversion resources. */ - value = ad1843_reg_read(sc, AD1843_CHANNEL_POWER_DOWN); - ad1843_reg_write(sc, AD1843_CHANNEL_POWER_DOWN, - value | (AD1843_DA1EN | AD1843_ANAEN | AD1843_AAMEN | - AD1843_ADREN | AD1843_ADLEN)); - - /* 8. Configure conversion resources while they are enabled. */ - value = ad1843_reg_read(sc, AD1843_DAC1_ANALOG_GAIN); - ad1843_reg_write(sc, AD1843_DAC1_ANALOG_GAIN, - value & ~(AD1843_LDA1GM | AD1843_RDA1GM)); - value = ad1843_reg_read(sc, AD1843_DAC1_DIGITAL_GAIN); - ad1843_reg_write(sc, AD1843_DAC1_DIGITAL_GAIN, - value & ~(AD1843_LDA1AM | AD1843_RDA1AM)); - value = ad1843_reg_read(sc, AD1843_MISC_SETTINGS); - ad1843_reg_write(sc, AD1843_MISC_SETTINGS, - value & ~(AD1843_HPOM | AD1843_MNOM)); - - value = ad1843_reg_read(sc, AD1843_CODEC_STATUS); - printf(": AD1843 rev %d\n", (u_int)value & AD1843_REVISION_MASK); - - sc->play.rate = sc->rec.rate = 48000; - sc->play.format = sc->rec.format = AD1843_PCM8; - - timeout_set(&sc->sc_volume_button_to, mavb_button_repeat, sc); - - audio_attach_mi(&mavb_sa_hw_if, sc, &sc->sc_dev); - - return; -} - -u_int16_t -ad1843_reg_read(struct mavb_softc *sc, ad1843_addr_t addr) -{ - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CODEC_CONTROL, - (addr & MAVB_CODEC_ADDRESS_MASK) << MAVB_CODEC_ADDRESS_SHIFT | - MAVB_CODEC_READ); - delay(200); - return bus_space_read_8(sc->sc_st, sc->sc_sh, MAVB_CODEC_STATUS); -} - -u_int16_t -ad1843_reg_write(struct mavb_softc *sc, ad1843_addr_t addr, u_int16_t value) -{ - bus_space_write_8(sc->sc_st, sc->sc_sh, MAVB_CODEC_CONTROL, - (addr & MAVB_CODEC_ADDRESS_MASK) << MAVB_CODEC_ADDRESS_SHIFT | - (value & MAVB_CODEC_WORD_MASK) << MAVB_CODEC_WORD_SHIFT); - delay(200); - return bus_space_read_8(sc->sc_st, sc->sc_sh, MAVB_CODEC_STATUS); -} - -void -ad1843_dump_regs(struct mavb_softc *sc) -{ - u_int16_t addr; - - for (addr = 0; addr < AD1843_NREGS; addr++) - printf("%d: 0x%04x\n", addr, ad1843_reg_read(sc, addr)); -} diff --git a/sys/arch/sgi/dev/mavbreg.h b/sys/arch/sgi/dev/mavbreg.h deleted file mode 100644 index 37379806a6f..00000000000 --- a/sys/arch/sgi/dev/mavbreg.h +++ /dev/null @@ -1,58 +0,0 @@ -/* $OpenBSD: mavbreg.h,v 1.1 2005/01/02 19:25:41 kettenis Exp $ */ - -/* - * Copyright (c) 2005 Mark Kettenis - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * MACE Moosehead A/V Board register definitions. - */ - -#define MAVB_CONTROL 0x00 -#define MAVB_CONTROL_RESET 0x0000000000000001 -#define MAVB_CONTROL_CODEC_PRESENT 0x0000000000000002 -#define MAVB_CONTROL_VOLUME_BUTTON_UP 0x0000000001000000 -#define MAVB_CONTROL_VOLUME_BUTTON_DOWN 0x0000000000800000 - -#define MAVB_CODEC_CONTROL 0x08 -#define MAVB_CODEC_READ 0x0000000000010000 -#define MAVB_CODEC_WORD_SHIFT 0 -#define MAVB_CODEC_WORD_MASK 0x000000000000ffff -#define MAVB_CODEC_ADDRESS_SHIFT 17 -#define MAVB_CODEC_ADDRESS_MASK 0x000000000000001f - -#define MAVB_CODEC_STATUS 0x18 -#define MAVB_CHANNEL1_CONTROL 0x20 -#define MAVB_CHANNEL2_CONTROL 0x40 -#define MAVB_CHANNEL3_CONTROL 0x60 -#define MAVB_CHANNEL_RESET 0x0000000000000400 -#define MAVB_CHANNEL_DMA_ENABLE 0x0000000000000200 -#define MAVB_CHANNEL_INT_DISABLED 0x0000000000000000 -#define MAVB_CHANNEL_INT_25 0x0000000000000020 -#define MAVB_CHANNEL_INT_50 0x0000000000000040 -#define MAVB_CHANNEL_INT_75 0x0000000000000060 -#define MAVB_CHANNEL_INT_EMPTY 0x0000000000000080 -#define MAVB_CHANNEL_INT_NOT_EMPTY 0x00000000000000a0 -#define MAVB_CHANNEL_INT_FULL 0x00000000000000c0 -#define MAVB_CHANNEL_INT_NOT_FULL 0x00000000000000e0 - -#define MAVB_CHANNEL1_READ_PTR 0x28 -#define MAVB_CHANNEL1_WRITE_PTR 0x30 -#define MAVB_CHANNEL1_DEPTH 0x38 -#define MAVB_CHANNEL2_READ_PTR 0x48 -#define MAVB_CHANNEL2_WRITE_PTR 0x50 -#define MAVB_CHANNEL2_DEPTH 0x58 - -#define MAVB_NREGS 0x80 diff --git a/sys/arch/sgi/dev/mkbc.c b/sys/arch/sgi/dev/mkbc.c deleted file mode 100644 index c4bbb622e19..00000000000 --- a/sys/arch/sgi/dev/mkbc.c +++ /dev/null @@ -1,927 +0,0 @@ -/* $OpenBSD: mkbc.c,v 1.15 2019/10/17 13:42:15 cheloha Exp $ */ - -/* - * Copyright (c) 2006, 2007, Joel Sing - * 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 ``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 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 MIND, - * 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. - */ - -/* - * Derived from sys/dev/ic/pckbc.c under the following terms: - * $NetBSD: pckbc.c,v 1.5 2000/06/09 04:58:35 soda Exp $ */ - -/* - * Copyright (c) 1998 - * Matthias Drochner. 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 ``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 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. - */ - -/* - * Driver for Moosehead PS/2 Controllers (mkbc) - * - * There are actually two separate controllers attached to the macebus. - * However in the interest of reusing code, we want to act like a pckbc(4) - * so that we can directly attach pckbd(4) and pms(4). As a result, we make - * each controller look like a "slot" and combine them into a single device. - * - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> -#include <sys/timeout.h> -#include <sys/kernel.h> -#include <sys/proc.h> -#include <sys/signalvar.h> -#include <sys/errno.h> -#include <sys/queue.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <mips64/archtype.h> - -#include <sgi/localbus/crimebus.h> -#include <sgi/localbus/macebusvar.h> - -#include <dev/ic/pckbcvar.h> -#include <dev/pckbc/pckbdvar.h> - -#include "mkbcreg.h" - -const char *mkbc_slot_names[] = { "kbd", "mouse" }; - -#define KBC_DEVCMD_ACK 0xfa -#define KBC_DEVCMD_RESEND 0xfe - -#define KBD_DELAY DELAY(8) - -struct mkbc_softc { - struct pckbc_softc sc_pckbc; - bus_space_tag_t iot; - bus_space_handle_t ioh; -}; - -int mkbc_match(struct device *, void *, void *); -void mkbc_attach(struct device *, struct device *, void *); - -struct cfattach mkbc_ca = { - sizeof(struct mkbc_softc), mkbc_match, mkbc_attach -}; - -struct cfdriver mkbc_cd = { - NULL, "mkbc", DV_DULL -}; - -/* Descriptor for one device command. */ -struct pckbc_devcmd { - TAILQ_ENTRY(pckbc_devcmd) next; - int flags; -#define KBC_CMDFLAG_SYNC 1 /* Give descriptor back to caller. */ -#define KBC_CMDFLAG_SLOW 2 - u_char cmd[4]; - int cmdlen, cmdidx, retries; - u_char response[4]; - int status, responselen, responseidx; -}; - -/* Data per slave device. */ -struct pckbc_slotdata { - int polling; /* Don't read data port in interrupt handler. */ - TAILQ_HEAD(, pckbc_devcmd) cmdqueue; /* Active commands. */ - TAILQ_HEAD(, pckbc_devcmd) freequeue; /* Free commands. */ -#define NCMD 5 - struct pckbc_devcmd cmds[NCMD]; - bus_space_handle_t ioh; -}; - -#define CMD_IN_QUEUE(q) (TAILQ_FIRST(&(q)->cmdqueue) != NULL) - -static int mkbc_console; -static struct pckbc_slotdata mkbc_cons_slotdata; -struct pckbc_internal mkbc_consdata; - -void mkbc_start(struct pckbc_internal *, pckbc_slot_t); -int mkbc_attach_slot(struct mkbc_softc *, pckbc_slot_t); -void mkbc_init_slotdata(struct pckbc_slotdata *); -int mkbc_submatch(struct device *, void *, void *); -int mkbcprint(void *, const char *); -int mkbcintr(void *); -int mkbcintr_internal(struct pckbc_internal *, struct pckbc_softc *); -void mkbc_cleanqueue(struct pckbc_slotdata *); -void mkbc_cleanup(void *); -void mkbc_poll(void *); -int mkbc_cmdresponse(struct pckbc_internal *, pckbc_slot_t, u_char); -int mkbc_poll_read(bus_space_tag_t, bus_space_handle_t); -int mkbc_poll_write(bus_space_tag_t, bus_space_handle_t, int); - -int -mkbc_match(struct device *parent, void *cf, void *aux) -{ - return 1; -} - -void -mkbc_init_slotdata(struct pckbc_slotdata *q) -{ - int i; - TAILQ_INIT(&q->cmdqueue); - TAILQ_INIT(&q->freequeue); - - for (i = 0; i < NCMD; i++) { - TAILQ_INSERT_TAIL(&q->freequeue, &(q->cmds[i]), next); - } - q->polling = 0; -} - -int -mkbcprint(void *aux, const char *pnp) -{ - struct pckbc_attach_args *pa = aux; - - if (!pnp) - printf(" (%s slot)", mkbc_slot_names[pa->pa_slot]); - - return (QUIET); -} - -int -mkbc_submatch(struct device *parent, void *match, void *aux) -{ - struct cfdata *cf = match; - struct pckbc_attach_args *pa = aux; - - if (cf->cf_loc[PCKBCCF_SLOT] != PCKBCCF_SLOT_DEFAULT && - cf->cf_loc[PCKBCCF_SLOT] != pa->pa_slot) - return (0); - return ((*cf->cf_attach->ca_match)(parent, cf, aux)); -} - -int -mkbc_attach_slot(struct mkbc_softc *msc, pckbc_slot_t slot) -{ - struct pckbc_softc *sc = &msc->sc_pckbc; - struct pckbc_internal *t = sc->id; - struct pckbc_attach_args pa; - bus_space_handle_t ioh; - int found; - - if (!t->t_slotdata[slot]) { - - t->t_slotdata[slot] = malloc(sizeof(struct pckbc_slotdata), - M_DEVBUF, M_NOWAIT); - - if (t->t_slotdata[slot] == NULL) { - printf("Failed to allocate slot data!\n"); - return 0; - } - mkbc_init_slotdata(t->t_slotdata[slot]); - - /* Map subregion of bus space for this "slot". */ - if (bus_space_subregion(msc->iot, msc->ioh, - MKBC_PORTSIZE * slot, MKBC_PORTSIZE, &ioh)) { - printf("Unable to map slot subregion!\n"); - return 0; - } - t->t_slotdata[slot]->ioh = ioh; - - /* Initialise controller. */ - bus_space_write_8(msc->iot, ioh, MKBC_CONTROL, - MKBC_CONTROL_TX_CLOCK_DISABLE | MKBC_CONTROL_RESET); - delay(100); /* 100us */ - - /* Enable controller. */ - bus_space_write_8(t->t_iot, t->t_slotdata[slot]->ioh, - MKBC_CONTROL, - MKBC_CONTROL_RX_CLOCK_ENABLE | MKBC_CONTROL_TX_ENABLE); - - } - - pa.pa_tag = t; - pa.pa_slot = slot; - found = (config_found_sm((struct device *)msc, &pa, - mkbcprint, mkbc_submatch) != NULL); - - return (found); -} - -void -mkbc_attach(struct device *parent, struct device *self, void *aux) -{ - struct mkbc_softc *msc = (void*)self; - struct macebus_attach_args *maa = aux; - struct pckbc_softc *sc = &msc->sc_pckbc; - struct pckbc_internal *t; - - if (mkbc_console == 0) { - - /* Setup bus space mapping. */ - msc->iot = maa->maa_iot; - if (bus_space_map(msc->iot, maa->maa_baseaddr, - MKBC_PORTSIZE * 2, 0, &msc->ioh)) { - printf(": unable to map bus space!\n"); - return; - } - - /* Setup pckbc_internal structure. */ - t = malloc(sizeof(struct pckbc_internal), M_DEVBUF, - M_WAITOK | M_ZERO); - t->t_iot = msc->iot; - t->t_ioh_d = 0; - t->t_ioh_c = 0; - t->t_addr = maa->maa_baseaddr; - t->t_sc = (struct pckbc_softc *)msc; - sc->id = t; - - timeout_set(&t->t_cleanup, mkbc_cleanup, t); - timeout_set(&t->t_poll, mkbc_poll, t); - - } else { - - /* Things have already been setup in mkbc_cnattach. */ - msc->iot = mkbc_consdata.t_iot; - msc->ioh = mkbc_consdata.t_ioh_d; - mkbc_consdata.t_sc = (struct pckbc_softc *)msc; - sc->id = &mkbc_consdata; - - } - - /* Establish interrupt handler. */ - if (macebus_intr_establish(maa->maa_intr, maa->maa_mace_intr, - IPL_TTY, mkbcintr, msc, sc->sc_dv.dv_xname)) - printf("\n"); - else - printf(": unable to establish interrupt\n"); - - /* - * Attach "slots" - technically these are separate controllers - * in the same bus space, however we want to act like pckbc(4) so - * that we can attach pckbd(4) and pms(4). - */ - mkbc_attach_slot(msc, PCKBC_KBD_SLOT); - mkbc_attach_slot(msc, PCKBC_AUX_SLOT); -} - -int -mkbcintr(void *vsc) -{ - struct mkbc_softc *msc = (struct mkbc_softc *)vsc; - struct pckbc_softc *sc = &msc->sc_pckbc; - struct pckbc_internal *t = sc->id; - - return mkbcintr_internal(t, sc); -} - -int -mkbcintr_internal(struct pckbc_internal *t, struct pckbc_softc *sc) -{ - pckbc_slot_t slot; - struct pckbc_slotdata *q; - int served = 0; - u_int64_t stat; - u_int64_t data; - - /* Reschedule timeout further into the idle times. */ - if (timeout_pending(&t->t_poll)) - timeout_add_sec(&t->t_poll, 1); - - /* - * Need to check both "slots" since interrupt could be from - * either controller. - */ - slot = PCKBC_KBD_SLOT; - q = t->t_slotdata[slot]; - for(;;) { - - if (!q) { - printf("mkbcintr: no kbd slot data!\n"); - break; - } - - stat = bus_space_read_8(t->t_iot, q->ioh, MKBC_STATUS); - if (!(stat & MKBC_STATUS_RX_FULL)) - break; - - served = 1; - - if (q->polling) - break; /* pckbc_poll_data() will get it */ - - KBD_DELAY; - data = bus_space_read_8(t->t_iot, q->ioh, MKBC_RX_PORT) & 0xff; - if (CMD_IN_QUEUE(q) && mkbc_cmdresponse(t, slot, data)) - continue; - - if (sc->inputhandler[slot]) - (*sc->inputhandler[slot])(sc->inputarg[slot], data); -#ifdef MKBCDEBUG - else - printf("mkbcintr: slot %d lost %d\n", slot, data); -#endif - } - - /* Mouse controller/slot. */ - slot = PCKBC_AUX_SLOT; - q = t->t_slotdata[slot]; - for(;;) { - - if (!q) { - printf("mkbcintr: no mouse slot data!\n"); - break; - } - - stat = bus_space_read_8(t->t_iot, q->ioh, MKBC_STATUS); - if (!(stat & MKBC_STATUS_RX_FULL)) - break; - - served = 1; - - if (q->polling) - break; /* pckbc_poll_data() will get it. */ - - KBD_DELAY; - data = bus_space_read_8(t->t_iot, q->ioh, MKBC_RX_PORT) & 0xff; - if (CMD_IN_QUEUE(q) && mkbc_cmdresponse(t, slot, data)) - continue; - - if (sc->inputhandler[slot]) - (*sc->inputhandler[slot])(sc->inputarg[slot], data); -#ifdef MKBCDEBUG - else - printf("mkbcintr: slot %d lost %d\n", slot, data); -#endif - } - - return (served); -} - -int -mkbc_poll_write(bus_space_tag_t iot, bus_space_handle_t ioh, int val) -{ - int timeout = 10000; - u_int64_t stat; - - /* Attempt to write a value to the controller. */ - while (timeout--) { - stat = bus_space_read_8(iot, ioh, MKBC_STATUS); - if (stat & MKBC_STATUS_TX_EMPTY) { - bus_space_write_8(iot, ioh, MKBC_TX_PORT, val & 0xff); - return 0; - } - delay(50); - } - return -1; -} - -int -mkbc_poll_read(bus_space_tag_t iot, bus_space_handle_t ioh) -{ - int timeout = 10000; - u_int64_t stat, val; - - /* Poll input from controller. */ - while (timeout--) { - stat = bus_space_read_8(iot, ioh, MKBC_STATUS); - if (stat & MKBC_STATUS_RX_FULL) { - val = bus_space_read_8(iot, ioh, MKBC_RX_PORT); - return val & 0xff; - } - delay(50); - } - return -1; -} - -/* - * Pass command to device, poll for ACK and data. - * to be called at spltty() - */ -static void -mkbc_poll_cmd(struct pckbc_internal *t, pckbc_slot_t slot, - struct pckbc_devcmd *cmd) -{ - bus_space_tag_t iot = t->t_iot; - bus_space_handle_t ioh = t->t_slotdata[slot]->ioh; - - int i, c = 0; - - while (cmd->cmdidx < cmd->cmdlen) { - if (mkbc_poll_write(iot, ioh, cmd->cmd[cmd->cmdidx]) == -1) { - printf("mkbc_poll_cmd: send error\n"); - cmd->status = EIO; - return; - } - for (i = 10; i; i--) { /* 1s ??? */ - c = mkbc_poll_read(iot, ioh); - if (c != -1) - break; - } - - if (c == KBC_DEVCMD_ACK) { - cmd->cmdidx++; - continue; - } - if (c == KBC_DEVCMD_RESEND) { -#ifdef MKBCDEBUG - printf("mkbc_cmd: RESEND\n"); -#endif - if (cmd->retries++ < 5) - continue; - else { -#ifdef MKBCDEBUG - printf("mkbc: cmd failed\n"); -#endif - cmd->status = EIO; - return; - } - } - if (c == -1) { -#ifdef MKBCDEBUG - printf("mkbc_cmd: timeout\n"); -#endif - cmd->status = EIO; - return; - } -#ifdef MKBCDEBUG - printf("mkbc_cmd: lost 0x%x\n", c); -#endif - } - - while (cmd->responseidx < cmd->responselen) { - if (cmd->flags & KBC_CMDFLAG_SLOW) - i = 100; /* 10s ??? */ - else - i = 10; /* 1s ??? */ - while (i--) { - c = mkbc_poll_read(iot, ioh); - if (c != -1) - break; - } - if (c == -1) { -#ifdef MKBCDEBUG - printf("mkbc_poll_cmd: no data\n"); -#endif - cmd->status = ETIMEDOUT; - return; - } else - cmd->response[cmd->responseidx++] = c; - } -} - -/* - * Clean up a command queue, throw away everything. - */ -void -mkbc_cleanqueue(struct pckbc_slotdata *q) -{ - struct pckbc_devcmd *cmd; -#ifdef MKBCDEBUG - int i; -#endif - - while ((cmd = TAILQ_FIRST(&q->cmdqueue))) { - TAILQ_REMOVE(&q->cmdqueue, cmd, next); -#ifdef MKBCDEBUG - printf("mkbc_cleanqueue: removing"); - for (i = 0; i < cmd->cmdlen; i++) - printf(" %02x", cmd->cmd[i]); - printf("\n"); -#endif - TAILQ_INSERT_TAIL(&q->freequeue, cmd, next); - } -} - -/* - * Timeout error handler: clean queues and data port. - * XXX could be less invasive. - */ -void -mkbc_cleanup(void *self) -{ - struct pckbc_internal *t = self; - int s; - - printf("mkbc: command timeout\n"); - - s = spltty(); - - if (t->t_slotdata[PCKBC_KBD_SLOT]) - mkbc_cleanqueue(t->t_slotdata[PCKBC_KBD_SLOT]); - if (t->t_slotdata[PCKBC_AUX_SLOT]) - mkbc_cleanqueue(t->t_slotdata[PCKBC_AUX_SLOT]); - - while (mkbc_poll_read(t->t_iot, t->t_slotdata[PCKBC_KBD_SLOT]->ioh) - != -1) ; - while (mkbc_poll_read(t->t_iot, t->t_slotdata[PCKBC_AUX_SLOT]->ioh) - != -1) ; - - /* Reset KBC? */ - - splx(s); -} - -/* - * Pass command to device during normal operation. - * to be called at spltty() - */ -void -mkbc_start(struct pckbc_internal *t, pckbc_slot_t slot) -{ - struct pckbc_slotdata *q = t->t_slotdata[slot]; - struct pckbc_devcmd *cmd = TAILQ_FIRST(&q->cmdqueue); - - if (q->polling) { - do { - mkbc_poll_cmd(t, slot, cmd); - if (cmd->status) - printf("mkbc_start: command error\n"); - - TAILQ_REMOVE(&q->cmdqueue, cmd, next); - if (cmd->flags & KBC_CMDFLAG_SYNC) - wakeup(cmd); - else { - timeout_del(&t->t_cleanup); - TAILQ_INSERT_TAIL(&q->freequeue, cmd, next); - } - cmd = TAILQ_FIRST(&q->cmdqueue); - } while (cmd); - return; - } - - if (mkbc_poll_write(t->t_iot, t->t_slotdata[slot]->ioh, - cmd->cmd[cmd->cmdidx])) { - printf("mkbc_start: send error\n"); - /* XXX what now? */ - return; - } -} - -/* - * Handle command responses coming in asynchronously, - * return nonzero if valid response. - * to be called at spltty() - */ -int -mkbc_cmdresponse(struct pckbc_internal *t, pckbc_slot_t slot, u_char data) -{ - struct pckbc_slotdata *q = t->t_slotdata[slot]; - struct pckbc_devcmd *cmd = TAILQ_FIRST(&q->cmdqueue); -#ifdef DIAGNOSTIC - if (!cmd) - panic("mkbc_cmdresponse: no active command"); -#endif - if (cmd->cmdidx < cmd->cmdlen) { - if (data != KBC_DEVCMD_ACK && data != KBC_DEVCMD_RESEND) - return (0); - - if (data == KBC_DEVCMD_RESEND) { - if (cmd->retries++ < 5) { - /* try again last command */ - goto restart; - } else { -#ifdef MKBCDEBUG - printf("mkbc: cmd failed\n"); -#endif - cmd->status = EIO; - /* dequeue */ - } - } else { - if (++cmd->cmdidx < cmd->cmdlen) - goto restart; - if (cmd->responselen) - return (1); - /* else dequeue */ - } - } else if (cmd->responseidx < cmd->responselen) { - cmd->response[cmd->responseidx++] = data; - if (cmd->responseidx < cmd->responselen) - return (1); - /* else dequeue */ - } else - return (0); - - /* dequeue: */ - TAILQ_REMOVE(&q->cmdqueue, cmd, next); - if (cmd->flags & KBC_CMDFLAG_SYNC) - wakeup(cmd); - else { - timeout_del(&t->t_cleanup); - TAILQ_INSERT_TAIL(&q->freequeue, cmd, next); - } - if (!CMD_IN_QUEUE(q)) - return (1); -restart: - mkbc_start(t, slot); - return (1); -} - -/* - * Interfaces to act like pckbc(4). - */ - -int -pckbc_xt_translation(pckbc_tag_t self) -{ - /* Translation isn't supported... */ - return (-1); -} - -/* For use in autoconfiguration. */ -int -pckbc_poll_cmd(pckbc_tag_t self, pckbc_slot_t slot, u_char *cmd, int len, - int responselen, u_char *respbuf, int slow) -{ - struct pckbc_devcmd nc; - int s; - - if ((len > 4) || (responselen > 4)) - return (EINVAL); - - bzero(&nc, sizeof(nc)); - bcopy(cmd, nc.cmd, len); - nc.cmdlen = len; - nc.responselen = responselen; - nc.flags = (slow ? KBC_CMDFLAG_SLOW : 0); - - s = spltty(); - mkbc_poll_cmd(self, slot, &nc); - splx(s); - - if (nc.status == 0 && respbuf) - bcopy(nc.response, respbuf, responselen); - - return (nc.status); -} - -void -pckbc_flush(pckbc_tag_t self, pckbc_slot_t slot) -{ - /* Read any data and discard. */ - struct pckbc_internal *t = self; - (void) mkbc_poll_read(t->t_iot, t->t_slotdata[slot]->ioh); -} - -/* - * Put command into the device's command queue, return zero or errno. - */ -int -pckbc_enqueue_cmd(pckbc_tag_t self, pckbc_slot_t slot, u_char *cmd, int len, - int responselen, int sync, u_char *respbuf) -{ - struct pckbc_internal *t = self; - struct pckbc_slotdata *q = t->t_slotdata[slot]; - struct pckbc_devcmd *nc; - int s, isactive, res = 0; - - if ((len > 4) || (responselen > 4)) - return (EINVAL); - s = spltty(); - nc = TAILQ_FIRST(&q->freequeue); - if (nc) { - TAILQ_REMOVE(&q->freequeue, nc, next); - } - splx(s); - if (!nc) - return (ENOMEM); - - bzero(nc, sizeof(*nc)); - bcopy(cmd, nc->cmd, len); - nc->cmdlen = len; - nc->responselen = responselen; - nc->flags = (sync ? KBC_CMDFLAG_SYNC : 0); - - s = spltty(); - - if (q->polling && sync) { - /* - * XXX We should poll until the queue is empty. - * But we don't come here normally, so make - * it simple and throw away everything. - */ - mkbc_cleanqueue(q); - } - - isactive = CMD_IN_QUEUE(q); - TAILQ_INSERT_TAIL(&q->cmdqueue, nc, next); - if (!isactive) - mkbc_start(t, slot); - - if (q->polling) - res = (sync ? nc->status : 0); - else if (sync) { - if ((res = tsleep_nsec(nc, 0, "kbccmd", SEC_TO_NSEC(1)))) { - TAILQ_REMOVE(&q->cmdqueue, nc, next); - mkbc_cleanup(t); - } else - res = nc->status; - } else - timeout_add_sec(&t->t_cleanup, 1); - - if (sync) { - if (respbuf) - bcopy(nc->response, respbuf, responselen); - TAILQ_INSERT_TAIL(&q->freequeue, nc, next); - } - - splx(s); - - return (res); -} - -int -pckbc_poll_data(pckbc_tag_t self, pckbc_slot_t slot) -{ - struct pckbc_internal *t = self; - struct pckbc_slotdata *q = t->t_slotdata[slot]; - int c; - - c = mkbc_poll_read(t->t_iot, q->ioh); - if (c != -1 && q && CMD_IN_QUEUE(q)) { - /* We jumped into a running command - try to deliver the - response. */ - if (mkbc_cmdresponse(t, slot, c)) - return (-1); - } - return (c); -} - -void -pckbc_set_inputhandler(pckbc_tag_t self, pckbc_slot_t slot, pckbc_inputfcn func, - void *arg, char *name) -{ - struct pckbc_internal *t = (struct pckbc_internal *)self; - struct pckbc_softc *sc = t->t_sc; - - if (slot >= PCKBC_NSLOTS) - panic("mkbc_set_inputhandler: bad slot %d", slot); - - sc->inputhandler[slot] = func; - sc->inputarg[slot] = arg; - sc->subname[slot] = name; - - if (mkbc_console && slot == PCKBC_KBD_SLOT) - timeout_add_sec(&t->t_poll, 1); -} - -void -pckbc_slot_enable(pckbc_tag_t self, pckbc_slot_t slot, int on) -{ - struct pckbc_internal *t = (struct pckbc_internal *)self; - - /* - * Should we also enable/disable the controller?? - * If we did then none of the poll_ functions would work... - */ - - if (on) { - - /* Enable controller interrupts. */ - bus_space_write_8(t->t_iot, t->t_slotdata[slot]->ioh, - MKBC_CONTROL, - MKBC_CONTROL_RX_CLOCK_ENABLE | MKBC_CONTROL_TX_ENABLE - | MKBC_CONTROL_RX_INT_ENABLE); - - } else { - - /* Disable controller interrupts. */ - bus_space_write_8(t->t_iot, t->t_slotdata[slot]->ioh, - MKBC_CONTROL, - MKBC_CONTROL_RX_CLOCK_ENABLE | MKBC_CONTROL_TX_ENABLE); - - } - - if (slot == PCKBC_KBD_SLOT) { - if (on) - timeout_add_sec(&t->t_poll, 1); - else - timeout_del(&t->t_poll); - } -} - -void -pckbc_set_poll(pckbc_tag_t self, pckbc_slot_t slot, int on) -{ - struct pckbc_internal *t = (struct pckbc_internal *)self; - - t->t_slotdata[slot]->polling = on; - - if (!on) { - int s; - - /* - * If disabling polling on a device that's been configured, - * make sure there are no bytes left in the FIFO, holding up - * the interrupt line. Otherwise we won't get any further - * interrupts. - */ - if (t->t_sc) { - s = spltty(); - mkbcintr(t->t_sc); - splx(s); - } - } -} - -int -mkbc_cnattach(bus_space_tag_t iot, bus_addr_t addr) -{ - bus_space_handle_t ioh, slot_ioh; - int res = 0; - - /* Ensure that we're on an O2. */ - if (sys_config.system_type != SGI_O2) - return (ENXIO); - - if (bus_space_map(iot, addr, MKBC_PORTSIZE * 2, 0, &ioh)) - return (ENXIO); - - mkbc_consdata.t_addr = addr; - mkbc_consdata.t_iot = iot; - mkbc_consdata.t_ioh_d = ioh; - - /* Map subregion of bus space for this "slot". */ - if (bus_space_subregion(iot, ioh, 0, MKBC_PORTSIZE, &slot_ioh)) { - bus_space_unmap(iot, ioh, MKBC_PORTSIZE * 2); - return (ENXIO); - } - - mkbc_cons_slotdata.ioh = slot_ioh; - mkbc_init_slotdata(&mkbc_cons_slotdata); - mkbc_consdata.t_slotdata[PCKBC_KBD_SLOT] = &mkbc_cons_slotdata; - - /* Initialise controller. */ - bus_space_write_8(iot, slot_ioh, MKBC_CONTROL, - MKBC_CONTROL_TX_CLOCK_DISABLE | MKBC_CONTROL_RESET); - delay(100); /* 100us */ - - /* Enable controller. */ - bus_space_write_8(iot, slot_ioh, MKBC_CONTROL, - MKBC_CONTROL_RX_CLOCK_ENABLE | MKBC_CONTROL_TX_ENABLE - | MKBC_CONTROL_RX_INT_ENABLE); - - timeout_set(&mkbc_consdata.t_cleanup, mkbc_cleanup, &mkbc_consdata); - timeout_set(&mkbc_consdata.t_poll, mkbc_poll, &mkbc_consdata); - - /* Flush input buffer. */ - (void) mkbc_poll_read(iot, slot_ioh); - - res = pckbd_cnattach(&mkbc_consdata); - - if (res) { - bus_space_unmap(iot, ioh, MKBC_PORTSIZE * 2); - } else { - mkbc_console = 1; - } - - return (res); -} - -void -mkbc_poll(void *self) -{ - struct pckbc_internal *t = self; - int s; - - s = spltty(); - (void)mkbcintr_internal(t, t->t_sc); - timeout_add_sec(&t->t_poll, 1); - splx(s); -} diff --git a/sys/arch/sgi/dev/mkbcreg.h b/sys/arch/sgi/dev/mkbcreg.h deleted file mode 100644 index d15e98a8149..00000000000 --- a/sys/arch/sgi/dev/mkbcreg.h +++ /dev/null @@ -1,54 +0,0 @@ -/* $OpenBSD: mkbcreg.h,v 1.3 2010/12/03 18:29:56 shadchin Exp $ */ - -/* - * Copyright (c) 2006, 2007, Joel Sing - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <dev/ic/pckbcvar.h> - -/* - * MACE PS/2 controller register definitions. - */ - -#define MKBC_PORTSIZE 0x20 - -#define MKBC_TX_PORT 0x00 -#define MKBC_RX_PORT 0x08 -#define MKBC_CONTROL 0x10 -#define MKBC_STATUS 0x18 - -/* - * Controller status flags - */ -#define MKBC_STATUS_CLOCK_SIGNAL 0x01 -#define MKBC_STATUS_CLOCK_INHIBIT 0x02 -#define MKBC_STATUS_TX_INPROGRESS 0x04 -#define MKBC_STATUS_TX_EMPTY 0x08 -#define MKBC_STATUS_RX_FULL 0x10 -#define MKBC_STATUS_RX_INPROGRESS 0x20 -#define MKBC_STATUS_ERROR_PARITY 0x40 -#define MKBC_STATUS_ERROR_FRAMING 0x80 - -/* - * Control bits - */ -#define MKBC_CONTROL_TX_CLOCK_DISABLE 0x01 -#define MKBC_CONTROL_TX_ENABLE 0x02 -#define MKBC_CONTROL_TX_INT_ENABLE 0x04 -#define MKBC_CONTROL_RX_INT_ENABLE 0x08 -#define MKBC_CONTROL_RX_CLOCK_ENABLE 0x10 -#define MKBC_CONTROL_RESET 0x20 - -int mkbc_cnattach(bus_space_tag_t, bus_addr_t); diff --git a/sys/arch/sgi/dev/owmac.c b/sys/arch/sgi/dev/owmac.c deleted file mode 100644 index 90e65e3407c..00000000000 --- a/sys/arch/sgi/dev/owmac.c +++ /dev/null @@ -1,194 +0,0 @@ -/* $OpenBSD: owmac.c,v 1.3 2019/01/15 18:33:30 visa Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * DS1981/1982/2502 1-Wire Add-only memory driver, for SGI machines. - * - * SGI uses DS1981 (or compatibles) to store the Ethernet address - * on IOC boards. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/kernel.h> -#include <sys/proc.h> - -#include <dev/onewire/onewiredevs.h> -#include <dev/onewire/onewirereg.h> -#include <dev/onewire/onewirevar.h> - -#include <sgi/dev/owmem_subr.h> -#include <sgi/dev/owmacvar.h> - -int owmac_match(struct device *, void *, void *); -void owmac_attach(struct device *, struct device *, void *); - -struct cfattach owmac_ca = { - sizeof(struct owmac_softc), owmac_match, owmac_attach, -}; - -struct cfdriver owmac_cd = { - NULL, "owmac", DV_DULL -}; - -#define EEPROM_NPAGES 4 - -int owmac_read_page(struct owmac_softc *, int, uint8_t *); -int owmac_read_redirect(struct owmac_softc *); - -void owmac_read_mac(struct owmac_softc *); - -int -owmac_match(struct device *parent, void *match, void *aux) -{ - struct onewire_attach_args *oa = aux; - - if (ONEWIRE_ROM_FAMILY_TYPE(oa->oa_rom) == ONEWIRE_FAMILY_DS1982) - return 1; - - /* - * Also match on UniqueWare devices with specific 0x91 family code. - */ - if ((ONEWIRE_ROM_SN(oa->oa_rom) >> (48 - 12)) == 0x5e7 && - ONEWIRE_ROM_FAMILY_CUSTOM(oa->oa_rom) && - ONEWIRE_ROM_FAMILY(oa->oa_rom) == 0x91) - return 1; - - return 0; -} - -void -owmac_attach(struct device *parent, struct device *self, void *aux) -{ - struct owmac_softc *sc = (struct owmac_softc *)self; - struct onewire_attach_args *oa = aux; - - sc->sc_onewire = oa->oa_onewire; - sc->sc_rom = oa->oa_rom; - - /* - * Read the redirection table. - */ - if (owmac_read_redirect(sc) != 0) { - printf(": unable to read redirection data\n"); - return; - } - - printf("\n"); - - /* - * Read the data. - */ - owmac_read_mac(sc); -} - -int -owmac_read_redirect(struct owmac_softc *sc) -{ - int rc = 0; - int status_offset; - - status_offset = 0x0001; /* 1..4 */ - - onewire_lock(sc->sc_onewire, 0); - if ((rc = onewire_reset(sc->sc_onewire)) != 0) - goto unlock; - - onewire_matchrom(sc->sc_onewire, sc->sc_rom); - - /* - * Start reading the EEPROM status block, at the page redirection - * offset. - */ - onewire_write_byte(sc->sc_onewire, ONEWIRE_CMD_READ_STATUS); - onewire_write_byte(sc->sc_onewire, status_offset & 0xff); - onewire_write_byte(sc->sc_onewire, status_offset >> 8); - /* XXX should verify this crc value */ - (void)onewire_read_byte(sc->sc_onewire); - - onewire_read_block(sc->sc_onewire, &sc->sc_redir, EEPROM_NPAGES); - - onewire_reset(sc->sc_onewire); -unlock: - onewire_unlock(sc->sc_onewire); - - return rc; -} - -int -owmac_read_page(struct owmac_softc *sc, int page, uint8_t *buf) -{ - int rc = 0; - int pg; - - /* - * Follow the redirection information. - */ - if ((pg = owmem_redirect(sc->sc_redir, EEPROM_NPAGES, page)) < 0) - return EINVAL; - - pg = page * EEPROM_PAGE_SIZE; - - onewire_lock(sc->sc_onewire, 0); - if ((rc = onewire_reset(sc->sc_onewire)) != 0) - goto unlock; - - onewire_matchrom(sc->sc_onewire, sc->sc_rom); - - /* - * Start reading the EEPROM data. - */ - onewire_write_byte(sc->sc_onewire, ONEWIRE_CMD_READ_MEMORY); - onewire_write_byte(sc->sc_onewire, pg & 0xff); - onewire_write_byte(sc->sc_onewire, 0); - /* XXX should verify this crc value */ - (void)onewire_read_byte(sc->sc_onewire); - - onewire_read_block(sc->sc_onewire, buf, EEPROM_PAGE_SIZE); - - onewire_reset(sc->sc_onewire); -unlock: - onewire_unlock(sc->sc_onewire); - - return rc; -} - -void -owmac_read_mac(struct owmac_softc *sc) -{ - uint8_t buf[EEPROM_PAGE_SIZE]; - - if (owmac_read_page(sc, 0, buf) != 0) - return; - - if (buf[0] != 0x0a) - return; - - sc->sc_enaddr[0] = buf[10]; - sc->sc_enaddr[1] = buf[9]; - sc->sc_enaddr[2] = buf[8]; - sc->sc_enaddr[3] = buf[7]; - sc->sc_enaddr[4] = buf[6]; - sc->sc_enaddr[5] = buf[5]; - - printf("%s: Ethernet Address %02x:%02x:%02x:%02x:%02x:%02x\n", - sc->sc_dev.dv_xname, - sc->sc_enaddr[0], sc->sc_enaddr[1], sc->sc_enaddr[2], - sc->sc_enaddr[3], sc->sc_enaddr[4], sc->sc_enaddr[5]); -} diff --git a/sys/arch/sgi/dev/owmacvar.h b/sys/arch/sgi/dev/owmacvar.h deleted file mode 100644 index 14b6456dcb5..00000000000 --- a/sys/arch/sgi/dev/owmacvar.h +++ /dev/null @@ -1,35 +0,0 @@ -/* $OpenBSD: owmacvar.h,v 1.1 2008/04/07 22:55:57 miod Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * DS1981/1982/2502 1-Wire Add-only memory driver, for SGI machines. - * - * SGI uses DS1981 (or compatibles) to store the Ethernet address - * on IOC boards. - */ - -struct owmac_softc { - struct device sc_dev; - - void *sc_onewire; - uint64_t sc_rom; - - uint8_t sc_redir[4]; /* redirection table */ - - uint8_t sc_enaddr[6]; -}; diff --git a/sys/arch/sgi/dev/owmem_subr.c b/sys/arch/sgi/dev/owmem_subr.c deleted file mode 100644 index 3ae3ca89c52..00000000000 --- a/sys/arch/sgi/dev/owmem_subr.c +++ /dev/null @@ -1,46 +0,0 @@ -/* $OpenBSD: owmem_subr.c,v 1.1 2008/04/07 22:55:57 miod Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Common routines to owmac and owserial drivers. - */ - -#include <sys/param.h> - -#include <sgi/dev/owmem_subr.h> - -int -owmem_redirect(uint8_t *redir, u_int npages, u_int page) -{ - int skips = 0; - - /* - * Follow the redirecting table until we end up in our final - * position. We have to be careful not to loop if the table - * is wrong. - */ - while (redir[page] != 0xff) { - if (++skips >= npages) - return -1; - page = 0xff ^ redir[page]; - if (page >= npages) - return -1; - } - - return page; -} diff --git a/sys/arch/sgi/dev/owmem_subr.h b/sys/arch/sgi/dev/owmem_subr.h deleted file mode 100644 index 2e955c89f25..00000000000 --- a/sys/arch/sgi/dev/owmem_subr.h +++ /dev/null @@ -1,25 +0,0 @@ -/* $OpenBSD: owmem_subr.h,v 1.1 2008/04/07 22:55:57 miod Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Common routines to owmac and owserial drivers. - */ - -#define EEPROM_PAGE_SIZE (256 / NBBY) /* 256 bits per page */ - -int owmem_redirect(uint8_t *, u_int, u_int); diff --git a/sys/arch/sgi/dev/owserial.c b/sys/arch/sgi/dev/owserial.c deleted file mode 100644 index 333e6073d02..00000000000 --- a/sys/arch/sgi/dev/owserial.c +++ /dev/null @@ -1,244 +0,0 @@ -/* $OpenBSD: owserial.c,v 1.2 2009/04/19 18:33:53 miod Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * DS2505 1-Wire Add-only memory driver, for SGI machines. - * - * SGI seems to use DS2505 (or compatibles) to store serial numbers. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/kernel.h> -#include <sys/proc.h> - -#include <dev/onewire/onewiredevs.h> -#include <dev/onewire/onewirereg.h> -#include <dev/onewire/onewirevar.h> - -#include <sgi/dev/owmem_subr.h> -#include <sgi/dev/owserialvar.h> - -int owserial_match(struct device *, void *, void *); -void owserial_attach(struct device *, struct device *, void *); - -struct cfattach owserial_ca = { - sizeof(struct owserial_softc), owserial_match, owserial_attach, -}; - -struct cfdriver owserial_cd = { - NULL, "owserial", DV_DULL -}; - -#define EEPROM_PAGE_SIZE (256 / NBBY) /* 256 bits per page */ - -static const struct onewire_matchfam owserial_fams[] = { - { ONEWIRE_FAMILY_DS2505 }, - { ONEWIRE_FAMILY_DS2506 } -}; - -int owserial_read_page(struct owserial_softc *, int, uint8_t *); -int owserial_read_redirect(struct owserial_softc *); - -void owserial_read_serial(struct owserial_softc *); - -int -owserial_match(struct device *parent, void *match, void *aux) -{ - return (onewire_matchbyfam(aux, owserial_fams, - sizeof(owserial_fams) /sizeof(owserial_fams[0]))); -} - -void -owserial_attach(struct device *parent, struct device *self, void *aux) -{ - struct owserial_softc *sc = (struct owserial_softc *)self; - struct onewire_attach_args *oa = aux; - - sc->sc_onewire = oa->oa_onewire; - sc->sc_rom = oa->oa_rom; - - /* - * Decide how many pages of 256 bits we have. - */ - - if (ONEWIRE_ROM_FAMILY_TYPE(sc->sc_rom) == ONEWIRE_FAMILY_DS2506) - sc->sc_npages = 256; - else - sc->sc_npages = 64; - - /* - * Read the redirection table. - */ - if (owserial_read_redirect(sc) != 0) { - printf(": unable to read redirection data\n"); - return; - } - - printf("\n"); - - /* - * Read the data. - */ - owserial_read_serial(sc); -} - -int -owserial_read_redirect(struct owserial_softc *sc) -{ - int rc = 0; - int status_offset, pos; - - status_offset = 0x0100; /* 100..13f or 100..1ff */ - pos = 0; - - onewire_lock(sc->sc_onewire, 0); - if ((rc = onewire_reset(sc->sc_onewire)) != 0) - goto unlock; - - onewire_matchrom(sc->sc_onewire, sc->sc_rom); - - /* - * Start reading the EEPROM status block, at the page redirection - * offset. - */ - onewire_write_byte(sc->sc_onewire, ONEWIRE_CMD_READ_STATUS); - onewire_write_byte(sc->sc_onewire, status_offset & 0xff); - onewire_write_byte(sc->sc_onewire, status_offset >> 8); - - for (pos = 0; pos < sc->sc_npages; pos += 8) { - onewire_read_block(sc->sc_onewire, sc->sc_redir + pos, 8); - /* XXX check crc */ - (void)onewire_read_byte(sc->sc_onewire); - (void)onewire_read_byte(sc->sc_onewire); - } - - onewire_reset(sc->sc_onewire); -unlock: - onewire_unlock(sc->sc_onewire); - - return rc; -} - -int -owserial_read_page(struct owserial_softc *sc, int page, uint8_t *buf) -{ - int rc = 0; - int pg; - - /* - * Follow the redirection information. - */ - if ((pg = owmem_redirect(sc->sc_redir, sc->sc_npages, page)) < 0) - return EINVAL; - - pg = page * EEPROM_PAGE_SIZE; - - onewire_lock(sc->sc_onewire, 0); - if ((rc = onewire_reset(sc->sc_onewire)) != 0) - goto unlock; - - onewire_matchrom(sc->sc_onewire, sc->sc_rom); - - /* - * Start reading the EEPROM data. - */ - onewire_write_byte(sc->sc_onewire, ONEWIRE_CMD_READ_MEMORY); - onewire_write_byte(sc->sc_onewire, pg & 0xff); - onewire_write_byte(sc->sc_onewire, pg >> 8); - - onewire_read_block(sc->sc_onewire, buf, EEPROM_PAGE_SIZE); - - onewire_reset(sc->sc_onewire); -unlock: - onewire_unlock(sc->sc_onewire); - - return rc; -} - -void -owserial_read_serial(struct owserial_softc *sc) -{ - uint8_t buf[EEPROM_PAGE_SIZE * 2]; - char name[1 + OWSERIAL_NAME_LEN]; - char product[1 + OWSERIAL_PRODUCT_LEN]; - char serial[1 + OWSERIAL_SERIAL_LEN]; - char *s, *e; - int pg; - int i; - - pg = owmem_redirect(sc->sc_redir, sc->sc_npages, 0); - if (pg < 0 || owserial_read_page(sc, pg, buf) != 0) - return; - - pg = owmem_redirect(sc->sc_redir, sc->sc_npages, 1); - if (pg < 0 || owserial_read_page(sc, pg, buf + EEPROM_PAGE_SIZE) != 0) - return; - - /* minimal sanity check */ - if (buf[0] != 0x01) - return; - for (i = EEPROM_PAGE_SIZE + 10; i < EEPROM_PAGE_SIZE + 16; i++) - if (buf[i] != 0xff) - return; - - bcopy(buf + 21, product, 9); - bcopy(buf + EEPROM_PAGE_SIZE + 3, product + 9, 3); - product[OWSERIAL_PRODUCT_LEN] = '\0'; - for (i = 0; i < OWSERIAL_PRODUCT_LEN; i++) - if (product[i] != '-' && (product[i] < '0' || product[i] > '9')) - return; - - bcopy(buf + EEPROM_PAGE_SIZE + 16, name, OWSERIAL_NAME_LEN); - name[OWSERIAL_NAME_LEN] = '\0'; - for (i = 0; i < OWSERIAL_NAME_LEN; i++) - if (name[i] < ' ' || name[i] > '~') - return; - - bcopy(buf + 1, serial, OWSERIAL_SERIAL_LEN); - serial[OWSERIAL_SERIAL_LEN] = '\0'; - for (i = 0; i < OWSERIAL_SERIAL_LEN; i++) - if (serial[i] < ' ' || serial[i] > '~') - return; - - /* - * Trim leading and trailing spaces from name and serial # - */ - - strlcpy(sc->sc_product, product, sizeof sc->sc_product); - - s = name; - while (*s == ' ') - s++; - e = name + OWSERIAL_NAME_LEN - 1; - while (*e == ' ' && e >= s) - *e-- = '\0'; - strlcpy(sc->sc_name, s, sizeof sc->sc_name); - - s = serial; - while (*s == ' ') - s++; - e = serial + OWSERIAL_SERIAL_LEN - 1; - while (*e == ' ' && e >= s) - *e-- = '\0'; - strlcpy(sc->sc_serial, s, sizeof sc->sc_serial); - - printf("%s: \"%s\" p/n %s, serial %s\n", - sc->sc_dev.dv_xname, sc->sc_name, sc->sc_product, sc->sc_serial); -} diff --git a/sys/arch/sgi/dev/owserialvar.h b/sys/arch/sgi/dev/owserialvar.h deleted file mode 100644 index 41002b5c808..00000000000 --- a/sys/arch/sgi/dev/owserialvar.h +++ /dev/null @@ -1,41 +0,0 @@ -/* $OpenBSD: owserialvar.h,v 1.2 2009/04/19 18:33:53 miod Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * DS2505 1-Wire Add-only memory driver, for SGI machines. - * - * SGI seems to use DS2505 (or compatibles) to store serial numbers. - */ - -#define OWSERIAL_NAME_LEN 14 -#define OWSERIAL_PRODUCT_LEN 12 -#define OWSERIAL_SERIAL_LEN 20 - -struct owserial_softc { - struct device sc_dev; - - void *sc_onewire; - uint64_t sc_rom; - - int sc_npages; /* number of pages */ - uint8_t sc_redir[256]; /* redirection table */ - - char sc_name[1 + OWSERIAL_NAME_LEN]; - char sc_product[1 + OWSERIAL_PRODUCT_LEN]; - char sc_serial[1 + OWSERIAL_SERIAL_LEN]; -}; diff --git a/sys/arch/sgi/dev/power.c b/sys/arch/sgi/dev/power.c deleted file mode 100644 index 8b38f7a20cb..00000000000 --- a/sys/arch/sgi/dev/power.c +++ /dev/null @@ -1,149 +0,0 @@ -/* $OpenBSD: power.c,v 1.16 2018/12/03 13:46:30 visa Exp $ */ - -/* - * Copyright (c) 2007 Jasper Lievisse Adriaanse <jasper@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/proc.h> -#include <sys/signalvar.h> - -#include <machine/autoconf.h> -#include <mips64/archtype.h> - -#include <dev/ic/ds1687reg.h> -#include <sgi/dev/dsrtcvar.h> - -#include "power.h" - -/* - * Power button driver for the SGI O2 and Octane. - */ - -int power_intr(void *); - -struct cfdriver power_cd = { - NULL, "power", DV_DULL -}; - -#if NPOWER_MACEBUS > 0 - -#include <sgi/localbus/macebusvar.h> - -void power_macebus_attach(struct device *, struct device *, void *); -int power_macebus_match(struct device *, void *, void *); - -struct cfattach power_macebus_ca = { - sizeof(struct device), power_macebus_match, power_macebus_attach -}; - -int -power_macebus_match(struct device *parent, void *match, void *aux) -{ - return (1); -} - -void -power_macebus_attach(struct device *parent, struct device *self, void *aux) -{ - struct macebus_attach_args *maa = aux; - - /* Establish interrupt handler. */ - if (macebus_intr_establish(maa->maa_intr, maa->maa_mace_intr, - IPL_TTY, power_intr, self, self->dv_xname)) - printf("\n"); - else - printf(": unable to establish interrupt!\n"); -} - -#endif - -#if NPOWER_MAINBUS > 0 - -#include <sgi/xbow/xbow.h> -#include <sgi/xbow/xheartreg.h> - -void power_mainbus_attach(struct device *, struct device *, void *); -int power_mainbus_match(struct device *, void *, void *); -int power_mainbus_intr(void *); - -struct cfattach power_mainbus_ca = { - sizeof(struct device), power_mainbus_match, power_mainbus_attach -}; - -int -power_mainbus_match(struct device *parent, void *match, void *aux) -{ - struct mainbus_attach_args *maa = aux; - - if (strcmp(maa->maa_name, power_cd.cd_name) != 0) - return 0; - - return sys_config.system_type == SGI_OCTANE ? 1 : 0; -} - -void -power_mainbus_attach(struct device *parent, struct device *self, void *aux) -{ - /* Establish interrupt handler. */ - if (xbow_intr_establish(power_mainbus_intr, self, HEART_ISR_POWER, - IPL_TTY, self->dv_xname, NULL) != 0) { - printf(": unable to establish interrupt!\n"); - return; - } - - printf("\n"); -} - -int -power_mainbus_intr(void *v) -{ - /* - * Clear interrupt condition; debouncing the kickstart bit will not - * suffice. - */ - xbow_intr_clear(HEART_ISR_POWER); - - return power_intr(v); -} - -#endif - -int -power_intr(void *unused) -{ - extern int allowpowerdown; - int val; - - /* - * Prevent further interrupts by clearing the kickstart flag - * in the DS1687's extended control register. - */ - val = dsrtc_register_read(DS1687_EXT_CTRL); - if (val == -1) - return 1; /* no rtc attached */ - - /* debounce condition */ - dsrtc_register_write(DS1687_EXT_CTRL, val & ~DS1687_KICKSTART); - - if (allowpowerdown == 1) { - allowpowerdown = 0; - prsignal(initprocess, SIGUSR2); - } - - return 1; -} diff --git a/sys/arch/sgi/dev/spdmem_mainbus.c b/sys/arch/sgi/dev/spdmem_mainbus.c deleted file mode 100644 index 3d37c202e87..00000000000 --- a/sys/arch/sgi/dev/spdmem_mainbus.c +++ /dev/null @@ -1,107 +0,0 @@ -/* $OpenBSD: spdmem_mainbus.c,v 1.3 2015/09/08 10:21:50 deraadt Exp $ */ - -/* - * Copyright (c) 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Display SPD memory information obtained from an IP35 brick L1 controller. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <dev/spdmemvar.h> - -#include <mips64/archtype.h> - -#include <machine/autoconf.h> - -#include <sgi/sgi/l1.h> - -struct spdmem_mainbus_softc { - struct spdmem_softc sc_base; - uint8_t *sc_spd; - size_t sc_spdlen; -}; - -int spdmem_mainbus_match(struct device *, void *, void *); -void spdmem_mainbus_attach(struct device *, struct device *, void *); -uint8_t spdmem_mainbus_read(struct spdmem_softc *, uint8_t); - -struct cfattach spdmem_mainbus_ca = { - sizeof(struct spdmem_mainbus_softc), - spdmem_mainbus_match, spdmem_mainbus_attach -}; - -int -spdmem_mainbus_match(struct device *parent, void *vcf, void *aux) -{ - struct spdmem_attach_args *saa = (struct spdmem_attach_args *)aux; - extern struct cfdriver spdmem_cd; - int rc; - uint8_t *spd; - size_t spdlen; - - if (sys_config.system_type != SGI_IP35) - return 0; - - if (strcmp(saa->maa.maa_name, spdmem_cd.cd_name) != 0) - return 0; - - rc = l1_get_brick_spd_record(saa->maa.maa_nasid, saa->dimm, - &spd, &spdlen); - if (rc == 0) { - free(spd, M_DEVBUF, spdlen); - return 1; - } else - return 0; -} - -void -spdmem_mainbus_attach(struct device *parent, struct device *self, void *aux) -{ - struct spdmem_mainbus_softc *sc = (struct spdmem_mainbus_softc *)self; - struct spdmem_attach_args *saa = (struct spdmem_attach_args *)aux; - int rc; - - printf(" dimm %d:", saa->dimm); - - rc = l1_get_brick_spd_record(saa->maa.maa_nasid, saa->dimm, - &sc->sc_spd, &sc->sc_spdlen); - if (rc != 0) { - printf(" can't get SPD record from L1, error %d\n", rc); - return; - } - - sc->sc_base.sc_read = spdmem_mainbus_read; - spdmem_attach_common(&sc->sc_base); - /* free record, as it won't be accessed anymore */ - free(sc->sc_spd, M_DEVBUF, sc->sc_spdlen); - sc->sc_spdlen = 0; -} - -uint8_t -spdmem_mainbus_read(struct spdmem_softc *v, uint8_t reg) -{ - struct spdmem_mainbus_softc *sc = (struct spdmem_mainbus_softc *)v; - - if (reg < sc->sc_spdlen) - return sc->sc_spd[reg]; - else - return 0; -} diff --git a/sys/arch/sgi/gio/Makefile b/sys/arch/sgi/gio/Makefile deleted file mode 100644 index 130e520dcfb..00000000000 --- a/sys/arch/sgi/gio/Makefile +++ /dev/null @@ -1,8 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2012/03/28 20:44:23 miod Exp $ -# $NetBSD: Makefile.giodevs,v 1.5 2008/10/19 22:05:21 apb Exp $ - -AWK= awk - -giodevs.h giodevs_data.h: giodevs devlist2h.awk - /bin/rm -f giodevs.h giodevs_data.h - ${AWK} -f devlist2h.awk giodevs diff --git a/sys/arch/sgi/gio/devlist2h.awk b/sys/arch/sgi/gio/devlist2h.awk deleted file mode 100644 index 3dddee47882..00000000000 --- a/sys/arch/sgi/gio/devlist2h.awk +++ /dev/null @@ -1,153 +0,0 @@ -#! /usr/bin/awk -f -# $OpenBSD: devlist2h.awk,v 1.2 2012/04/18 17:18:10 miod Exp $ -# $NetBSD: devlist2h.awk,v 1.5 2008/05/02 18:11:05 martin Exp $ -# -# Copyright (c) 1998 The NetBSD Foundation, Inc. -# All rights reserved. -# -# This code is derived from software contributed to The NetBSD Foundation -# by Christos Zoulas. -# -# 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. -# -# Copyright (c) 1995, 1996 Christopher G. Demetriou -# 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. -# 3. All advertising materials mentioning features or use of this software -# must display the following acknowledgement: -# This product includes software developed by Christopher G. Demetriou. -# This product includes software developed by Christos Zoulas -# 4. The name of the author(s) may not be used to endorse or promote products -# derived from this software without specific prior written permission -# -# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. -# -function collectline(_f, _line) { - _oparen = 0 - _line = "" - while (_f <= NF) { - if ($_f == "#") { - _line = _line "(" - _oparen = 1 - _f++ - continue - } - if (_oparen) { - _line = _line $_f - if (_f < NF) - _line = _line " " - _f++ - continue - } - _line = _line $_f - if (_f < NF) - _line = _line " " - _f++ - } - if (_oparen) - _line = _line ")" - return _line -} -BEGIN { - nproducts = nvendors = blanklines = 0 - dfile="giodevs_data.h" - hfile="giodevs.h" - line="" -} -NR == 1 { - VERSION = $0 - gsub("\\$", "", VERSION) - - printf("/*\n") > hfile - printf(" * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT.\n") \ - > hfile - printf(" *\n") > hfile - printf(" * generated from:\n") > hfile - printf(" *\t%s\n", VERSION) > hfile - printf(" */\n\n") > hfile - - printf("/*\n") > dfile - printf(" * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT.\n") \ - > dfile - printf(" *\n") > dfile - printf(" * generated from:\n") > dfile - printf(" *\t%s\n", VERSION) > dfile - printf(" */\n\n") > dfile - - next -} -NF > 0 && $1 == "product" { - nproducts++ - - products[nproducts, 1] = $2; - products[nproducts, 2] = $3 - products[nproducts, 3] = collectline(4, line) - - next -} -{ - if ($0 == "") - blanklines++ - if (blanklines < 2) - print $0 > dfile -} -END { - # print out the match tables - - printf("\n") > dfile - - printf("struct gio_knowndev {\n") > dfile - printf("\tint productid;\n") > dfile - printf("\tconst char *product;\n") > dfile - printf("};\n") > dfile - printf("\nstruct gio_knowndev gio_knowndevs[] = {\n") > dfile - - printf("\n") > hfile - for (i = 1; i <= nproducts; i++) { - printf("#define GIO_PRODUCT_%s\t%s\t/* %s */\n", - products[i, 1], products[i,2], products[i, 3]) > hfile - - printf("\t{ GIO_PRODUCT_%s, \"%s\" },\n", - products[i, 1], products[i, 3]) > dfile - } - printf("\t{ 0, NULL }\n") > dfile - printf("};\n") > dfile - close(dfile) - close(hfile) -} diff --git a/sys/arch/sgi/gio/files.gio b/sys/arch/sgi/gio/files.gio deleted file mode 100644 index 8e14a55aed5..00000000000 --- a/sys/arch/sgi/gio/files.gio +++ /dev/null @@ -1,35 +0,0 @@ -# $OpenBSD: files.gio,v 1.4 2012/05/10 21:30:09 miod Exp $ -# $NetBSD: files.gio,v 1.11 2009/02/12 06:33:57 rumble Exp $ - -device gio {[slot = -1], [addr = -1]} -attach gio at giobus - -file arch/sgi/gio/gio.c gio needs-flag - -device hpc {[offset = -1]}: smc93cx6 -attach hpc at gio -file arch/sgi/hpc/hpc.c hpc - -# XL graphics -device newport: wsemuldisplaydev, rasops8 -attach newport at gio -file arch/sgi/gio/newport.c newport needs-flag - -# GR2 graphics -device grtwo: wsemuldisplaydev, rasops8 -attach grtwo at gio -file arch/sgi/gio/grtwo.c grtwo needs-flag - -# LG1/LG2 graphics -device light: wsemuldisplaydev, rasops8 -attach light at gio -file arch/sgi/gio/light.c light needs-flag - -# Impact graphics -attach impact at gio with impact_gio -file arch/sgi/gio/impact_gio.c impact_gio - -# PCI cards glued to the GIO bus -device giopci: pcibus -attach giopci at gio -file arch/sgi/gio/pci_gio.c giopci diff --git a/sys/arch/sgi/gio/gio.c b/sys/arch/sgi/gio/gio.c deleted file mode 100644 index 4175cc24f50..00000000000 --- a/sys/arch/sgi/gio/gio.c +++ /dev/null @@ -1,797 +0,0 @@ -/* $OpenBSD: gio.c,v 1.19 2021/03/11 11:17:00 jsg Exp $ */ -/* $NetBSD: gio.c,v 1.32 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2000 Soren S. Jorvang - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> - -#include <mips64/archtype.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giovar.h> -#include <sgi/gio/giodevs.h> -#include <sgi/gio/giodevs_data.h> - -#include <sgi/gio/grtworeg.h> -#include <sgi/gio/lightreg.h> -#include <sgi/gio/newportreg.h> - -#include <sgi/localbus/imcvar.h> -#include <sgi/localbus/intreg.h> -#include <sgi/localbus/intvar.h> -#include <sgi/sgi/ip22.h> - -#include "grtwo.h" -#include "impact.h" -#include "light.h" -#include "newport.h" - -#if NGRTWO > 0 -#include <sgi/gio/grtwovar.h> -#endif -#if NIMPACT_GIO > 0 -#include <sgi/dev/impactvar.h> -#endif -#if NLIGHT > 0 -#include <sgi/gio/lightvar.h> -#endif -#if NNEWPORT > 0 -#include <sgi/gio/newportvar.h> -#endif - -int gio_match(struct device *, void *, void *); -void gio_attach(struct device *, struct device *, void *); -int gio_print(void *, const char *); -int gio_print_fb(void *, const char *); -int gio_search(struct device *, void *, void *); -int gio_submatch(struct device *, void *, void *); -uint32_t gio_id(vaddr_t, paddr_t, int); -int gio_is_framebuffer_id(uint32_t); - -struct gio_softc { - struct device sc_dev; - - bus_space_tag_t sc_iot; - bus_dma_tag_t sc_dmat; -}; - -const struct cfattach gio_ca = { - sizeof(struct gio_softc), gio_match, gio_attach -}; - -struct cfdriver gio_cd = { - NULL, "gio", DV_DULL -}; - -/* Address of the console frame buffer registers, if applicable */ -paddr_t giofb_consaddr; -/* Id of the console frame buffer */ -uint32_t giofb_consid; -/* Names of the frame buffers, as obtained by ARCBios */ -const char *giofb_names[GIO_MAX_FB]; - -struct gio_probe { - uint32_t slot; - uint64_t base; - uint32_t mach_type; - uint32_t mach_subtype; -}; - -/* - * Expansion Slot Base Addresses - * - * IP20 and IP24 have two GIO connectors: GIO_SLOT_EXP0 and - * GIO_SLOT_EXP1. - * - * On IP24 these slots exist on the graphics board or the IOPLUS - * "mezzanine" on Indy and Challenge S, respectively. The IOPLUS or - * graphics board connects to the mainboard via a single GIO64 connector. - * - * IP22 has either three or four physical connectors, but only two - * electrically distinct slots: GIO_SLOT_GFX and GIO_SLOT_EXP0. - * - * It should also be noted that DMA is (mostly) not supported in Challenge S's - * GIO_SLOT_EXP1. See gio(4) for the story. - */ -static const struct gio_probe slot_bases[] = { - /* GFX is only a slot on Indigo 2 */ - { GIO_SLOT_GFX, GIO_ADDR_GFX, SGI_IP22, IP22_INDIGO2 }, - - /* EXP0 is available on all systems */ - { GIO_SLOT_EXP0, GIO_ADDR_EXP0, SGI_IP20, -1 }, - { GIO_SLOT_EXP0, GIO_ADDR_EXP0, SGI_IP22, -1 }, - - /* EXP1 does not exist on Indigo 2 */ - { GIO_SLOT_EXP1, GIO_ADDR_EXP1, SGI_IP20, -1 }, - { GIO_SLOT_EXP1, GIO_ADDR_EXP1, SGI_IP22, IP22_INDY }, - { GIO_SLOT_EXP1, GIO_ADDR_EXP1, SGI_IP22, IP22_CHALLS }, - - { 0, 0, 0, 0 } -}; - -/* - * Graphic Board Base Addresses - * - * Graphics boards are not treated like expansion slot cards. Their base - * addresses do not necessarily correspond to GIO slot addresses and they - * do not contain product identification words. - * - * This list needs to be sorted in address order, to match the descriptions - * obtained from ARCBios. - */ -static const struct gio_probe gfx_bases[] = { - { -1, GIO_ADDR_GFX, SGI_IP20, -1 }, - { -1, GIO_ADDR_GFX, SGI_IP22, -1 }, - - /* IP20 LG1/LG2 */ - { -1, GIO_ADDR_GFX + 0x003f0000, SGI_IP20, -1 }, - { -1, GIO_ADDR_GFX + 0x003f8000, SGI_IP20, -1 }, /* second head */ - - { -1, GIO_ADDR_EXP0, SGI_IP22, -1 }, - { -1, GIO_ADDR_EXP1, SGI_IP22, -1 }, - - { 0, 0, 0, 0 } -}; - -int -gio_match(struct device *parent, void *match, void *aux) -{ - struct imc_attach_args *iaa = aux; - - if (strcmp(iaa->iaa_name, gio_cd.cd_name) != 0) - return 0; - - return 1; -} - -void -gio_attach(struct device *parent, struct device *self, void *aux) -{ - struct gio_softc *sc = (struct gio_softc *)self; - struct imc_attach_args *iaa = (struct imc_attach_args *)aux; - struct gio_attach_args ga; - uint32_t gfx[GIO_MAX_FB], id; - uint i, j, ngfx; - int sys_type; - - printf("\n"); - - sc->sc_iot = iaa->iaa_st; - sc->sc_dmat = iaa->iaa_dmat; - - switch (sys_config.system_type) { - case SGI_IP20: - sys_type = SGI_IP20; - break; - default: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - sys_type = SGI_IP22; - break; - } - - ngfx = 0; - memset(gfx, 0, sizeof(gfx)); - - /* - * Try and attach graphics devices first. - * Unfortunately, they - not being GIO devices after all (except for - * Impact) - do not contain a Product Identification Word, nor have - * a slot number. - * - * Record addresses to which graphics devices attach so that - * we do not confuse them with expansion slots, should the - * addresses coincide. - * - * If only the ARCBios component tree would be so kind as to give - * us the address of the frame buffer components... - */ - if (sys_type != SGI_IP22 || - sys_config.system_subtype != IP22_CHALLS) { - for (i = 0; gfx_bases[i].base != 0; i++) { - /* skip slots that don't apply to us */ - if (gfx_bases[i].mach_type != sys_type) - continue; - - if (gfx_bases[i].mach_subtype != -1 && - gfx_bases[i].mach_subtype != - sys_config.system_subtype) - continue; - - ga.ga_addr = gfx_bases[i].base; - ga.ga_ioh = PHYS_TO_XKPHYS(ga.ga_addr, CCA_NC); - - /* no need to probe a glass console again */ - if (ga.ga_addr == giofb_consaddr && giofb_consid != 0) - id = giofb_consid; - else { - id = gio_id(ga.ga_ioh, ga.ga_addr, 1); - if (!gio_is_framebuffer_id(id)) - continue; - } - - ga.ga_iot = sc->sc_iot; - ga.ga_dmat = sc->sc_dmat; - ga.ga_slot = -1; - ga.ga_product = id; - /* - * Note that this relies upon ARCBios listing frame - * buffers in ascending address order, which seems - * to be the case so far on multihead Indigo2 systems. - */ - if (ngfx < GIO_MAX_FB) - ga.ga_descr = giofb_names[ngfx]; - else - ga.ga_descr = NULL; /* shouldn't happen */ - - if (config_found_sm(self, &ga, gio_print_fb, - gio_submatch)) - gfx[ngfx] = gfx_bases[i].base; - - ngfx++; - } - } - - /* - * Now attach any GIO expansion cards. - * - * Be sure to skip any addresses to which a graphics device has - * already been attached. - */ - for (i = 0; slot_bases[i].base != 0; i++) { - int skip = 0; - - /* skip slots that don't apply to us */ - if (slot_bases[i].mach_type != sys_type) - continue; - - if (slot_bases[i].mach_subtype != -1 && - slot_bases[i].mach_subtype != sys_config.system_subtype) - continue; - - for (j = 0; j < ngfx; j++) { - if (slot_bases[i].base == gfx[j]) { - skip = 1; - break; - } - } - if (skip) - continue; - - ga.ga_addr = slot_bases[i].base; - ga.ga_iot = sc->sc_iot; - ga.ga_ioh = PHYS_TO_XKPHYS(ga.ga_addr, CCA_NC); - - id = gio_id(ga.ga_ioh, ga.ga_addr, 0); - if (id == 0) - continue; - - ga.ga_dmat = sc->sc_dmat; - ga.ga_slot = slot_bases[i].slot; - ga.ga_product = id; - ga.ga_descr = NULL; - - config_found_sm(self, &ga, gio_print, gio_submatch); - } - - config_search(gio_search, self, aux); -} - -/* - * Try and figure out whether there is a device at the given slot address. - */ -uint32_t -gio_id(vaddr_t va, paddr_t pa, int maybe_gfx) -{ - uint32_t id32, mystery; - uint16_t id16 = 0; - uint8_t id8 = 0; - - /* - * First, attempt to read the address with various sizes. - * - * - GIO32 devices will only support reads from 32-bit aligned - * addresses, in all sizes (at least for the ID register). - * - frame buffers will support aligned reads from any size at - * any address, but will actually return the access width if - * the slot is pipelined. - */ - - if (guarded_read_4(va, &id32) != 0) - return 0; - - /* - * If the address doesn't match a base slot address, then we are - * only probing for a light(4) frame buffer. - */ - - if (pa != GIO_ADDR_GFX && pa != GIO_ADDR_EXP0 && pa != GIO_ADDR_EXP1) { - if (maybe_gfx == 0) - return 0; - else { - if (pa == LIGHT_ADDR_0 || pa == LIGHT_ADDR_1) { - if (guarded_read_4(va + REX_PAGE1_SET + - REX_P1REG_XYOFFSET, &id32) != 0) - return 0; - if (id32 == 0x08000800) - return GIO_PRODUCT_FAKEID_LIGHT; - } - return 0; - } - } - - /* - * GIO32 devices with a 32-bit ID register will not necessarily - * answer to addresses not aligned on 32 bit boundaries. - */ - - if (guarded_read_2(va | 2, &id16) != 0 || - guarded_read_1(va | 3, &id8) != 0) { - if (GIO_PRODUCT_32BIT_ID(id32)) - return id32; - else /* not a frame buffer anyway */ - return GIO_PRODUCT_PRODUCTID(id32); - } - - /* - * Of course, GIO32 devices with a 8-bit ID register can use the - * other bytes in the first 32-bit word for other purposes. - */ - - if ((id32 & 0xffff) == id16 && (id32 & 0xff) == id8) { - if (GIO_PRODUCT_32BIT_ID(id32)) - return id32; - else if (!GIO_PRODUCT_32BIT_ID(id8) && id8 != 0x00) - return /*GIO_PRODUCT_PRODUCTID*/(id8); - } - - /* - * If there is a frame buffer device, then either we have hit a - * device register (grtwo), or we did not fault because the slot - * is pipelined (newport). - * In the latter case, we attempt to probe a known register offset. - */ - - if (maybe_gfx) { - /* - * On (at least) Indy systems with newport graphics, the - * presence of a SCSI Expansion board (030-8133) in either - * slot will cause extra bits to be set in the topmost byte - * of the 32-bit access to the pipelined slot (i.e. the - * value of id32 is 0x18000004, not 0x00000004). - * - * This would prevent newport from being recognized - * properly. - * - * This behaviour seems to be specific to the SCSI board, - * since the E++ board does not trigger it. This would - * rule out an HPC1.x-specific cause. - * - * We work around this by ignoring the topmost byte of id32 - * from this point on, but it's ugly and isaish... - * - * Note that this is not necessary on Indigo 2 since this - * troublesome board can not be installed on such a system. - * Indigo are probably safe from this issues, for they can't - * use newport graphics; but the issue at hand might be - * HPC 1.x related, so better play safe. - */ - if (sys_config.system_type == SGI_IP20 || - (sys_config.system_type == SGI_IP22 && - sys_config.system_subtype != IP22_INDIGO2)) - id32 &= ~0xff000000; - - if (id32 != 4 || id16 != 2 || id8 != 1) { - if (guarded_read_4(va + HQ2_MYSTERY, &mystery) == 0 && - mystery == HQ2_MYSTERY_VALUE) - return GIO_PRODUCT_FAKEID_GRTWO; - else - return 0; - } - - /* could be newport(4) */ - if (pa == GIO_ADDR_GFX || pa == GIO_ADDR_EXP0) { - va += NEWPORT_REX3_OFFSET; - if (guarded_read_4(va, &id32) == 0 && - guarded_read_2(va | 2, &id16) == 0 && - guarded_read_1(va | 3, &id8) == 0) { - if (id32 != 4 || id16 != 2 || id8 != 1) - return GIO_PRODUCT_FAKEID_NEWPORT; - } - } - - return 0; - } - - return 0; -} - -int -gio_print(void *aux, const char *pnp) -{ - struct gio_attach_args *ga = aux; - const char *descr; - int product, revision; - uint i; - - product = GIO_PRODUCT_PRODUCTID(ga->ga_product); - if (GIO_PRODUCT_32BIT_ID(ga->ga_product)) - revision = GIO_PRODUCT_REVISION(ga->ga_product); - else - revision = 0; - - descr = "unknown GIO card"; - for (i = 0; gio_knowndevs[i].productid != 0; i++) { - if (gio_knowndevs[i].productid == product) { - descr = gio_knowndevs[i].product; - break; - } - } - - if (pnp != NULL) { - printf("%s", descr); - if (ga->ga_product != -1) - printf(" (product 0x%02x revision 0x%02x)", - product, revision); - printf(" at %s", pnp); - } - - if (ga->ga_slot != -1) - printf(" slot %d", ga->ga_slot); - printf(" addr 0x%llx", ga->ga_addr); - - return UNCONF; -} - -int -gio_print_fb(void *aux, const char *pnp) -{ - struct gio_attach_args *ga = aux; - const char *fbname; - - if (pnp != NULL) { - switch (ga->ga_product) { - case GIO_PRODUCT_FAKEID_GRTWO: - fbname = "grtwo"; - break; - case GIO_PRODUCT_FAKEID_LIGHT: - fbname = "light"; - break; - case GIO_PRODUCT_FAKEID_NEWPORT: - fbname = "newport"; - break; - default: - if (GIO_PRODUCT_32BIT_ID(ga->ga_product) && - GIO_PRODUCT_PRODUCTID(ga->ga_product) == - GIO_PRODUCT_IMPACT) - fbname = "impact"; - else /* should never happen */ - fbname = "framebuffer"; - break; - } - printf("%s at %s", fbname, pnp); - } - - printf(" addr 0x%llx", ga->ga_addr); - - return UNCONF; -} - -int -gio_search(struct device *parent, void *vcf, void *aux) -{ - struct gio_softc *sc = (struct gio_softc *)parent; - struct cfdata *cf = (struct cfdata *)vcf; - struct gio_attach_args ga; - - /* Handled by direct configuration, so skip here */ - if (cf->cf_loc[1 /*GIOCF_ADDR*/] == -1) - return 0; - - ga.ga_addr = (uint64_t)cf->cf_loc[1 /*GIOCF_ADDR*/]; - ga.ga_iot = sc->sc_iot; - ga.ga_ioh = PHYS_TO_XKPHYS(ga.ga_addr, CCA_NC); - ga.ga_dmat = sc->sc_dmat; - ga.ga_slot = cf->cf_loc[0 /*GIOCF_SLOT*/]; - ga.ga_product = -1; - ga.ga_descr = NULL; - - if ((*cf->cf_attach->ca_match)(parent, cf, &ga) == 0) - return 0; - - config_attach(parent, cf, &ga, gio_print); - - return 1; -} - -int -gio_submatch(struct device *parent, void *vcf, void *aux) -{ - struct cfdata *cf = (struct cfdata *)vcf; - struct gio_attach_args *ga = (struct gio_attach_args *)aux; - - if (cf->cf_loc[0 /*GIOCF_SLOT*/] != -1 && - cf->cf_loc[0 /*GIOCF_SLOT*/] != ga->ga_slot) - return 0; - - if (cf->cf_loc[1 /*GIOCF_ADDR*/] != -1 && - (uint64_t)cf->cf_loc[1 /*GIOCF_ADDR*/] != ga->ga_addr) - return 0; - - return (*cf->cf_attach->ca_match)(parent, cf, aux); -} - -int -giofb_cnprobe() -{ - struct gio_attach_args ga; - uint32_t id; - int i; - int sys_type; - - switch (sys_config.system_type) { - case SGI_IP20: - sys_type = SGI_IP20; - break; - default: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - sys_type = SGI_IP22; - break; - } - - for (i = 0; gfx_bases[i].base != 0; i++) { - if (giofb_consaddr != 0 && - gfx_bases[i].base != giofb_consaddr) - continue; - - /* skip bases that don't apply to us */ - if (gfx_bases[i].mach_type != sys_type) - continue; - - if (gfx_bases[i].mach_subtype != -1 && - gfx_bases[i].mach_subtype != sys_config.system_subtype) - continue; - - ga.ga_addr = gfx_bases[i].base; - ga.ga_iot = &imcbus_tag; - ga.ga_ioh = PHYS_TO_XKPHYS(ga.ga_addr, CCA_NC); - ga.ga_dmat = &imc_bus_dma_tag; - ga.ga_slot = -1; - ga.ga_descr = NULL; - - id = gio_id(ga.ga_ioh, ga.ga_addr, 1); - if (!gio_is_framebuffer_id(id)) - continue; - - ga.ga_product = giofb_consid = id; - switch (id) { - default: -#if NIMPACT_GIO > 0 - if (GIO_PRODUCT_32BIT_ID(id) && - GIO_PRODUCT_PRODUCTID(id) == GIO_PRODUCT_IMPACT) { - if (impact_gio_cnprobe(&ga) != 0) - return 0; - } -#endif - break; - case GIO_PRODUCT_FAKEID_GRTWO: -#if NGRTWO > 0 - if (grtwo_cnprobe(&ga) != 0) - return 0; -#endif - break; - case GIO_PRODUCT_FAKEID_LIGHT: -#if NLIGHT > 0 - if (light_cnprobe(&ga) != 0) - return 0; -#endif - break; - case GIO_PRODUCT_FAKEID_NEWPORT: -#if NNEWPORT > 0 - if (newport_cnprobe(&ga) != 0) - return 0; -#endif - break; - } - } - - return ENXIO; -} - -int -giofb_cnattach() -{ - struct gio_attach_args ga; - - ga.ga_addr = giofb_consaddr; - ga.ga_iot = &imcbus_tag; - ga.ga_ioh = PHYS_TO_XKPHYS(ga.ga_addr, CCA_NC); - ga.ga_dmat = &imc_bus_dma_tag; - ga.ga_slot = -1; - ga.ga_product = giofb_consid; - ga.ga_descr = NULL; - - switch (giofb_consid) { - default: -#if NIMPACT_GIO > 0 - if (GIO_PRODUCT_32BIT_ID(giofb_consid) && - GIO_PRODUCT_PRODUCTID(giofb_consid) == GIO_PRODUCT_IMPACT) { - if (impact_gio_cnattach(&ga) == 0) - return 0; - } -#endif - break; - case GIO_PRODUCT_FAKEID_GRTWO: -#if NGRTWO > 0 - if (grtwo_cnattach(&ga) == 0) - return 0; -#endif - break; - case GIO_PRODUCT_FAKEID_LIGHT: -#if NLIGHT > 0 - if (light_cnattach(&ga) == 0) - return 0; -#endif - break; - case GIO_PRODUCT_FAKEID_NEWPORT: -#if NNEWPORT > 0 - if (newport_cnattach(&ga) == 0) - return 0; -#endif - break; - } - - giofb_consaddr = 0; - return ENXIO; -} - -int -gio_is_framebuffer_id(uint32_t id) -{ - switch (id) { - case GIO_PRODUCT_FAKEID_GRTWO: - case GIO_PRODUCT_FAKEID_LIGHT: - case GIO_PRODUCT_FAKEID_NEWPORT: - return 1; - default: - if (GIO_PRODUCT_32BIT_ID(id) && - GIO_PRODUCT_PRODUCTID(id) == GIO_PRODUCT_IMPACT) - return 1; - else - return 0; - } -} - -/* - * Devices living in the expansion slots must enable or disable some - * GIO arbiter settings. This is accomplished via imc(4) registers. - */ -int -gio_arb_config(int slot, uint32_t flags) -{ - if (flags == 0) - return (EINVAL); - - if (flags & ~(GIO_ARB_RT | GIO_ARB_LB | GIO_ARB_MST | GIO_ARB_SLV | - GIO_ARB_PIPE | GIO_ARB_NOPIPE | GIO_ARB_32BIT | GIO_ARB_64BIT | - GIO_ARB_HPC2_32BIT | GIO_ARB_HPC2_64BIT)) - return (EINVAL); - - if (((flags & GIO_ARB_RT) && (flags & GIO_ARB_LB)) || - ((flags & GIO_ARB_MST) && (flags & GIO_ARB_SLV)) || - ((flags & GIO_ARB_PIPE) && (flags & GIO_ARB_NOPIPE)) || - ((flags & GIO_ARB_32BIT) && (flags & GIO_ARB_64BIT)) || - ((flags & GIO_ARB_HPC2_32BIT) && (flags & GIO_ARB_HPC2_64BIT))) - return (EINVAL); - - return (imc_gio64_arb_config(slot, flags)); -} - -/* - * Return the logical interrupt number for an expansion board (not a frame - * buffer!) in the specified slot. - * - * Indy and Challenge S have a single GIO interrupt per GIO slot, but - * distinct slot interrupts. Indigo and Indigo2 have three GIO interrupts per - * slot, but at a given GIO interrupt level, all slots share the same - * interrupt on the interrupt controller. - * - * Expansion boards appear to always use the intermediate level. - */ -int -gio_intr_map(int slot) -{ - switch (sys_config.system_type) { - case SGI_IP20: - if (slot == GIO_SLOT_GFX) - return -1; - return INT2_L0_INTR(INT2_L0_GIO_LVL1); - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - if (sys_config.system_subtype == IP22_INDIGO2) { - if (slot == GIO_SLOT_EXP1) - return -1; - return INT2_L0_INTR(INT2_L0_GIO_LVL1); - } else { - if (slot == GIO_SLOT_GFX) - return -1; - return INT2_MAP1_INTR(slot == GIO_SLOT_EXP0 ? - INT2_MAP_GIO_SLOT0 : INT2_MAP_GIO_SLOT1); - } - default: - return -1; - } -} - -void * -gio_intr_establish(int intr, int level, int (*func)(void *), void *arg, - const char *what) -{ - return int2_intr_establish(intr, level, func, arg, what); -} - -const char * -gio_product_string(int prid) -{ - int i; - - for (i = 0; gio_knowndevs[i].product != NULL; i++) - if (gio_knowndevs[i].productid == prid) - return (gio_knowndevs[i].product); - - return (NULL); -} diff --git a/sys/arch/sgi/gio/giodevs b/sys/arch/sgi/gio/giodevs deleted file mode 100644 index 6969fca00b5..00000000000 --- a/sys/arch/sgi/gio/giodevs +++ /dev/null @@ -1,27 +0,0 @@ -$OpenBSD: giodevs,v 1.5 2014/08/19 19:01:15 miod Exp $ -/* $NetBSD: giodevs,v 1.8 2007/02/19 04:46:33 rumble Exp $ */ - -/* devices with 8-bit identification registers */ -product XPI 0x01 XPI low cost FDDI -product GTR 0x02 GTR TokenRing -product ISDN 0x04 Synchronous ISDN -product CANON 0x06 Canon Interface -product JPEG_D 0x08 JPEG (Double Wide) -product JPEG_S 0x09 JPEG (Single Wide) -product XPI_M0 0x0a XPI mez. FDDI device 0 -product XPI_M1 0x0b XPI mez. FDDI device 1 -product EP 0x0e E-Plex 8-port Ethernet -product IVAS 0x30 Lyon Lamb IVAS -product FORE_ATM 0x5c FORE Systems GIA-200 ATM -product GIOCLC 0x7f Cyclone Colorbus - -/* devices with 32-bit identification registers */ -product ATM 0x05 ATM board -product SCSI 0x07 16 bit SCSI Card -product SMPTE 0x0c SMPTE 259M Video -product BABBLE 0x0d Babblefish Compression -product IMPACT 0x10 Impact -product PHOBOS_G160 0x35 Phobos G160 10/100 Ethernet -product PHOBOS_G130 0x36 Phobos G130 10/100 Ethernet -product PHOBOS_G100 0x37 Phobos G100 100baseTX Fast Ethernet -product SETENG_GFE 0x38 Set Engineering GFE 10/100 Ethernet diff --git a/sys/arch/sgi/gio/giodevs.h b/sys/arch/sgi/gio/giodevs.h deleted file mode 100644 index 21e1daeaebb..00000000000 --- a/sys/arch/sgi/gio/giodevs.h +++ /dev/null @@ -1,29 +0,0 @@ -/* - * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT. - * - * generated from: - * OpenBSD: giodevs,v 1.4 2012/07/18 20:10:12 miod Exp - */ - - -#define GIO_PRODUCT_XPI 0x01 /* XPI low cost FDDI */ -#define GIO_PRODUCT_GTR 0x02 /* GTR TokenRing */ -#define GIO_PRODUCT_ISDN 0x04 /* Synchronous ISDN */ -#define GIO_PRODUCT_CANON 0x06 /* Canon Interface */ -#define GIO_PRODUCT_JPEG_D 0x08 /* JPEG (Double Wide) */ -#define GIO_PRODUCT_JPEG_S 0x09 /* JPEG (Single Wide) */ -#define GIO_PRODUCT_XPI_M0 0x0a /* XPI mez. FDDI device 0 */ -#define GIO_PRODUCT_XPI_M1 0x0b /* XPI mez. FDDI device 1 */ -#define GIO_PRODUCT_EP 0x0e /* E-Plex 8-port Ethernet */ -#define GIO_PRODUCT_IVAS 0x30 /* Lyon Lamb IVAS */ -#define GIO_PRODUCT_SETENG_GFE 0x38 /* Set Engineering GFE 10/100 Ethernet */ -#define GIO_PRODUCT_FORE_ATM 0x5c /* FORE Systems GIA-200 ATM */ -#define GIO_PRODUCT_GIOCLC 0x7f /* Cyclone Colorbus */ -#define GIO_PRODUCT_ATM 0x05 /* ATM board */ -#define GIO_PRODUCT_SCSI 0x07 /* 16 bit SCSI Card */ -#define GIO_PRODUCT_SMPTE 0x0c /* SMPTE 259M Video */ -#define GIO_PRODUCT_BABBLE 0x0d /* Babblefish Compression */ -#define GIO_PRODUCT_IMPACT 0x10 /* Impact */ -#define GIO_PRODUCT_PHOBOS_G160 0x35 /* Phobos G160 10/100 Ethernet */ -#define GIO_PRODUCT_PHOBOS_G130 0x36 /* Phobos G130 10/100 Ethernet */ -#define GIO_PRODUCT_PHOBOS_G100 0x37 /* Phobos G100 100baseTX Fast Ethernet */ diff --git a/sys/arch/sgi/gio/giodevs_data.h b/sys/arch/sgi/gio/giodevs_data.h deleted file mode 100644 index 094bd0069be..00000000000 --- a/sys/arch/sgi/gio/giodevs_data.h +++ /dev/null @@ -1,40 +0,0 @@ -/* - * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT. - * - * generated from: - * OpenBSD: giodevs,v 1.4 2012/07/18 20:10:12 miod Exp - */ - -/* $NetBSD: giodevs,v 1.8 2007/02/19 04:46:33 rumble Exp $ */ - -/* devices with 8-bit identification registers */ - -struct gio_knowndev { - int productid; - const char *product; -}; - -struct gio_knowndev gio_knowndevs[] = { - { GIO_PRODUCT_XPI, "XPI low cost FDDI" }, - { GIO_PRODUCT_GTR, "GTR TokenRing" }, - { GIO_PRODUCT_ISDN, "Synchronous ISDN" }, - { GIO_PRODUCT_CANON, "Canon Interface" }, - { GIO_PRODUCT_JPEG_D, "JPEG (Double Wide)" }, - { GIO_PRODUCT_JPEG_S, "JPEG (Single Wide)" }, - { GIO_PRODUCT_XPI_M0, "XPI mez. FDDI device 0" }, - { GIO_PRODUCT_XPI_M1, "XPI mez. FDDI device 1" }, - { GIO_PRODUCT_EP, "E-Plex 8-port Ethernet" }, - { GIO_PRODUCT_IVAS, "Lyon Lamb IVAS" }, - { GIO_PRODUCT_SETENG_GFE, "Set Engineering GFE 10/100 Ethernet" }, - { GIO_PRODUCT_FORE_ATM, "FORE Systems GIA-200 ATM" }, - { GIO_PRODUCT_GIOCLC, "Cyclone Colorbus" }, - { GIO_PRODUCT_ATM, "ATM board" }, - { GIO_PRODUCT_SCSI, "16 bit SCSI Card" }, - { GIO_PRODUCT_SMPTE, "SMPTE 259M Video" }, - { GIO_PRODUCT_BABBLE, "Babblefish Compression" }, - { GIO_PRODUCT_IMPACT, "Impact" }, - { GIO_PRODUCT_PHOBOS_G160, "Phobos G160 10/100 Ethernet" }, - { GIO_PRODUCT_PHOBOS_G130, "Phobos G130 10/100 Ethernet" }, - { GIO_PRODUCT_PHOBOS_G100, "Phobos G100 100baseTX Fast Ethernet" }, - { 0, NULL } -}; diff --git a/sys/arch/sgi/gio/gioreg.h b/sys/arch/sgi/gio/gioreg.h deleted file mode 100644 index 9abc4ff4283..00000000000 --- a/sys/arch/sgi/gio/gioreg.h +++ /dev/null @@ -1,75 +0,0 @@ -/* $OpenBSD: gioreg.h,v 1.4 2014/07/02 17:44:35 miod Exp $ */ -/* $NetBSD: gioreg.h,v 1.4 2006/08/31 00:01:10 rumble Exp $ */ - -/* - * Copyright (c) 2003 Ilpo Ruotsalainen - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -/* - * The GIO Product Identification Word is the first word (1 or 4 bytes) - * in each GIO device's address space. It is the same format for GIO32, - * GIO32-bis, and GIO64 devices. The macros below extract the following - * fields: - * - * Bits: - * 0-6 Product ID Code - * 7 Product Identification Word size (0: 8 bits, 1: 32 bits) - * 8-15 Product Revision - * 16 GIO Interface Size (0: 32, 1: 64; NB: GIO64 devices may be 32) - * 17 Rom Present (1: present) - * 18-31 Manufacturer-specific Code - * - * The upper three bytes containing the Product Revision, GIO Interface - * Size, Rom Presence indicator, and Manufacturer-specific Code are only - * valid if bit 7 is set in the Product ID Word. If it is not set, all - * values default to 0. - * - * If the Rom Present bit is set, the three words after the Product ID are - * reserved for three ROM registers: - * Board Serial Number Register (base_address + 0x4) - * ROM Index Register (base_address + 0x8) - * ROM Read Register (base_address + 0xc) - * - * The ROM Index Register is initialised by the CPU to 0 and incremented by - * 4 on each read from the ROM Read Register. The Board Serial Number - * Register contains a manufacturer-specific serial number. - */ - -#define GIO_PRODUCT_32BIT_ID(x) ((x) & 0x80) -#define GIO_PRODUCT_PRODUCTID(x) ((x) & 0x7f) -#define GIO_PRODUCT_REVISION(x) (((x) >> 8) & 0xff) -#define GIO_PRODUCT_IS_64BIT(x) (!!((x) & 0x10000)) -#define GIO_PRODUCT_HAS_ROM(x) (!!((x) & 0x20000)) -#define GIO_PRODUCT_MANUCODE(x) ((x) >> 18) - -#define GIO_ADDR_GFX 0x1f000000 /* 4MB */ -#define GIO_ADDR_EXP0 0x1f400000 /* 2MB */ -#define GIO_ADDR_EXP1 0x1f600000 /* 4MB */ -#define GIO_ADDR_END 0x1fa00000 - -#define IS_GIO_ADDRESS(pa) ((pa) >= GIO_ADDR_GFX && (pa) < GIO_ADDR_END) diff --git a/sys/arch/sgi/gio/giovar.h b/sys/arch/sgi/gio/giovar.h deleted file mode 100644 index 3b5b9ca62cf..00000000000 --- a/sys/arch/sgi/gio/giovar.h +++ /dev/null @@ -1,97 +0,0 @@ -/* $OpenBSD: giovar.h,v 1.4 2012/05/17 19:46:52 miod Exp $ */ -/* $NetBSD: giovar.h,v 1.10 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2000 Soren S. Jorvang - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * GIO 32/32-bis/64 bus - */ - -struct gio_attach_args { - bus_space_tag_t ga_iot; - bus_space_handle_t ga_ioh; - bus_dma_tag_t ga_dmat; - - int ga_slot; /* -1 if graphics */ - u_int64_t ga_addr; - - u_int32_t ga_product; /* not valid if graphics */ - const char *ga_descr; /* only valid if graphics */ -}; - - -#define GIO_SLOT_GFX 0 -#define GIO_SLOT_EXP0 1 -#define GIO_SLOT_EXP1 2 - -#define GIO_ARB_RT 0x001 /* real-time device */ -#define GIO_ARB_LB 0x002 /* long-burst device */ - -#define GIO_ARB_MST 0x004 /* bus master enable */ -#define GIO_ARB_SLV 0x008 /* slave */ - -#define GIO_ARB_PIPE 0x010 /* pipelining enable */ -#define GIO_ARB_NOPIPE 0x020 /* pipelining disable */ - -#define GIO_ARB_32BIT 0x040 /* 32-bit transfers */ -#define GIO_ARB_64BIT 0x080 /* 64-bit transfers */ - -#define GIO_ARB_HPC2_32BIT 0x100 /* 32-bit secondary HPC (ignores slot)*/ -#define GIO_ARB_HPC2_64BIT 0x200 /* 64-bit secondary HPC (ignores slot)*/ - -/* - * Maximum number of graphics boards installed. The known limit is 2, - * but we're allowing room for some surprises. - */ -#define GIO_MAX_FB 3 - -int gio_arb_config(int, uint32_t); -int gio_intr_map(int); -void *gio_intr_establish(int, int, int (*)(void *), void *, - const char *); -const char *gio_product_string(int); - -int giofb_cnattach(void); -int giofb_cnprobe(void); - -extern paddr_t giofb_consaddr; -extern const char *giofb_names[GIO_MAX_FB]; - -/* - * Fake GIO device IDs to identify frame buffers without GIO IDs. - * These are built as 32-bit GIO IDs without the `32-bit ID' bit set. - */ - -#define GIO_PRODUCT_FAKEID_LIGHT 0xff010000 -#define GIO_PRODUCT_FAKEID_NEWPORT 0xff020000 -#define GIO_PRODUCT_FAKEID_GRTWO 0xff030000 diff --git a/sys/arch/sgi/gio/grtwo.c b/sys/arch/sgi/gio/grtwo.c deleted file mode 100644 index 1090dedff94..00000000000 --- a/sys/arch/sgi/gio/grtwo.c +++ /dev/null @@ -1,919 +0,0 @@ -/* $OpenBSD: grtwo.c,v 1.15 2020/05/25 09:55:48 jsg Exp $ */ -/* $NetBSD: grtwo.c,v 1.11 2009/11/22 19:09:15 mbalmer Exp $ */ - -/* - * Copyright (c) 2012, 2014 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2004 Christopher SEKIYA - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -/* wscons driver for SGI GR2 family of framebuffers - * - * Heavily based on the newport wscons driver. - */ - -/* - * GR2 coordinates start from (0,0) in the lower left corner, to (1279,1023) - * in the upper right. The low-level drawing routines will take care of - * converting the traditional ``y goes down'' coordinates to those expected - * by the hardware. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <machine/autoconf.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsdisplayvar.h> -#include <dev/rasops/rasops.h> - -#include <sgi/dev/gl.h> -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giovar.h> -#include <sgi/gio/grtworeg.h> -#include <dev/ic/bt458reg.h> -#include <sgi/gio/grtwovar.h> -#include <sgi/localbus/intreg.h> -#include <sgi/localbus/intvar.h> - -#include <dev/cons.h> - -#define GRTWO_WIDTH 1280 -#define GRTWO_HEIGHT 1024 - -struct grtwo_softc { - struct device sc_dev; - - struct grtwo_devconfig *sc_dc; - - int sc_nscreens; - struct wsscreen_list sc_wsl; - const struct wsscreen_descr *sc_scrlist[1]; -}; - -struct grtwo_devconfig { - struct rasops_info dc_ri; - uint32_t dc_defattr; - struct wsdisplay_charcell *dc_bs; - - uint32_t dc_addr; - bus_space_tag_t iot; - bus_space_handle_t ioh; - - uint32_t xmapmode; - - uint8_t boardrev; - uint8_t backendrev; - int hq2rev; - int ge7rev; - int vc1rev; - int zbuffer; - int depth; - int monitor; - - struct grtwo_softc *dc_sc; - struct wsscreen_descr dc_wsd; -}; - -int grtwo_match(struct device *, void *, void *); -void grtwo_attach(struct device *, struct device *, void *); - -struct cfdriver grtwo_cd = { - NULL, "grtwo", DV_DULL -}; - -const struct cfattach grtwo_ca = { - sizeof(struct grtwo_softc), grtwo_match, grtwo_attach -}; - -/* accessops */ -int grtwo_ioctl(void *, u_long, caddr_t, int, struct proc *); -paddr_t grtwo_mmap(void *, off_t, int); -int grtwo_alloc_screen(void *, const struct wsscreen_descr *, void **, - int *, int *, uint32_t *); -void grtwo_free_screen(void *, void *); -int grtwo_show_screen(void *, void *, int, void (*)(void *, int, int), - void *); -int grtwo_load_font(void *, void *, struct wsdisplay_font *); -int grtwo_list_font(void *, struct wsdisplay_font *); -void grtwo_burner(void *, u_int, u_int); - -static struct wsdisplay_accessops grtwo_accessops = { - .ioctl = grtwo_ioctl, - .mmap = grtwo_mmap, - .alloc_screen = grtwo_alloc_screen, - .free_screen = grtwo_free_screen, - .show_screen = grtwo_show_screen, - .load_font = grtwo_load_font, - .list_font = grtwo_list_font, - .burn_screen = grtwo_burner -}; - -int grtwo_cursor(void *, int, int, int); -int grtwo_putchar(void *, int, int, u_int, uint32_t); -int grtwo_copycols(void *, int, int, int, int); -int grtwo_erasecols(void *, int, int, int, uint32_t); -int grtwo_copyrows(void *, int, int, int); -int grtwo_eraserows(void *, int, int, uint32_t); - -void grtwo_wait_gfifo(struct grtwo_devconfig *); -static __inline__ -void grtwo_set_color(bus_space_tag_t, bus_space_handle_t, int); -void grtwo_fillrect(struct grtwo_devconfig *, int, int, int, int, int); -void grtwo_copyrect(struct grtwo_devconfig *, int, int, int, int, int, int); -int grtwo_setup_hw(struct grtwo_devconfig *); -static __inline__ -int grtwo_attach_common(struct grtwo_devconfig *, struct gio_attach_args *); -int grtwo_init_screen(struct grtwo_devconfig *, int); -int grtwo_putchar_internal(struct rasops_info *, int, int, u_int, int, int, - int); - -static struct grtwo_devconfig grtwo_console_dc; -/* console backing store, worst cast font selection */ -static struct wsdisplay_charcell - grtwo_console_bs[(GRTWO_WIDTH / 8) * (GRTWO_HEIGHT / 16)]; - -void -grtwo_wait_gfifo(struct grtwo_devconfig *dc) -{ - int i; - - /* - * This loop is for paranoia. Of course there is currently no - * known way to whack the FIFO (or reset the board) in case it - * gets stuck... but this code is careful to avoid this situation - * and it should never happen (famous last words) - */ - for (i = 100000; i != 0; i--) { - if (!int2_is_intr_pending(INT2_L0_FIFO)) - break; - delay(1); - } -#ifdef DIAGNOSTIC - if (i == 0) { - if (dc != &grtwo_console_dc && dc->dc_sc != NULL) - printf("%s: FIFO is stuck\n", - dc->dc_sc->sc_dev.dv_xname); - } -#endif -} - -static __inline__ void -grtwo_set_color(bus_space_tag_t iot, bus_space_handle_t ioh, int color) -{ - bus_space_write_4(iot, ioh, GR2_FIFO_COLOR, color); -} - -/* - * Rectangle fill with the given background. - */ -void -grtwo_fillrect(struct grtwo_devconfig *dc, int x1, int y1, int x2, - int y2, int bg) -{ - grtwo_wait_gfifo(dc); - grtwo_set_color(dc->iot, dc->ioh, bg); - - grtwo_wait_gfifo(dc); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_RECTI2D, x1); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, - GRTWO_HEIGHT - 1 - y1); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, x2); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, - GRTWO_HEIGHT - 1 - y2); -} - -/* - * Rectangle copy. - * Does not handle overlapping copies; this is handled at the wsdisplay - * emulops level by splitting overlapping copies in smaller, non-overlapping, - * operations. - */ -void -grtwo_copyrect(struct grtwo_devconfig *dc, int x1, int y1, int x2, - int y2, int width, int height) -{ - int length = (width + 3) >> 2; - int lines = 4864 / length; - int step; - - y1 += height; y2 += height; - while (height != 0) { - step = imin(height, lines); - y1 -= step; y2 -= step; - - grtwo_wait_gfifo(dc); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_RECTCOPY, length); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, lines); - /* source */ - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, x1); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, y1); - /* span */ - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, width); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, step); - /* dest */ - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, x2); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, y2); - - height -= step; - } -} - -int -grtwo_setup_hw(struct grtwo_devconfig *dc) -{ - int i = 0; - uint8_t rd0, rd1, rd2, rd3; - uint32_t vc1; - - rd0 = bus_space_read_1(dc->iot, dc->ioh, GR2_REVISION_RD0); - rd1 = bus_space_read_1(dc->iot, dc->ioh, GR2_REVISION_RD1); - rd2 = bus_space_read_1(dc->iot, dc->ioh, GR2_REVISION_RD2); - rd3 = bus_space_read_1(dc->iot, dc->ioh, GR2_REVISION_RD3); - - /* Get various revisions */ - dc->boardrev = ~rd0 & GR2_REVISION_RD0_VERSION_MASK; - - /* - * Boards prior to rev 4 have a pretty whacky config scheme. - * What is doubly weird is that i have a rev 2 board, but the rev 4 - * probe routines work just fine. - * We'll trust SGI, though, and separate things a bit. It's only - * critical for the display depth calculation. - */ - - if (dc->boardrev < 4) { - dc->backendrev = ~(rd2 & GR2_REVISION_RD2_BACKEND_REV) >> - GR2_REVISION_RD2_BACKEND_SHIFT; - if (dc->backendrev == 0) - return ENXIO; - dc->zbuffer = ~rd1 & GR2_REVISION_RD1_ZBUFFER; - if ((rd3 & GR2_REVISION_RD3_VMA) != GR2_REVISION_RD3_VMA) - i++; - if ((rd3 & GR2_REVISION_RD3_VMB) != GR2_REVISION_RD3_VMB) - i++; - if ((rd3 & GR2_REVISION_RD3_VMC) != GR2_REVISION_RD3_VMC) - i++; - dc->depth = 8 * i; - dc->monitor = ((rd2 & 0x03) << 1) | (rd1 & 0x01); - } else { - dc->backendrev = ~rd1 & GR2_REVISION4_RD1_BACKEND; - if (dc->backendrev == 0) - return ENXIO; - dc->zbuffer = rd1 & GR2_REVISION4_RD1_ZBUFFER; - dc->depth = (rd1 & GR2_REVISION4_RD1_24BPP) ? 24 : 8; - dc->monitor = (rd0 & GR2_REVISION4_RD0_MONITOR_MASK) >> - GR2_REVISION4_RD0_MONITOR_SHIFT; - } - - dc->hq2rev = (bus_space_read_4(dc->iot, dc->ioh, HQ2_VERSION) & - HQ2_VERSION_MASK) >> HQ2_VERSION_SHIFT; - dc->ge7rev = (bus_space_read_4(dc->iot, dc->ioh, GE7_REVISION) & - GE7_REVISION_MASK) >> GE7_REVISION_SHIFT; - /* dc->vc1rev = vc1_read_ireg(dc, 5) & 0x07; */ - - vc1 = bus_space_read_4(dc->iot, dc->ioh, VC1_SYSCTL); - if (vc1 == -1) - return ENXIO; /* XXX would need a reset */ - - /* Turn on display, DID, disable cursor display */ - bus_space_write_4(dc->iot, dc->ioh, VC1_SYSCTL, - VC1_SYSCTL_VC1 | VC1_SYSCTL_DID); - - dc->xmapmode = bus_space_read_4(dc->iot, dc->ioh, - XMAP5_BASEALL + XMAP5_MODE); - - /* - * Setup Bt457 RAMDACs - */ - /* enable all planes */ - bus_space_write_1(dc->iot, dc->ioh, BT457_R + BT457_ADDR, BT_RMR); - bus_space_write_1(dc->iot, dc->ioh, BT457_R + BT457_CTRL, 0xff); - bus_space_write_1(dc->iot, dc->ioh, BT457_G + BT457_ADDR, BT_RMR); - bus_space_write_1(dc->iot, dc->ioh, BT457_G + BT457_CTRL, 0xff); - bus_space_write_1(dc->iot, dc->ioh, BT457_B + BT457_ADDR, BT_RMR); - bus_space_write_1(dc->iot, dc->ioh, BT457_B + BT457_CTRL, 0xff); - /* setup a regular gamma ramp */ - bus_space_write_1(dc->iot, dc->ioh, BT457_R + BT457_ADDR, 0); - bus_space_write_1(dc->iot, dc->ioh, BT457_G + BT457_ADDR, 0); - bus_space_write_1(dc->iot, dc->ioh, BT457_B + BT457_ADDR, 0); - for (i = 0; i < 256; i++) { - bus_space_write_1(dc->iot, dc->ioh, BT457_R + BT457_CMAPDATA, - i); - bus_space_write_1(dc->iot, dc->ioh, BT457_G + BT457_CMAPDATA, - i); - bus_space_write_1(dc->iot, dc->ioh, BT457_B + BT457_CMAPDATA, - i); - } - - /* - * Setup Bt479 RAMDAC - */ - grtwo_wait_gfifo(dc); - bus_space_write_1(dc->iot, dc->ioh, XMAP5_BASEALL + XMAP5_ADDRHI, - GR2_CMAP8 >> 8); - bus_space_write_1(dc->iot, dc->ioh, XMAP5_BASEALL + XMAP5_ADDRLO, - GR2_CMAP8 & 0xff); - bus_space_write_multi_1(dc->iot, dc->ioh, XMAP5_BASEALL + XMAP5_CLUT, - rasops_cmap, sizeof(rasops_cmap)); - - return 0; -} - -/* Attach routines */ -int -grtwo_match(struct device *parent, void *vcf, void *aux) -{ - struct gio_attach_args *ga = aux; - - if (ga->ga_product != GIO_PRODUCT_FAKEID_GRTWO) - return 0; - - return 1; -} - -void -grtwo_attach(struct device *parent, struct device *self, void *aux) -{ - struct grtwo_softc *sc = (struct grtwo_softc *)self; - struct gio_attach_args *ga = aux; - struct grtwo_devconfig *dc; - struct wsemuldisplaydev_attach_args waa; - const char *descr; - extern struct consdev wsdisplay_cons; - - descr = ga->ga_descr; - if (descr == NULL || *descr == '\0') - descr = "GR2"; - printf(": %s", descr); - - if (cn_tab == &wsdisplay_cons && - ga->ga_addr == grtwo_console_dc.dc_addr) { - waa.console = 1; - dc = &grtwo_console_dc; - sc->sc_nscreens = 1; - } else { - /* - * XXX The driver will not work correctly if we are not the - * XXX console device. An initialization is missing - it - * XXX seems that everything works, but the colormap is - * XXX stuck as black, which makes the device unusable. - */ - printf("\n%s: device has not been setup by firmware!\n", - self->dv_xname); - return; -#if 0 - waa.console = 0; - dc = malloc(sizeof(struct grtwo_devconfig), - M_DEVBUF, M_WAITOK | M_CANFAIL | M_ZERO); - if (dc == NULL) - goto out; - if (grtwo_attach_common(dc, ga) != 0) { - printf("\n%s: not responding\n", self->dv_xname); - free(dc, M_DEVBUF, sizeof *dc); - return; - } - if (grtwo_init_screen(dc, M_WAITOK | M_CANFAIL) != 0) { - free(dc, M_DEVBUF, sizeof *dc); - goto out; - } -#endif - } - sc->sc_dc = dc; - dc->dc_sc = sc; - - printf(", revision %d, monitor sense %d\n", dc->boardrev, dc->monitor); - printf("%s: %dx%d, %dbpp\n", - self->dv_xname, GRTWO_WIDTH, GRTWO_HEIGHT, dc->depth); - - sc->sc_scrlist[0] = &dc->dc_wsd; - sc->sc_wsl.nscreens = 1; - sc->sc_wsl.screens = sc->sc_scrlist; - - waa.scrdata = &sc->sc_wsl; - waa.accessops = &grtwo_accessops; - waa.accesscookie = dc; - waa.defaultscreens = 0; - - config_found(self, &waa, wsemuldisplaydevprint); - return; - -#if 0 -out: - printf("\n%s: failed to allocate memory\n", self->dv_xname); - return; -#endif -} - -int -grtwo_cnprobe(struct gio_attach_args *ga) -{ - return grtwo_match(NULL, NULL, ga); -} - -int -grtwo_cnattach(struct gio_attach_args *ga) -{ - struct rasops_info *ri = &grtwo_console_dc.dc_ri; - struct wsdisplay_charcell *cell; - uint32_t defattr; - int rc; - int i; - - rc = grtwo_attach_common(&grtwo_console_dc, ga); - if (rc != 0) - return rc; - grtwo_console_dc.dc_bs = grtwo_console_bs; - rc = grtwo_init_screen(&grtwo_console_dc, M_NOWAIT); - if (rc != 0) - return rc; - - ri->ri_ops.pack_attr(ri, 0, 0, 0, &defattr); - cell = grtwo_console_bs; - for (i = ri->ri_cols * ri->ri_rows; i != 0; i--, cell++) - cell->attr = defattr; - - wsdisplay_cnattach(&grtwo_console_dc.dc_wsd, ri, 0, 0, defattr); - - return 0; -} - -static __inline__ int -grtwo_attach_common(struct grtwo_devconfig *dc, struct gio_attach_args * ga) -{ - dc->dc_addr = ga->ga_addr; - dc->iot = ga->ga_iot; - dc->ioh = ga->ga_ioh; - - return grtwo_setup_hw(dc); -} - -int -grtwo_init_screen(struct grtwo_devconfig *dc, int malloc_flags) -{ - struct rasops_info *ri = &dc->dc_ri; - - memset(ri, 0, sizeof(struct rasops_info)); - ri->ri_hw = dc; - ri->ri_flg = RI_CENTER | RI_FULLCLEAR; - /* for the proper operation of rasops computations, pretend 8bpp */ - ri->ri_depth = 8; - ri->ri_stride = GRTWO_WIDTH; - ri->ri_width = GRTWO_WIDTH; - ri->ri_height = GRTWO_HEIGHT; - rasops_init(ri, 160, 160); - - /* - * Allocate backing store to remember character cells, to - * be able to paint an inverted cursor. - */ - if (dc->dc_bs == NULL) { - dc->dc_bs = mallocarray(ri->ri_rows, ri->ri_cols * - sizeof(struct wsdisplay_charcell), M_DEVBUF, - malloc_flags | M_ZERO); - if (dc->dc_bs == NULL) - return ENOMEM; - } - - ri->ri_ops.cursor = grtwo_cursor; - ri->ri_ops.copyrows = grtwo_copyrows; - ri->ri_ops.eraserows = grtwo_eraserows; - ri->ri_ops.copycols = grtwo_copycols; - ri->ri_ops.erasecols = grtwo_erasecols; - ri->ri_ops.putchar = grtwo_putchar; - - strlcpy(dc->dc_wsd.name, "std", sizeof(dc->dc_wsd.name)); - dc->dc_wsd.ncols = ri->ri_cols; - dc->dc_wsd.nrows = ri->ri_rows; - dc->dc_wsd.textops = &ri->ri_ops; - dc->dc_wsd.fontwidth = ri->ri_font->fontwidth; - dc->dc_wsd.fontheight = ri->ri_font->fontheight; - dc->dc_wsd.capabilities = ri->ri_caps; - - grtwo_fillrect(dc, 0, 0, GRTWO_WIDTH - 1, GRTWO_HEIGHT - 1, - ri->ri_devcmap[WSCOL_BLACK]); - - return 0; -} - -/* wsdisplay textops */ - -int -grtwo_cursor(void *c, int on, int row, int col) -{ - struct rasops_info *ri = c; - struct grtwo_devconfig *dc = ri->ri_hw; - struct wsdisplay_charcell *cell; - int bg, fg, ul; - - cell = dc->dc_bs + row * ri->ri_cols + col; - ri->ri_ops.unpack_attr(ri, cell->attr, &fg, &bg, &ul); - - if (on) { - /* redraw the existing character with inverted colors */ - return grtwo_putchar_internal(ri, row, col, cell->uc, - ~ri->ri_devcmap[fg], ~ri->ri_devcmap[bg], ul); - } else { - /* redraw the existing character with correct colors */ - return grtwo_putchar_internal(ri, row, col, cell->uc, - ri->ri_devcmap[fg], ri->ri_devcmap[bg], ul); - } -} - -int -grtwo_putchar(void *c, int row, int col, u_int ch, uint32_t attr) -{ - struct rasops_info *ri = c; - struct grtwo_devconfig *dc = ri->ri_hw; - struct wsdisplay_charcell *cell; - int bg, fg, ul; - - /* Update backing store. */ - cell = dc->dc_bs + row * ri->ri_cols + col; - cell->uc = ch; - cell->attr = attr; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, &ul); - return grtwo_putchar_internal(ri, row, col, ch, ri->ri_devcmap[fg], - ri->ri_devcmap[bg], ul); -} - -int -grtwo_putchar_internal(struct rasops_info *ri, int row, int col, u_int ch, - int fg, int bg, int ul) -{ - struct grtwo_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - uint8_t *bitmap; - uint32_t pattern; - int x, y; - int h = font->fontheight; - int w = font->fontwidth; - int i; - - /* - * The `draw char' operation below writes on top of the existing - * background. We need to paint the background first. - */ - x = ri->ri_xorigin + col * w; - y = ri->ri_yorigin + row * h; - grtwo_fillrect(dc, x, y, x + w - 1, y + h - 1, bg); - - if ((ch == ' ' || ch == 0) && ul == 0) - return 0; - - /* Set the drawing color */ - grtwo_wait_gfifo(dc); - grtwo_set_color(dc->iot, dc->ioh, fg); - - /* - * This character drawing operation apparently expects a 18 pixel - * character cell height. We will perform as many cell fillings as - * necessary to draw a complete glyph. - */ - bitmap = (uint8_t *)font->data + - (ch - font->firstchar + 1) * ri->ri_fontscale; - y = ri->ri_height - h - y; - while (h != 0) { - /* Set drawing coordinates */ - grtwo_wait_gfifo(dc); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_CMOV2I, x); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, y); - - grtwo_wait_gfifo(dc); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DRAWCHAR, w); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, - h > GR2_DRAWCHAR_HEIGHT ? GR2_DRAWCHAR_HEIGHT : h); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, 2); - /* (x,y) offset */ - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, 0); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, 0); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, 0); - bus_space_write_4(dc->iot, dc->ioh, GR2_FIFO_DATA, 0); - - grtwo_wait_gfifo(dc); - if (w <= 8) { - for (i = 0; i < GR2_DRAWCHAR_HEIGHT; i++) { - if (h != 0) { - bitmap -= font->stride; - if (ul && h == font->fontheight - 1) - pattern = 0xff << 8; - else - pattern = *bitmap << 8; - h--; - } else - pattern = 0; - - bus_space_write_4(dc->iot, dc->ioh, - GR2_FIFO_DATA, pattern); - } - } else { - for (i = 0; i < GR2_DRAWCHAR_HEIGHT; i++) { - if (h != 0) { - bitmap -= font->stride; - if (ul && h == font->fontheight - 1) - pattern = 0xffff; - else - pattern = *(uint16_t *)bitmap; - h--; - } else - pattern = 0; - - bus_space_write_4(dc->iot, dc->ioh, - GR2_FIFO_DATA, pattern); - } - } - - y += GR2_DRAWCHAR_HEIGHT; - } - - return 0; -} - -int -grtwo_copycols(void *c, int row, int src, int dst, int ncol) -{ - struct rasops_info *ri = c; - struct grtwo_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - struct wsdisplay_charcell *cell; - int y = ri->ri_yorigin + row * font->fontheight; - int delta, chunk; - - /* Copy columns in backing store. */ - cell = dc->dc_bs + row * ri->ri_cols; - memmove(cell + dst, cell + src, ncol * sizeof(*cell)); - - if (src > dst) { - /* may overlap, copy in non-overlapping blocks */ - delta = src - dst; - while (ncol > 0) { - chunk = ncol <= delta ? ncol : delta; - grtwo_copyrect(dc, - ri->ri_xorigin + src * font->fontwidth, y, - ri->ri_xorigin + dst * font->fontwidth, y, - chunk * font->fontwidth, font->fontheight); - src += chunk; - dst += chunk; - ncol -= chunk; - } - } else { - grtwo_copyrect(dc, - ri->ri_xorigin + src * font->fontwidth, y, - ri->ri_xorigin + dst * font->fontwidth, y, - ncol * font->fontwidth, font->fontheight); - } - - return 0; -} - -int -grtwo_erasecols(void *c, int row, int startcol, int ncol, uint32_t attr) -{ - struct rasops_info *ri = c; - struct grtwo_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - struct wsdisplay_charcell *cell; - int y = ri->ri_yorigin + row * font->fontheight; - int i, bg, fg; - - /* Erase columns in backing store. */ - cell = dc->dc_bs + row * ri->ri_cols + startcol; - for (i = ncol; i != 0; i--, cell++) { - cell->uc = 0; - cell->attr = attr; - } - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, NULL); - - grtwo_fillrect(dc, ri->ri_xorigin + startcol * font->fontwidth, y, - ri->ri_xorigin + (startcol + ncol) * font->fontwidth - 1, - y + font->fontheight - 1, ri->ri_devcmap[bg]); - - return 0; -} - -int -grtwo_copyrows(void *c, int src, int dst, int nrow) -{ - struct rasops_info *ri = c; - struct grtwo_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - struct wsdisplay_charcell *cell; - int delta, chunk; - - /* Copy rows in backing store. */ - cell = dc->dc_bs + dst * ri->ri_cols; - memmove(cell, dc->dc_bs + src * ri->ri_cols, - nrow * ri->ri_cols * sizeof(*cell)); - - if (src > dst) { - /* may overlap, copy in non-overlapping blocks */ - delta = src - dst; - while (nrow > 0) { - chunk = nrow <= delta ? nrow : delta; - grtwo_copyrect(dc, ri->ri_xorigin, - ri->ri_yorigin + src * font->fontheight, - ri->ri_xorigin, - ri->ri_yorigin + dst * font->fontheight, - ri->ri_emuwidth, chunk * font->fontheight); - src += chunk; - dst += chunk; - nrow -= chunk; - } - } else { - grtwo_copyrect(dc, ri->ri_xorigin, - ri->ri_yorigin + src * font->fontheight, ri->ri_xorigin, - ri->ri_yorigin + dst * font->fontheight, ri->ri_emuwidth, - nrow * font->fontheight); - } - - return 0; -} - -int -grtwo_eraserows(void *c, int startrow, int nrow, uint32_t attr) -{ - struct rasops_info *ri = c; - struct grtwo_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - struct wsdisplay_charcell *cell; - int i, bg, fg; - - /* Erase rows in backing store. */ - cell = dc->dc_bs + startrow * ri->ri_cols; - for (i = ri->ri_cols; i != 0; i--, cell++) { - cell->uc = 0; - cell->attr = attr; - } - for (i = 1; i < nrow; i++) - memmove(dc->dc_bs + (startrow + i) * ri->ri_cols, - dc->dc_bs + startrow * ri->ri_cols, - ri->ri_cols * sizeof(*cell)); - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, NULL); - - if (nrow == ri->ri_rows && (ri->ri_flg & RI_FULLCLEAR)) { - grtwo_fillrect(dc, 0, 0, GRTWO_WIDTH - 1, GRTWO_HEIGHT - 1, - ri->ri_devcmap[bg]); - return 0; - } - - grtwo_fillrect(dc, ri->ri_xorigin, - ri->ri_yorigin + startrow * font->fontheight, - ri->ri_xorigin + ri->ri_emuwidth - 1, - ri->ri_yorigin + (startrow + nrow) * font->fontheight - 1, - ri->ri_devcmap[bg]); - - return 0; -} - -/* wsdisplay accessops */ - -int -grtwo_alloc_screen(void *v, const struct wsscreen_descr * type, void **cookiep, - int *curxp, int *curyp, uint32_t *attrp) -{ - struct grtwo_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - struct grtwo_softc *sc = dc->dc_sc; - struct wsdisplay_charcell *cell; - int i; - - if (sc->sc_nscreens > 0) - return ENOMEM; - - sc->sc_nscreens++; - - *cookiep = ri; - *curxp = *curyp = 0; - ri->ri_ops.pack_attr(ri, 0, 0, 0, &dc->dc_defattr); - *attrp = dc->dc_defattr; - - cell = dc->dc_bs; - for (i = ri->ri_cols * ri->ri_rows; i != 0; i--, cell++) - cell->attr = dc->dc_defattr; - - return 0; -} - -void -grtwo_free_screen(void *v, void *cookie) -{ -} - -int -grtwo_show_screen(void *v, void *cookie, int waitok, - void (*cb) (void *, int, int), void *cbarg) -{ - return 0; -} - -int -grtwo_ioctl(void *v, u_long cmd, caddr_t data, int flag, struct proc *p) -{ - struct grtwo_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - struct wsdisplay_fbinfo *fb; - - switch (cmd) { - case WSDISPLAYIO_GTYPE: - *(u_int *) data = WSDISPLAY_TYPE_GRTWO; - break; - case WSDISPLAYIO_GINFO: - fb = (struct wsdisplay_fbinfo *)data; - fb->width = ri->ri_width; - fb->height = ri->ri_height; - fb->depth = dc->depth; /* real depth */ - if (dc->depth > 8) - fb->cmsize = 0; - else - fb->cmsize = 1 << dc->depth; - break; - default: - return -1; - } - - return 0; -} - -paddr_t -grtwo_mmap(void *v, off_t offset, int prot) -{ - /* no directly accessible frame buffer memory */ - return -1; -} - -int -grtwo_load_font(void *v, void *emulcookie, struct wsdisplay_font *font) -{ - struct grtwo_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - - return rasops_load_font(ri, emulcookie, font); -} - -int -grtwo_list_font(void *v, struct wsdisplay_font *font) -{ - struct grtwo_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - - return rasops_list_font(ri, font); -} - -void -grtwo_burner(void *v, u_int on, u_int flags) -{ - struct grtwo_devconfig *dc = v; - - on = on ? 0xff : 0x00; - - bus_space_write_1(dc->iot, dc->ioh, BT457_R + BT457_ADDR, BT_RMR); - bus_space_write_1(dc->iot, dc->ioh, BT457_R + BT457_CTRL, on); - bus_space_write_1(dc->iot, dc->ioh, BT457_G + BT457_ADDR, BT_RMR); - bus_space_write_1(dc->iot, dc->ioh, BT457_G + BT457_CTRL, on); - bus_space_write_1(dc->iot, dc->ioh, BT457_B + BT457_ADDR, BT_RMR); - bus_space_write_1(dc->iot, dc->ioh, BT457_B + BT457_CTRL, on); -} diff --git a/sys/arch/sgi/gio/grtworeg.h b/sys/arch/sgi/gio/grtworeg.h deleted file mode 100644 index 8d67d2bdb85..00000000000 --- a/sys/arch/sgi/gio/grtworeg.h +++ /dev/null @@ -1,240 +0,0 @@ -/* $OpenBSD: grtworeg.h,v 1.3 2014/03/27 20:15:00 miod Exp $ */ -/* $NetBSD: grtworeg.h,v 1.2 2005/12/11 12:18:53 christos Exp $ */ - -/* - * Copyright (c) 2004 Christopher SEKIYA - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -/* - * Memory map: - * - * 0x1f000000 - 0x1f01ffff Shared data RAM - * 0x1f020000 - 0x1f03ffff (unused) - * 0x1f040000 - 0x1f05ffff FIFO - * 0x1f060000 - 0x1f068000 HQ2 ucode - * 0x1f068000 - 0x1f069fff GE7 (eight of them) - * 0x1f06a000 - 0x1f06b004 HQ2 - * 0x1f06c000 Board revision register - * 0x1f06c020 clock - * 0x1f06c040 VC1 - * 0x1f06c060 BT479 Triple-DAC (read) - * 0x1f06c080 BT479 Triple-DAC (write) - * 0x1f06c0a0 BT457 DAC (red) - * 0x1f06c0c0 BT457 DAC (green) - * 0x1f06c0e0 BT457 DAC (blue) - * 0x1f06c100 XMAP5 (five of them) - * 0x1f06c1a0 XMAP5 ("xmap all") - * 0x1f06c1c0 Kaleidoscope (AB1) - * 0x1f06c1e0 Kaleidoscope (CC1) - * 0x1f06c200 RE3 (27-bit registers) - * 0x1f06c280 RE3 (24-bit registers) - * 0x1f06c600 RE3 (32-bit registers) - */ - -#define GR2_FIFO 0x40000 -#define GR2_FIFO_INIT (GR2_FIFO + 0x644) -#define GR2_FIFO_COLOR (GR2_FIFO + 0x648) -#define GR2_FIFO_FINISH (GR2_FIFO + 0x64c) -#define GR2_FIFO_PNT2I (GR2_FIFO + 0x650) -#define GR2_FIFO_RECTI2D (GR2_FIFO + 0x654) -#define GR2_FIFO_CMOV2I (GR2_FIFO + 0x658) -#define GR2_FIFO_LINE2I (GR2_FIFO + 0x65c) -#define GR2_FIFO_DRAWCHAR (GR2_FIFO + 0x660) -#define GR2_FIFO_RECTCOPY (GR2_FIFO + 0x664) -#define GR2_FIFO_DATA (GR2_FIFO + 0x77c) - -/* HQ2 */ - -#define HQ2_BASE 0x6a000 -#define HQ2_ATTRJUMP (HQ2_BASE + 0x00) -#define HQ2_VERSION (HQ2_BASE + 0x40) -#define HQ2_VERSION_MASK 0xff000000 -#define HQ2_VERSION_SHIFT 23 - -#define HQ2_NUMGE (HQ2_BASE + 0x44) -#define HQ2_FIN1 (HQ2_BASE + 0x48) -#define HQ2_FIN2 (HQ2_BASE + 0x4c) -#define HQ2_DMASYNC (HQ2_BASE + 0x50) -#define HQ2_FIFO_FULL_TIMEOUT (HQ2_BASE + 0x54) -#define HQ2_FIFO_EMPTY_TIMEOUT (HQ2_BASE + 0x58) -#define HQ2_FIFO_FULL (HQ2_BASE + 0x5c) -#define HQ2_FIFO_EMPTY (HQ2_BASE + 0x60) -#define HQ2_GE7_LOAD_UCODE (HQ2_BASE + 0x64) -#define HQ2_GEDMA (HQ2_BASE + 0x68) -#define HQ2_HQ_GEPC (HQ2_BASE + 0x6c) -#define HQ2_GEPC (HQ2_BASE + 0x70) -#define HQ2_INTR (HQ2_BASE + 0x74) -#define HQ2_UNSTALL (HQ2_BASE + 0x78) -#define HQ2_MYSTERY (HQ2_BASE + 0x7c) -#define HQ2_MYSTERY_VALUE 0xdeadbeef -#define HQ2_REFRESH (HQ2_BASE + 0x80) -#define HQ2_FIN3 (HQ2_BASE + 0x1000) - -/* GE7 */ - -#define GE7_REVISION 0x680fc -#define GE7_REVISION_MASK 0xe0 -#define GE7_REVISION_SHIFT 5 - -/* VC1 */ - -#define VC1_BASE 0x6c040 -#define VC1_COMMAND (VC1_BASE + 0x00) -#define VC1_XMAPMODE (VC1_BASE + 0x04) -#define VC1_SRAM (VC1_BASE + 0x08) -#define VC1_TESTREG (VC1_BASE + 0x0c) -#define VC1_ADDRLO (VC1_BASE + 0x10) -#define VC1_ADDRHI (VC1_BASE + 0x14) -#define VC1_SYSCTL (VC1_BASE + 0x18) - -/* VC1 System Control Register */ -#define VC1_SYSCTL_INTERRUPT 0x01 /* active low */ -#define VC1_SYSCTL_VTG 0x02 /* active low */ -#define VC1_SYSCTL_VC1 0x04 -#define VC1_SYSCTL_DID 0x08 -#define VC1_SYSCTL_CURSOR 0x10 -#define VC1_SYSCTL_CURSOR_DISPLAY 0x20 -#define VC1_SYSCTL_GENSYNC 0x40 -#define VC1_SYSCTL_VIDEO 0x80 - -/* VC1 SRAM memory map */ -#define VC1_SRAM_VIDTIM_LST_BASE 0x0000 -#define VC1_SRAM_VIDTIM_CURSLST_BASE 0x0400 -#define VC1_SRAM_VIDTIM_FRMT_BASE 0x0800 -#define VC1_SRAM_VIDTIM_CURSFRMT_BASE 0x0900 -#define VC1_SRAM_INTERLACED 0x09f0 -#define VC1_SRAM_SCREENWIDTH 0x09f2 -#define VC1_SRAM_NEXTDID_ADDR 0x09f4 -#define VC1_SRAM_CURSOR0_BASE 0x0a00 /* 32x32 */ -#define VC1_SRAM_DID_FRMT_BASE 0x0b00 -#define VC1_SRAM_DID_MAX_FMTSIZE 0x0900 -#define VC1_SRAM_DID_LST_END 0x8000 - -/* VC1 registers */ -#define VC1_VIDEO_EP 0x00 -#define VC1_VIDEO_LC 0x02 -#define VC1_VIDEO_SC 0x04 -#define VC1_VIDEO_TSA 0x06 -#define VC1_VIDEO_TSB 0x07 -#define VC1_VIDEO_TSC 0x08 -#define VC1_VIDEO_LP 0x09 -#define VC1_VIDEO_LS_EP 0x0b -#define VC1_VIDEO_LR 0x0d -#define VC1_VIDEO_FC 0x10 -#define VC1_VIDEO_ENABLE 0x14 - -/* Cursor Generator */ -#define VC1_CURSOR_EP 0x20 -#define VC1_CURSOR_XL 0x22 -#define VC1_CURSOR_YL 0x24 -#define VC1_CURSOR_MODE 0x26 -#define VC1_CURSOR_BX 0x27 -#define VC1_CURSOR_LY 0x28 -#define VC1_CURSOR_YC 0x2a -#define VC1_CURSOR_CC 0x2e -#define VC1_CURSOR_RC 0x30 - -/* Board revision register */ - -#define GR2_REVISION 0x6c000 -#define GR2_REVISION_RD0 0x6c000 -#define GR2_REVISION_RD0_VERSION_MASK 0x0f -#define GR2_REVISION4_RD0_MONITOR_MASK 0xf0 -#define GR2_REVISION4_RD0_MONITOR_SHIFT 4 - -#define GR2_REVISION_RD1 0x6c004 -#define GR2_REVISION_RD1_BACKEND_REV 0x03 -#define GR2_REVISION_RD1_ZBUFFER 0x0c - -#define GR2_REVISION4_RD1_BACKEND 0x03 -#define GR2_REVISION4_RD1_24BPP 0x10 -#define GR2_REVISION4_RD1_ZBUFFER 0x20 - -#define GR2_REVISION_RD2 0x6c008 -#define GR2_REVISION_RD2_BACKEND_REV 0x0c -#define GR2_REVISION_RD2_BACKEND_SHIFT 2 - -/* one slot = 8bpp, two slots = 16bpp, three slots = 24bpp, br < 4 only */ -#define GR2_REVISION_RD3 0x6c00c -#define GR2_REVISION_RD3_VMA 0x03 /* both bits set == empty - * slot */ -#define GR2_REVISION_RD3_VMB 0x0c -#define GR2_REVISION_RD3_VMC 0x30 - -/* Bt479 */ - -#define BT479_R 0x6c060 -#define BT479_W 0x6c080 - -#define BT479_WRADDR 0x00 -#define BT479_CMAPDATA 0x04 -#define BT479_MASK 0x08 /* pixel read mask */ -#define BT479_RDADDR 0x0c -#define BT479_OVWRADDR 0x10 -#define BT479_OVDATA 0x14 -#define BT479_CTL 0x18 -#define BT479_OVRDADDR 0x1c - -#define GR2_CMAP12 0x0000 -#define GR2_CMAP8 0x1000 -#define GR2_CMAP4 0x1400 - -/* Bt457 */ - -#define BT457_R 0x6c0a0 -#define BT457_G 0x6c0c0 -#define BT457_B 0x6c0e0 - -#define BT457_ADDR 0x00 -#define BT457_CMAPDATA 0x04 -#define BT457_CTRL 0x08 -#define BT457_OVDATA 0x0c - -/* XMAP5 */ - -#define XMAP5_BASE0 0x6c100 -#define XMAP5_BASE1 0x6c120 -#define XMAP5_BASE2 0x6c140 -#define XMAP5_BASE3 0x6c160 -#define XMAP5_BASE4 0x6c180 -#define XMAP5_BASEALL 0x6c1a0 - -#define XMAP5_MISC 0x00 -#define XMAP5_MODE 0x04 -#define XMAP5_CLUT 0x08 -#define XMAP5_CRC 0x0c -#define XMAP5_ADDRLO 0x10 -#define XMAP5_ADDRHI 0x14 -#define XMAP5_BYTECOUNT 0x18 -#define XMAP5_FIFOSTATUS 0x1c - -/* - * FIFO operation constraints. - */ - -#define GR2_DRAWCHAR_HEIGHT 18 diff --git a/sys/arch/sgi/gio/grtwovar.h b/sys/arch/sgi/gio/grtwovar.h deleted file mode 100644 index 0adddb44bb6..00000000000 --- a/sys/arch/sgi/gio/grtwovar.h +++ /dev/null @@ -1,34 +0,0 @@ -/* $OpenBSD: grtwovar.h,v 1.1 2012/04/18 11:01:55 miod Exp $ */ -/* $NetBSD: grtwovar.h,v 1.3 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2004 Christopher SEKIYA - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -int grtwo_cnattach(struct gio_attach_args *); -int grtwo_cnprobe(struct gio_attach_args *); diff --git a/sys/arch/sgi/gio/impact_gio.c b/sys/arch/sgi/gio/impact_gio.c deleted file mode 100644 index e964cef2ad7..00000000000 --- a/sys/arch/sgi/gio/impact_gio.c +++ /dev/null @@ -1,136 +0,0 @@ -/* $OpenBSD: impact_gio.c,v 1.7 2017/09/08 05:36:52 deraadt Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Driver for the SGI Impact graphics board (GIO attachment). - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> - -#include <machine/autoconf.h> - -#include <mips64/arcbios.h> - -#include <sgi/dev/impactreg.h> -#include <sgi/dev/impactvar.h> -#include <sgi/gio/giodevs.h> -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giovar.h> -#include <sgi/sgi/ip22.h> - -#include <dev/cons.h> - -#define IMPACT_REG_OFFSET 0x00000000 -#define IMPACT_REG_SIZE 0x00080000 - -int impact_gio_match(struct device *, void *, void *); -void impact_gio_attach(struct device *, struct device *, void *); - -const struct cfattach impact_gio_ca = { - sizeof(struct impact_softc), impact_gio_match, impact_gio_attach -}; - -int -impact_gio_match(struct device *parent, void *match, void *aux) -{ - struct gio_attach_args *ga = aux; - - if (GIO_PRODUCT_32BIT_ID(ga->ga_product) && - GIO_PRODUCT_PRODUCTID(ga->ga_product) == GIO_PRODUCT_IMPACT) - return 1; - - return 0; -} - -void -impact_gio_attach(struct device *parent, struct device *self, void *aux) -{ - struct gio_attach_args *ga = aux; - struct impact_softc *sc = (struct impact_softc *)self; - bus_space_tag_t iot; - bus_space_handle_t ioh; - int console; - extern struct consdev wsdisplay_cons; - - if (ga->ga_descr != NULL && *ga->ga_descr != '\0') - printf(": %s", ga->ga_descr); - - if (strncmp(bios_graphics, "alive", 5) != 0) { - printf("\n%s: device has not been setup by firmware!\n", - self->dv_xname); - return; - } - - printf("\n"); - - console = cn_tab == &wsdisplay_cons && giofb_consaddr == ga->ga_addr; - - if (console != 0) { - iot = NULL; - ioh = 0; - } else { - iot = ga->ga_iot; - - /* Setup bus space mappings. */ - if (bus_space_map(iot, ga->ga_addr + IMPACT_REG_OFFSET, - IMPACT_REG_SIZE, 0, &ioh)) { - printf("failed to map registers\n"); - return; - } - } - - if (impact_attach_common(sc, iot, ioh, console, 0) != 0) { - if (console == 0) - bus_space_unmap(iot, ioh, IMPACT_REG_SIZE); - } -} - -/* - * Console support. - */ - -int -impact_gio_cnprobe(struct gio_attach_args *ga) -{ - return impact_gio_match(NULL, NULL, ga); -} - -int -impact_gio_cnattach(struct gio_attach_args *ga) -{ - bus_space_tag_t iot; - bus_space_handle_t ioh; - int rc; - - iot = ga->ga_iot; - rc = bus_space_map(iot, ga->ga_addr + IMPACT_REG_OFFSET, - IMPACT_REG_SIZE, 0, &ioh); - if (rc != 0) - return rc; - - rc = impact_cnattach_common(iot, ioh, 0); - if (rc != 0) { - bus_space_unmap(iot, ioh, IMPACT_REG_SIZE); - return rc; - } - - return 0; -} diff --git a/sys/arch/sgi/gio/light.c b/sys/arch/sgi/gio/light.c deleted file mode 100644 index ad7289f343d..00000000000 --- a/sys/arch/sgi/gio/light.c +++ /dev/null @@ -1,793 +0,0 @@ -/* $OpenBSD: light.c,v 1.10 2020/05/25 09:55:48 jsg Exp $ */ -/* $NetBSD: light.c,v 1.5 2007/03/04 06:00:39 christos Exp $ */ - -/* - * Copyright (c) 2012, 2014 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2006 Stephen M. Rumble - * Copyright (c) 2003 Ilpo Ruotsalainen - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -/* - * SGI "Light" graphics, a.k.a. "Entry", "Starter", "LG1", and "LG2". - * - * 1024x768 8bpp at 60Hz. - * - * This driver supports the boards found in Indigo R3k and R4k machines. - * There is a Crimson variant, but the register offsets differ significantly. - * - * Light's REX chip is the precursor of the REX3 found in "newport", hence - * much similarity exists. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <machine/autoconf.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsdisplayvar.h> -#include <dev/rasops/rasops.h> - -#include <sgi/dev/gl.h> -#include <sgi/gio/giovar.h> -#include <sgi/gio/lightvar.h> -#include <sgi/gio/lightreg.h> - -#include <dev/cons.h> - -struct light_softc { - struct device sc_dev; - - struct light_devconfig *sc_dc; - - int sc_nscreens; - struct wsscreen_list sc_wsl; - const struct wsscreen_descr *sc_scrlist[1]; -}; - -struct light_devconfig { - struct rasops_info dc_ri; - uint32_t dc_defattr; - - uint32_t dc_addr; - bus_space_tag_t dc_st; - bus_space_handle_t dc_sh; - - int dc_boardrev; - - struct light_softc *dc_sc; - struct wsscreen_descr dc_wsd; - - uint8_t dc_cmap[256 * 3]; -}; - -/* always 1024x768x8 */ -#define LIGHT_XRES 1024 -#define LIGHT_YRES 768 -#define LIGHT_DEPTH 8 - -int light_match(struct device *, void *, void *); -void light_attach(struct device *, struct device *, void *); - -struct cfdriver light_cd = { - NULL, "light", DV_DULL -}; - -const struct cfattach light_ca = { - sizeof(struct light_softc), light_match, light_attach -}; - -/* wsdisplay_accessops */ -int light_ioctl(void *, u_long, caddr_t, int, struct proc *); -paddr_t light_mmap(void *, off_t, int); -int light_alloc_screen(void *, const struct wsscreen_descr *, void **, - int *, int *, uint32_t *); -void light_free_screen(void *, void *); -int light_show_screen(void *, void *, int, void (*)(void *, int, int), - void *); -int light_load_font(void *, void *, struct wsdisplay_font *); -int light_list_font(void *, struct wsdisplay_font *); -void light_burner(void *, u_int, u_int); - -struct wsdisplay_accessops light_accessops = { - .ioctl = light_ioctl, - .mmap = light_mmap, - .alloc_screen = light_alloc_screen, - .free_screen = light_free_screen, - .show_screen = light_show_screen, - .load_font = light_load_font, - .list_font = light_list_font, - .burn_screen = light_burner -}; - -int light_do_cursor(struct rasops_info *); -int light_putchar(void *, int, int, u_int, uint32_t); -int light_copycols(void *, int, int, int, int); -int light_erasecols(void *, int, int, int, uint32_t); -int light_copyrows(void *, int, int, int); -int light_eraserows(void *, int, int, uint32_t); - -static __inline__ -uint32_t rex_read(struct light_devconfig *, uint32_t, uint32_t); -static __inline__ -void rex_write(struct light_devconfig *, uint32_t, uint32_t, uint32_t); -uint8_t rex_vc1_sysctl_read(struct light_devconfig *); -void rex_vc1_sysctl_write(struct light_devconfig *, uint8_t); -static __inline__ -void rex_wait(struct light_devconfig *); -static __inline__ -int rex_revision(struct light_devconfig *); -void rex_copy_rect(struct light_devconfig *, int, int, int, int, int, int, - int); -void rex_fill_rect(struct light_devconfig *, int, int, int, int, int); - -int light_getcmap(struct light_devconfig *, struct wsdisplay_cmap *); -void light_loadcmap(struct light_devconfig *, int, int); -int light_putcmap(struct light_devconfig *, struct wsdisplay_cmap *); - -void light_attach_common(struct light_devconfig *, struct gio_attach_args *); -void light_init_screen(struct light_devconfig *); - -static struct light_devconfig light_console_dc; - -#define LIGHT_IS_LG1(_rev) ((_rev) < 2) /* else LG2 */ - -/* - * REX routines and helper functions. - */ - -static __inline__ -uint32_t -rex_read(struct light_devconfig *dc, uint32_t rset, uint32_t r) -{ - return bus_space_read_4(dc->dc_st, dc->dc_sh, rset + r); -} - -static __inline__ -void -rex_write(struct light_devconfig *dc, uint32_t rset, uint32_t r, uint32_t v) -{ - bus_space_write_4(dc->dc_st, dc->dc_sh, rset + r, v); -} - -uint8_t -rex_vc1_sysctl_read(struct light_devconfig *dc) -{ - rex_write(dc, REX_PAGE1_GO, REX_P1REG_CFGSEL, REX_CFGSEL_VC1_SYSCTL); - - rex_read(dc, REX_PAGE1_GO, REX_P1REG_VC1_ADDRDATA); - return rex_read(dc, REX_PAGE1_SET, REX_P1REG_VC1_ADDRDATA); -} - -void -rex_vc1_sysctl_write(struct light_devconfig *dc, uint8_t val) -{ - rex_write(dc, REX_PAGE1_GO, REX_P1REG_CFGSEL, REX_CFGSEL_VC1_SYSCTL); - - rex_write(dc, REX_PAGE1_SET, REX_P1REG_VC1_ADDRDATA, val); - rex_write(dc, REX_PAGE1_GO, REX_P1REG_VC1_ADDRDATA, val); -} - -static __inline__ -void -rex_wait(struct light_devconfig *dc) -{ - while (rex_read(dc, REX_PAGE1_SET,REX_P1REG_CFGMODE) & REX_CFGMODE_BUSY) - continue; -} - -static __inline__ -int -rex_revision(struct light_devconfig *dc) -{ - rex_write(dc, REX_PAGE1_SET, REX_P1REG_CFGSEL, REX_CFGSEL_VC1_LADDR); - rex_read(dc, REX_PAGE1_GO, REX_P1REG_WCLOCKREV); - return rex_read(dc, REX_PAGE1_SET, REX_P1REG_WCLOCKREV) & 0x7; -} - -void -rex_copy_rect(struct light_devconfig *dc, int from_x, int from_y, int to_x, - int to_y, int width, int height, int rop) -{ - int dx, dy, ystarti, yendi; - - dx = from_x - to_x; - dy = from_y - to_y; - - if (to_y > from_y) { - ystarti = to_y + height - 1; - yendi = to_y; - } else { - ystarti = to_y; - yendi = to_y + height - 1; - } - - rex_wait(dc); - - rex_write(dc, REX_PAGE0_SET, REX_P0REG_XSTARTI, to_x); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_XENDI, to_x + width - 1); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_YSTARTI, ystarti); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_YENDI, yendi); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_COMMAND, REX_OP_DRAW | - REX_OP_FLG_LOGICSRC | REX_OP_FLG_QUADMODE | - REX_OP_FLG_BLOCK | REX_OP_FLG_STOPONX | REX_OP_FLG_STOPONY | - (rop << REX_LOGICOP_SHIFT)); - rex_write(dc, REX_PAGE0_GO, REX_P0REG_XYMOVE, - ((dx << 16) & 0xffff0000) | (dy & 0x0000ffff)); -} - -void -rex_fill_rect(struct light_devconfig *dc, int from_x, int from_y, int to_x, - int to_y, int bg) -{ - struct rasops_info *ri = &dc->dc_ri; - - rex_wait(dc); - - rex_write(dc, REX_PAGE0_SET, REX_P0REG_YSTARTI, from_y); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_YENDI, to_y - 1); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_XSTARTI, from_x); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_XENDI, to_x - 1); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_COLORREDI, - ri->ri_devcmap[bg] & 0xff); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_COMMAND, REX_OP_DRAW | - REX_OP_FLG_QUADMODE | REX_OP_FLG_BLOCK | - REX_OP_FLG_STOPONX | REX_OP_FLG_STOPONY | - (OPENGL_LOGIC_OP_COPY << REX_LOGICOP_SHIFT)); - rex_read(dc, REX_PAGE0_GO, REX_P0REG_COMMAND); -} - -/* - * Colormap routines - */ - -int -light_getcmap(struct light_devconfig *dc, struct wsdisplay_cmap *cm) -{ - u_int index = cm->index, count = cm->count, i; - u_int colcount = 1 << dc->dc_ri.ri_depth; - int rc; - u_int8_t color[256], *c, *r; - - if (index >= colcount || count > colcount - index) - return EINVAL; - - c = dc->dc_cmap + 0 + index * 3; - for (i = count, r = color; i != 0; i--) { - *r++ = *c; - c += 3; - } - if ((rc = copyout(color, cm->red, count)) != 0) - return rc; - - c = dc->dc_cmap + 1 + index * 3; - for (i = count, r = color; i != 0; i--) { - *r++ = *c; - c += 3; - } - if ((rc = copyout(color, cm->green, count)) != 0) - return rc; - - c = dc->dc_cmap + 2 + index * 3; - for (i = count, r = color; i != 0; i--) { - *r++ = *c; - c += 3; - } - if ((rc = copyout(color, cm->blue, count)) != 0) - return rc; - - return 0; -} - -int -light_putcmap(struct light_devconfig *dc, struct wsdisplay_cmap *cm) -{ - u_int index = cm->index, count = cm->count; - u_int colcount = 1 << dc->dc_ri.ri_depth; - int i, rc; - u_int8_t r[256], g[256], b[256], *nr, *ng, *nb, *c; - - if (index >= colcount || count > colcount - index) - return EINVAL; - - if ((rc = copyin(cm->red, r, count)) != 0) - return rc; - if ((rc = copyin(cm->green, g, count)) != 0) - return rc; - if ((rc = copyin(cm->blue, b, count)) != 0) - return rc; - - nr = r, ng = g, nb = b; - c = dc->dc_cmap + index * 3; - for (i = count; i != 0; i--) { - *c++ = *nr++; - *c++ = *ng++; - *c++ = *nb++; - } - - return 0; -} - -void -light_loadcmap(struct light_devconfig *dc, int from, int count) -{ - u_int8_t *cmap = dc->dc_cmap; - - /* XXX should wait for retrace first */ - - cmap += 3 * from; - rex_write(dc, REX_PAGE1_GO, REX_P1REG_CFGSEL, REX_CFGSEL_DAC_WADDR); - rex_write(dc, REX_PAGE1_SET, REX_P1REG_DAC_ADDRDATA, from); - rex_write(dc, REX_PAGE1_GO, REX_P1REG_DAC_ADDRDATA, from); - - rex_write(dc, REX_PAGE1_GO, REX_P1REG_CFGSEL, REX_CFGSEL_DAC_CMAP); - while (count-- > 0) { - rex_write(dc, REX_PAGE1_GO, REX_P1REG_DAC_ADDRDATA, *cmap); - rex_write(dc, REX_PAGE1_SET, REX_P1REG_DAC_ADDRDATA, *cmap++); - rex_write(dc, REX_PAGE1_GO, REX_P1REG_DAC_ADDRDATA, *cmap); - rex_write(dc, REX_PAGE1_SET, REX_P1REG_DAC_ADDRDATA, *cmap++); - rex_write(dc, REX_PAGE1_GO, REX_P1REG_DAC_ADDRDATA, *cmap); - rex_write(dc, REX_PAGE1_SET, REX_P1REG_DAC_ADDRDATA, *cmap++); - } -} - -/* - * Autoconf and console glue - */ - -int -light_match(struct device *parent, void *vcf, void *aux) -{ - struct gio_attach_args *ga = aux; - - if (ga->ga_product != GIO_PRODUCT_FAKEID_LIGHT) - return 0; - - return 1; -} - -void -light_attach(struct device *parent, struct device *self, void *aux) -{ - struct light_softc *sc = (struct light_softc *)self; - struct gio_attach_args *ga = aux; - struct light_devconfig *dc; - struct wsemuldisplaydev_attach_args waa; - extern struct consdev wsdisplay_cons; - - if (cn_tab == &wsdisplay_cons && - ga->ga_addr == light_console_dc.dc_addr) { - waa.console = 1; - dc = &light_console_dc; - sc->sc_nscreens = 1; - } else { - waa.console = 0; - dc = malloc(sizeof(struct light_devconfig), M_DEVBUF, - M_WAITOK | M_ZERO); - light_attach_common(dc, ga); - light_init_screen(dc); - } - sc->sc_dc = dc; - dc->dc_sc = sc; - - if (ga->ga_descr != NULL && *ga->ga_descr != '\0') - printf(": %s", ga->ga_descr); - else - printf(": LG%dMC\n", - LIGHT_IS_LG1(sc->sc_dc->dc_boardrev) ? 1 : 2); - printf(", revision %d\n", dc->dc_boardrev); - printf("%s: %dx%d, %dbpp\n", self->dv_xname, - dc->dc_ri.ri_width, dc->dc_ri.ri_height, dc->dc_ri.ri_depth); - - sc->sc_scrlist[0] = &dc->dc_wsd; - sc->sc_wsl.nscreens = 1; - sc->sc_wsl.screens = sc->sc_scrlist; - - waa.scrdata = &sc->sc_wsl; - waa.accessops = &light_accessops; - waa.accesscookie = dc; - waa.defaultscreens = 0; - - config_found(self, &waa, wsemuldisplaydevprint); -} - -int -light_cnprobe(struct gio_attach_args *ga) -{ - return light_match(NULL, NULL, ga); -} - -int -light_cnattach(struct gio_attach_args *ga) -{ - struct rasops_info *ri = &light_console_dc.dc_ri; - uint32_t defattr; - - light_attach_common(&light_console_dc, ga); - light_init_screen(&light_console_dc); - - ri->ri_ops.pack_attr(ri, 0, 0, 0, &defattr); - wsdisplay_cnattach(&light_console_dc.dc_wsd, ri, 0, 0, defattr); - - return 0; -} - -void -light_attach_common(struct light_devconfig *dc, struct gio_attach_args *ga) -{ - dc->dc_addr = ga->ga_addr; - dc->dc_st = ga->ga_iot; - dc->dc_sh = ga->ga_ioh; - - dc->dc_boardrev = rex_revision(dc); - - rex_vc1_sysctl_write(dc, rex_vc1_sysctl_read(dc) & - ~(VC1_SYSCTL_CURSOR | VC1_SYSCTL_CURSOR_ON)); -} - -void -light_init_screen(struct light_devconfig *dc) -{ - struct rasops_info *ri = &dc->dc_ri; - - memset(ri, 0, sizeof(struct rasops_info)); - ri->ri_hw = dc; - ri->ri_flg = RI_CENTER | RI_FULLCLEAR; - /* for the proper operation of rasops computations, pretend 8bpp */ - ri->ri_depth = 8; - ri->ri_stride = LIGHT_XRES; - ri->ri_width = LIGHT_XRES; - ri->ri_height = LIGHT_YRES; - - rasops_init(ri, 160, 160); - - ri->ri_do_cursor = light_do_cursor; - ri->ri_ops.copyrows = light_copyrows; - ri->ri_ops.eraserows = light_eraserows; - ri->ri_ops.copycols = light_copycols; - ri->ri_ops.erasecols = light_erasecols; - ri->ri_ops.putchar = light_putchar; - - strlcpy(dc->dc_wsd.name, "std", sizeof(dc->dc_wsd.name)); - dc->dc_wsd.ncols = ri->ri_cols; - dc->dc_wsd.nrows = ri->ri_rows; - dc->dc_wsd.textops = &ri->ri_ops; - dc->dc_wsd.fontwidth = ri->ri_font->fontwidth; - dc->dc_wsd.fontheight = ri->ri_font->fontheight; - dc->dc_wsd.capabilities = ri->ri_caps; - - memcpy(dc->dc_cmap, rasops_cmap, sizeof(dc->dc_cmap)); - light_loadcmap(dc, 0, 1 << ri->ri_depth); - - rex_fill_rect(dc, 0, 0, ri->ri_width, ri->ri_height, WSCOL_BLACK); -} - -/* - * wsdisplay_emulops - */ - -int -light_do_cursor(struct rasops_info *ri) -{ - struct light_devconfig *dc = ri->ri_hw; - int x, y, w, h; - - w = ri->ri_font->fontwidth; - h = ri->ri_font->fontheight; - x = ri->ri_ccol * w + ri->ri_xorigin; - y = ri->ri_crow * h + ri->ri_yorigin; - - rex_copy_rect(dc, x, y, x, y, w, h, OPENGL_LOGIC_OP_COPY_INVERTED); - - return 0; -} - -int -light_putchar(void *c, int row, int col, u_int ch, uint32_t attr) -{ - struct rasops_info *ri = c; - struct light_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - uint8_t *bitmap; - uint32_t pattern; - int x = col * font->fontwidth + ri->ri_xorigin; - int y = row * font->fontheight + ri->ri_yorigin; - int i; - int bg, fg, ul; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, &ul); - - if ((ch == ' ' || ch == 0) && ul == 0) { - rex_fill_rect(dc, x, y, x + font->fontwidth, - y + font->fontheight, bg); - return 0; - } - - rex_wait(dc); - - rex_write(dc, REX_PAGE0_SET, REX_P0REG_YSTARTI, y); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_YENDI, y + font->fontheight - 1); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_XSTARTI, x); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_XENDI, x + font->fontwidth - 1); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_COLORREDI, - ri->ri_devcmap[fg] & 0xff); - rex_write(dc, REX_PAGE0_SET, REX_P0REG_COLORBACK, - ri->ri_devcmap[bg] & 0xff); - rex_write(dc, REX_PAGE0_GO, REX_P0REG_COMMAND, REX_OP_NOP); - - rex_wait(dc); - - rex_write(dc, REX_PAGE0_SET, REX_P0REG_COMMAND, REX_OP_DRAW | - REX_OP_FLG_ENZPATTERN | REX_OP_FLG_QUADMODE | - REX_OP_FLG_XYCONTINUE | REX_OP_FLG_STOPONX | REX_OP_FLG_BLOCK | - REX_OP_FLG_LENGTH32 | REX_OP_FLG_ZOPAQUE | - (OPENGL_LOGIC_OP_COPY << REX_LOGICOP_SHIFT)); - - bitmap = (uint8_t *)font->data + - (ch - font->firstchar) * ri->ri_fontscale; - if (font->fontwidth <= 8) { - for (i = font->fontheight; i != 0; i--) { - if (ul && i == 1) - pattern = 0xff; - else - pattern = *bitmap; - rex_write(dc, REX_PAGE0_GO, REX_P0REG_ZPATTERN, - pattern << 24); - bitmap += font->stride; - } - } else { - for (i = font->fontheight; i != 0; i--) { - if (ul && i == 1) - pattern = 0xffff; - else - pattern = *(uint16_t *)bitmap; - rex_write(dc, REX_PAGE0_GO, REX_P0REG_ZPATTERN, - pattern << 16); - bitmap += font->stride; - } - } - - return 0; -} - -/* copy set of columns within the same line */ -int -light_copycols(void *c, int row, int srccol, int dstcol, int ncols) -{ - struct rasops_info *ri = c; - struct light_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int from_x, to_x, y, width, height; - - from_x = ri->ri_xorigin + srccol * font->fontwidth; - to_x = ri->ri_xorigin + dstcol * font->fontwidth; - y = ri->ri_yorigin + row * font->fontheight; - width = ncols * font->fontwidth; - height = font->fontheight; - - rex_copy_rect(dc, from_x, y, to_x, y, width, height, - OPENGL_LOGIC_OP_COPY); - - return 0; -} - -/* erase a set of columns in the same line */ -int -light_erasecols(void *c, int row, int startcol, int ncols, uint32_t attr) -{ - struct rasops_info *ri = c; - struct light_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int from_x, from_y, to_x, to_y; - int bg, fg; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, NULL); - - from_x = ri->ri_xorigin + startcol * font->fontwidth; - from_y = ri->ri_yorigin + row * font->fontheight; - to_x = from_x + ncols * font->fontwidth; - to_y = from_y + font->fontheight; - - rex_fill_rect(dc, from_x, from_y, to_x, to_y, bg); - - return 0; -} - -/* copy a set of complete rows */ -int -light_copyrows(void *c, int srcrow, int dstrow, int nrows) -{ - struct rasops_info *ri = c; - struct light_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int x, from_y, to_y, width, height; - - x = ri->ri_xorigin; - from_y = ri->ri_yorigin + srcrow * font->fontheight; - to_y = ri->ri_yorigin + dstrow * font->fontheight; - width = ri->ri_emuwidth; - height = nrows * font->fontheight; - - rex_copy_rect(dc, x, from_y, x, to_y, width, height, - OPENGL_LOGIC_OP_COPY); - - return 0; -} - -/* erase a set of complete rows */ -int -light_eraserows(void *c, int row, int nrows, uint32_t attr) -{ - struct rasops_info *ri = c; - struct light_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int bg, fg; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, NULL); - - if (nrows == ri->ri_rows && (ri->ri_flg & RI_FULLCLEAR)) { - rex_fill_rect(dc, 0, 0, ri->ri_width, ri->ri_height, bg); - return 0; - } - - rex_fill_rect(dc, ri->ri_xorigin, - ri->ri_yorigin + row * font->fontheight, - ri->ri_xorigin + ri->ri_emuwidth, - ri->ri_yorigin + (row + nrows) * font->fontheight, bg); - - return 0; -} - -/* - * wsdisplay_accessops - */ - -int -light_ioctl(void *v, u_long cmd, caddr_t data, int flag, struct proc *p) -{ - struct light_devconfig *dc = v; - struct wsdisplay_fbinfo *fb; - struct wsdisplay_cmap *cm; - int rc; - - switch (cmd) { - case WSDISPLAYIO_GTYPE: - *(u_int *)data = WSDISPLAY_TYPE_LIGHT; - break; - case WSDISPLAYIO_GINFO: - fb = (struct wsdisplay_fbinfo *)data; - fb->width = dc->dc_ri.ri_width; - fb->height = dc->dc_ri.ri_height; - fb->depth = dc->dc_ri.ri_depth; - fb->cmsize = 1 << fb->depth; - break; - case WSDISPLAYIO_GETCMAP: - cm = (struct wsdisplay_cmap *)data; - rc = light_getcmap(dc, cm); - if (rc != 0) - return rc; - break; - case WSDISPLAYIO_PUTCMAP: - cm = (struct wsdisplay_cmap *)data; - rc = light_putcmap(dc, cm); - if (rc != 0) - return rc; - light_loadcmap(dc, cm->index, cm->count); - break; - default: - return -1; - } - - return 0; -} - -paddr_t -light_mmap(void *v, off_t off, int prot) -{ - return -1; -} - -int -light_alloc_screen(void *v, const struct wsscreen_descr *type, void **cookiep, - int *curxp, int *curyp, uint32_t *attrp) -{ - struct light_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - struct light_softc *sc = dc->dc_sc; - - if (sc->sc_nscreens > 0) - return ENOMEM; - - sc->sc_nscreens++; - - *cookiep = ri; - *curxp = *curyp = 0; - ri->ri_ops.pack_attr(ri, 0, 0, 0, &dc->dc_defattr); - *attrp = dc->dc_defattr; - - return 0; -} - -void -light_free_screen(void *v, void *cookie) -{ -} - -int -light_show_screen(void *v, void *cookie, int waitok, - void (*cb)(void *, int, int), void *cbarg) -{ - return 0; -} - -int -light_load_font(void *v, void *emulcookie, struct wsdisplay_font *font) -{ - struct light_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - - return rasops_load_font(ri, emulcookie, font); -} - -int -light_list_font(void *v, struct wsdisplay_font *font) -{ - struct light_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - - return rasops_list_font(ri, font); -} - -void -light_burner(void *v, u_int on, u_int flags) -{ - struct light_devconfig *dc = v; - - if (on) - rex_vc1_sysctl_write(dc, rex_vc1_sysctl_read(dc) | - VC1_SYSCTL_VIDEO_ON); - else - rex_vc1_sysctl_write(dc, rex_vc1_sysctl_read(dc) & - ~VC1_SYSCTL_VIDEO_ON); -} diff --git a/sys/arch/sgi/gio/lightreg.h b/sys/arch/sgi/gio/lightreg.h deleted file mode 100644 index 17576b62a67..00000000000 --- a/sys/arch/sgi/gio/lightreg.h +++ /dev/null @@ -1,96 +0,0 @@ -/* $OpenBSD: lightreg.h,v 1.2 2014/03/18 23:23:09 miod Exp $ */ -/* $NetBSD: lightreg.h,v 1.3 2006/12/29 00:31:48 rumble Exp $ */ - -/* - * Copyright (c) 2006 Stephen M. Rumble - * 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. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -#define LIGHT_ADDR_0 0x1f3f0000 -#define LIGHT_ADDR_1 0x1f3f8000 /* dual head */ -#define LIGHT_SIZE 0x00008000 - -#define REX_PAGE0_SET 0x00000000 /* REX registers */ -#define REX_PAGE0_GO 0x00000800 -#define REX_PAGE1_SET 0x00004790 /* configuration registers */ -#define REX_PAGE1_GO 0x00004F90 - -/* REX register offsets (from REX_PAGE0_{SET,GO}) */ -#define REX_P0REG_COMMAND 0x00000000 -#define REX_P0REG_XSTARTI 0x0000000C -#define REX_P0REG_YSTARTI 0x0000001C -#define REX_P0REG_XYMOVE 0x00000034 -#define REX_P0REG_COLORREDI 0x00000038 -#define REX_P0REG_COLORGREENI 0x00000040 -#define REX_P0REG_COLORBLUEI 0x00000048 -#define REX_P0REG_COLORBACK 0x0000005C -#define REX_P0REG_ZPATTERN 0x00000060 -#define REX_P0REG_XENDI 0x00000084 -#define REX_P0REG_YENDI 0x00000088 - -/* configuration register offsets (from REX_PAGE1_{SET,GO}) */ -#define REX_P1REG_WCLOCKREV 0x00000054 /* nsclock / revision */ -#define REX_P1REG_DAC_ADDRDATA 0x00000058 /* DAC r/w addr and data 8bit */ -#define REX_P1REG_CFGSEL 0x0000005c /* function selector */ -#define REX_P1REG_VC1_ADDRDATA 0x00000060 /* vc1 r/w addr and data 8bit */ -#define REX_P1REG_CFGMODE 0x00000068 /* REX system config */ -#define REX_P1REG_XYOFFSET 0x0000006c /* x, y start of screen */ - -/* REX opcodes */ -#define REX_OP_NOP 0x00000000 -#define REX_OP_DRAW 0x00000001 - -/* REX command flags */ -#define REX_OP_FLG_BLOCK 0x00000008 -#define REX_OP_FLG_LENGTH32 0x00000010 -#define REX_OP_FLG_QUADMODE 0x00000020 -#define REX_OP_FLG_XYCONTINUE 0x00000080 -#define REX_OP_FLG_STOPONX 0x00000100 -#define REX_OP_FLG_STOPONY 0x00000200 -#define REX_OP_FLG_ENZPATTERN 0x00000400 -#define REX_OP_FLG_LOGICSRC 0x00080000 -#define REX_OP_FLG_ZOPAQUE 0x00800000 -#define REX_OP_FLG_ZCONTINUE 0x01000000 - -/* REX logicops */ -#define REX_LOGICOP_SHIFT 28 - -/* configmode bits */ -#define REX_CFGMODE_BUSY 0x00000001 - -/* configsel bits */ -#define REX_CFGSEL_VC1_LADDR 0x00000004 /* low address bits */ -#define REX_CFGSEL_VC1_HADDR 0x00000005 /* high address bits */ -#define REX_CFGSEL_VC1_SYSCTL 0x00000006 -#define REX_CFGSEL_DAC_WADDR 0x00000000 /* write address */ -#define REX_CFGSEL_DAC_CMAP 0x00000001 /* colormap data */ -#define REX_CFGSEL_DAC_PMASK 0x00000002 /* pixel read mask */ -#define REX_CFGSEL_DAC_RADDR 0x00000003 /* read address */ -#define REX_CFGSEL_DAC_OVWADDR 0x00000004 /* overlay write address */ -#define REX_CFGSEL_DAC_OV 0x00000005 /* overlay registers */ -#define REX_CFGSEL_DAC_CTL 0x00000006 /* control registers */ -#define REX_CFGSEL_DAC_OVRADDR 0x00000007 /* overlay read address */ - -/* vc1 sysctl bits (byte) */ -#define VC1_SYSCTL_VIDEO_ON 0x04 -#define VC1_SYSCTL_CURSOR 0x10 -#define VC1_SYSCTL_CURSOR_ON 0x20 diff --git a/sys/arch/sgi/gio/lightvar.h b/sys/arch/sgi/gio/lightvar.h deleted file mode 100644 index fefd59ca7db..00000000000 --- a/sys/arch/sgi/gio/lightvar.h +++ /dev/null @@ -1,29 +0,0 @@ -/* $OpenBSD: lightvar.h,v 1.1 2012/04/17 15:36:55 miod Exp $ */ -/* $NetBSD: lightvar.h,v 1.2 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2006 Stephen M. Rumble - * 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. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -int light_cnattach(struct gio_attach_args *); -int light_cnprobe(struct gio_attach_args *); diff --git a/sys/arch/sgi/gio/newport.c b/sys/arch/sgi/gio/newport.c deleted file mode 100644 index bb0416ad59b..00000000000 --- a/sys/arch/sgi/gio/newport.c +++ /dev/null @@ -1,911 +0,0 @@ -/* $OpenBSD: newport.c,v 1.13 2020/05/25 09:55:48 jsg Exp $ */ -/* $NetBSD: newport.c,v 1.15 2009/05/12 23:51:25 macallan Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2003 Ilpo Ruotsalainen - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <machine/autoconf.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsdisplayvar.h> -#include <dev/rasops/rasops.h> - -#include <sgi/dev/gl.h> -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giovar.h> -#include <sgi/gio/newportreg.h> -#include <sgi/gio/newportvar.h> - -#include <dev/cons.h> - -struct newport_softc { - struct device sc_dev; - - struct newport_devconfig *sc_dc; - - int sc_nscreens; - struct wsscreen_list sc_wsl; - const struct wsscreen_descr *sc_scrlist[1]; -}; - -struct newport_devconfig { - struct rasops_info dc_ri; - uint32_t dc_defattr; - - uint32_t dc_addr; - bus_space_tag_t dc_st; - bus_space_handle_t dc_sh; - - int dc_xres; - int dc_yres; - int dc_depth; - -#ifdef notyet - int dc_mode; -#endif - - int dc_boardrev; - int dc_vc2rev; - int dc_xmaprev; - - struct newport_softc *dc_sc; - struct wsscreen_descr dc_wsd; -}; - -int newport_match(struct device *, void *, void *); -void newport_attach(struct device *, struct device *, void *); - -struct cfdriver newport_cd = { - NULL, "newport", DV_DULL -}; - -const struct cfattach newport_ca = { - sizeof(struct newport_softc), newport_match, newport_attach -}; - -/* accessops */ -int newport_ioctl(void *, u_long, caddr_t, int, struct proc *); -paddr_t newport_mmap(void *, off_t, int); -int newport_alloc_screen(void *, const struct wsscreen_descr *, void **, - int *, int *, uint32_t *); -void newport_free_screen(void *, void *); -int newport_show_screen(void *, void *, int, void (*)(void *, int, int), - void *); -int newport_load_font(void *, void *, struct wsdisplay_font *); -int newport_list_font(void *, struct wsdisplay_font *); - -struct wsdisplay_accessops newport_accessops = { - .ioctl = newport_ioctl, - .mmap = newport_mmap, - .alloc_screen = newport_alloc_screen, - .free_screen = newport_free_screen, - .show_screen = newport_show_screen, - .load_font = newport_load_font, - .list_font = newport_list_font -}; - -int newport_do_cursor(struct rasops_info *); -int newport_putchar(void *, int, int, u_int, uint32_t); -int newport_copycols(void *, int, int, int, int); -int newport_erasecols(void *, int, int, int, uint32_t); -int newport_copyrows(void *, int, int, int); -int newport_eraserows(void *, int, int, uint32_t); - -static __inline__ -void rex3_write(struct newport_devconfig *, bus_size_t, uint32_t); -static __inline__ -void rex3_write_go(struct newport_devconfig *, bus_size_t, uint32_t); -static __inline__ -uint32_t rex3_read(struct newport_devconfig *, bus_size_t); -int rex3_wait_gfifo(struct newport_devconfig *, const char *); - -void vc2_write_ireg(struct newport_devconfig *, uint8_t, uint16_t); -uint16_t vc2_read_ireg(struct newport_devconfig *, uint8_t); -uint16_t vc2_read_ram(struct newport_devconfig *, uint16_t); -void vc2_write_ram(struct newport_devconfig *, uint16_t, uint16_t); -uint32_t xmap9_read(struct newport_devconfig *, int); -void xmap9_write(struct newport_devconfig *, int, uint8_t); -void xmap9_write_mode(struct newport_devconfig *, uint8_t, uint32_t); - -void newport_attach_common(struct newport_devconfig *, - struct gio_attach_args *); -int newport_bitblt(struct newport_devconfig *, int, int, int, int, int, int, - int); -void newport_cmap_setrgb(struct newport_devconfig *, int, uint8_t, uint8_t, - uint8_t); -int newport_fill_rectangle(struct newport_devconfig *, int, int, int, int, - int); -void newport_get_resolution(struct newport_devconfig *); -int newport_init_screen(struct newport_devconfig *); -void newport_setup_hw(struct newport_devconfig *); - -static struct newport_devconfig newport_console_dc; - -/**** Low-level hardware register groveling functions ****/ -static __inline__ void -rex3_write(struct newport_devconfig *dc, bus_size_t rexreg, uint32_t val) -{ - bus_space_write_4(dc->dc_st, dc->dc_sh, NEWPORT_REX3_OFFSET + rexreg, - val); -} - -static __inline__ void -rex3_write_go(struct newport_devconfig *dc, bus_size_t rexreg, uint32_t val) -{ - rex3_write(dc, rexreg + REX3_REG_GO, val); -} - -static __inline__ uint32_t -rex3_read(struct newport_devconfig *dc, bus_size_t rexreg) -{ - return bus_space_read_4(dc->dc_st, dc->dc_sh, NEWPORT_REX3_OFFSET + - rexreg); -} - -int -rex3_wait_gfifo(struct newport_devconfig *dc, const char *from) -{ - unsigned int iter; - uint32_t rxstatus; - - for (iter = 100000; iter != 0; iter--) { - rxstatus = rex3_read(dc, REX3_REG_STATUS); - if ((rxstatus & - (REX3_STATUS_GFXBUSY | REX3_STATUS_FIFOLEVEL_MASK)) == 0) - return 0; - } - -#ifdef DEBUG - printf("%s: failed to idle, %05x\n", from, rxstatus); -#endif - return EAGAIN; -} - -void -vc2_write_ireg(struct newport_devconfig *dc, uint8_t ireg, uint16_t val) -{ - rex3_write(dc, REX3_REG_DCBMODE, - REX3_DCBMODE_DW_3 | REX3_DCBMODE_ENCRSINC | - (NEWPORT_DCBADDR_VC2 << REX3_DCBMODE_DCBADDR_SHIFT) | - (VC2_DCBCRS_INDEX << REX3_DCBMODE_DCBCRS_SHIFT) | - REX3_DCBMODE_ENASYNCACK | (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - rex3_write(dc, REX3_REG_DCBDATA0, (ireg << 24) | (val << 8)); -} - -uint16_t -vc2_read_ireg(struct newport_devconfig *dc, uint8_t ireg) -{ - rex3_write(dc, REX3_REG_DCBMODE, - REX3_DCBMODE_DW_1 | REX3_DCBMODE_ENCRSINC | - (NEWPORT_DCBADDR_VC2 << REX3_DCBMODE_DCBADDR_SHIFT) | - (VC2_DCBCRS_INDEX << REX3_DCBMODE_DCBCRS_SHIFT) | - REX3_DCBMODE_ENASYNCACK | (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - rex3_write(dc, REX3_REG_DCBDATA0, ireg << 24); - - rex3_write(dc, REX3_REG_DCBMODE, - REX3_DCBMODE_DW_2 | REX3_DCBMODE_ENCRSINC | - (NEWPORT_DCBADDR_VC2 << REX3_DCBMODE_DCBADDR_SHIFT) | - (VC2_DCBCRS_IREG << REX3_DCBMODE_DCBCRS_SHIFT) | - REX3_DCBMODE_ENASYNCACK | (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - return (uint16_t)(rex3_read(dc, REX3_REG_DCBDATA0) >> 16); -} - -uint16_t -vc2_read_ram(struct newport_devconfig *dc, uint16_t addr) -{ - vc2_write_ireg(dc, VC2_IREG_RAM_ADDRESS, addr); - - rex3_write(dc, REX3_REG_DCBMODE, REX3_DCBMODE_DW_2 | - (NEWPORT_DCBADDR_VC2 << REX3_DCBMODE_DCBADDR_SHIFT) | - (VC2_DCBCRS_RAM << REX3_DCBMODE_DCBCRS_SHIFT) | - REX3_DCBMODE_ENASYNCACK | (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - return (uint16_t)(rex3_read(dc, REX3_REG_DCBDATA0) >> 16); -} - -#if 0 -void -vc2_write_ram(struct newport_devconfig *dc, uint16_t addr, uint16_t val) -{ - vc2_write_ireg(dc, VC2_IREG_RAM_ADDRESS, addr); - - rex3_write(dc, REX3_REG_DCBMODE, REX3_DCBMODE_DW_2 | - (NEWPORT_DCBADDR_VC2 << REX3_DCBMODE_DCBADDR_SHIFT) | - (VC2_DCBCRS_RAM << REX3_DCBMODE_DCBCRS_SHIFT) | - REX3_DCBMODE_ENASYNCACK | (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - rex3_write(dc, REX3_REG_DCBDATA0, val << 16); -} -#endif - -uint32_t -xmap9_read(struct newport_devconfig *dc, int crs) -{ - rex3_write(dc, REX3_REG_DCBMODE, REX3_DCBMODE_DW_1 | - (NEWPORT_DCBADDR_XMAP_0 << REX3_DCBMODE_DCBADDR_SHIFT) | - (crs << REX3_DCBMODE_DCBCRS_SHIFT) | - (3 << REX3_DCBMODE_CSWIDTH_SHIFT) | - (2 << REX3_DCBMODE_CSHOLD_SHIFT) | - (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - return rex3_read(dc, REX3_REG_DCBDATA0); -} - -void -xmap9_write(struct newport_devconfig *dc, int crs, uint8_t val) -{ - rex3_write(dc, REX3_REG_DCBMODE, REX3_DCBMODE_DW_1 | - (NEWPORT_DCBADDR_XMAP_BOTH << REX3_DCBMODE_DCBADDR_SHIFT) | - (crs << REX3_DCBMODE_DCBCRS_SHIFT) | - (3 << REX3_DCBMODE_CSWIDTH_SHIFT) | - (2 << REX3_DCBMODE_CSHOLD_SHIFT) | - (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - rex3_write(dc, REX3_REG_DCBDATA0, val << 24); -} - -void -xmap9_write_mode(struct newport_devconfig *dc, uint8_t index, uint32_t mode) -{ - rex3_write(dc, REX3_REG_DCBMODE, REX3_DCBMODE_DW_4 | - (NEWPORT_DCBADDR_XMAP_BOTH << REX3_DCBMODE_DCBADDR_SHIFT) | - (XMAP9_DCBCRS_MODE_SETUP << REX3_DCBMODE_DCBCRS_SHIFT) | - (3 << REX3_DCBMODE_CSWIDTH_SHIFT) | - (2 << REX3_DCBMODE_CSHOLD_SHIFT) | - (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - rex3_write(dc, REX3_REG_DCBDATA0, (index << 24) | mode); -} - -/**** Helper functions ****/ -int -newport_fill_rectangle(struct newport_devconfig *dc, int x1, int y1, int x2, - int y2, int bg) -{ - struct rasops_info *ri = &dc->dc_ri; - - if (rex3_wait_gfifo(dc, __func__) != 0) - return EAGAIN; - - rex3_write(dc, REX3_REG_DRAWMODE0, REX3_DRAWMODE0_OPCODE_DRAW | - REX3_DRAWMODE0_ADRMODE_BLOCK | REX3_DRAWMODE0_DOSETUP | - REX3_DRAWMODE0_STOPONX | REX3_DRAWMODE0_STOPONY); - rex3_write(dc, REX3_REG_DRAWMODE1, REX3_DRAWMODE1_PLANES_CI | - REX3_DRAWMODE1_DD_DD8 | REX3_DRAWMODE1_RWPACKED | - REX3_DRAWMODE1_HD_HD8 | REX3_DRAWMODE1_COMPARE_LT | - REX3_DRAWMODE1_COMPARE_EQ | REX3_DRAWMODE1_COMPARE_GT | - (OPENGL_LOGIC_OP_COPY << REX3_DRAWMODE1_LOGICOP_SHIFT)); - rex3_write(dc, REX3_REG_WRMASK, 0xffffffff); - rex3_write(dc, REX3_REG_COLORI, ri->ri_devcmap[bg] & 0xff); - rex3_write(dc, REX3_REG_XYSTARTI, (x1 << REX3_XYSTARTI_XSHIFT) | y1); - - rex3_write_go(dc, REX3_REG_XYENDI, (x2 << REX3_XYENDI_XSHIFT) | y2); - - return 0; -} - -int -newport_bitblt(struct newport_devconfig *dc, int xs, int ys, int xd, - int yd, int wi, int he, int rop) -{ - int xe, ye; - uint32_t tmp; - - if (rex3_wait_gfifo(dc, __func__) != 0) - return EAGAIN; - - if (yd > ys) { - /* need to copy bottom up */ - ye = ys; - yd += he - 1; - ys += he - 1; - } else - ye = ys + he - 1; - - if (xd > xs) { - /* need to copy right to left */ - xe = xs; - xd += wi - 1; - xs += wi - 1; - } else - xe = xs + wi - 1; - - rex3_write(dc, REX3_REG_DRAWMODE0, REX3_DRAWMODE0_OPCODE_SCR2SCR | - REX3_DRAWMODE0_ADRMODE_BLOCK | REX3_DRAWMODE0_DOSETUP | - REX3_DRAWMODE0_STOPONX | REX3_DRAWMODE0_STOPONY); - rex3_write(dc, REX3_REG_DRAWMODE1, REX3_DRAWMODE1_PLANES_CI | - REX3_DRAWMODE1_DD_DD8 | REX3_DRAWMODE1_RWPACKED | - REX3_DRAWMODE1_HD_HD8 | REX3_DRAWMODE1_COMPARE_LT | - REX3_DRAWMODE1_COMPARE_EQ | REX3_DRAWMODE1_COMPARE_GT | - (rop << REX3_DRAWMODE1_LOGICOP_SHIFT)); - rex3_write(dc, REX3_REG_XYSTARTI, (xs << REX3_XYSTARTI_XSHIFT) | ys); - rex3_write(dc, REX3_REG_XYENDI, (xe << REX3_XYENDI_XSHIFT) | ye); - - tmp = (yd - ys) & 0xffff; - tmp |= (xd - xs) << REX3_XYMOVE_XSHIFT; - - rex3_write_go(dc, REX3_REG_XYMOVE, tmp); - - return 0; -} - -void -newport_cmap_setrgb(struct newport_devconfig *dc, int index, uint8_t r, - uint8_t g, uint8_t b) -{ - rex3_write(dc, REX3_REG_DCBMODE, - REX3_DCBMODE_DW_2 | REX3_DCBMODE_ENCRSINC | - (NEWPORT_DCBADDR_CMAP_BOTH << REX3_DCBMODE_DCBADDR_SHIFT) | - (CMAP_DCBCRS_ADDRESS_LOW << REX3_DCBMODE_DCBCRS_SHIFT) | - (1 << REX3_DCBMODE_CSWIDTH_SHIFT) | - (1 << REX3_DCBMODE_CSHOLD_SHIFT) | - (1 << REX3_DCBMODE_CSSETUP_SHIFT) | REX3_DCBMODE_SWAPENDIAN); - - rex3_write(dc, REX3_REG_DCBDATA0, index << 16); - - rex3_write(dc, REX3_REG_DCBMODE, REX3_DCBMODE_DW_3 | - (NEWPORT_DCBADDR_CMAP_BOTH << REX3_DCBMODE_DCBADDR_SHIFT) | - (CMAP_DCBCRS_PALETTE << REX3_DCBMODE_DCBCRS_SHIFT) | - (1 << REX3_DCBMODE_CSWIDTH_SHIFT) | - (1 << REX3_DCBMODE_CSHOLD_SHIFT) | - (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - - rex3_write(dc, REX3_REG_DCBDATA0, (r << 24) | (g << 16) | (b << 8)); -} - -void -newport_get_resolution(struct newport_devconfig *dc) -{ - uint16_t vep, lines; - uint16_t linep, cols; - uint16_t data; - - vep = vc2_read_ireg(dc, VC2_IREG_VIDEO_ENTRY); - - dc->dc_xres = 0; - dc->dc_yres = 0; - - for (;;) { - /* Iterate over runs in video timing table */ - - cols = 0; - - linep = vc2_read_ram(dc, vep++); - lines = vc2_read_ram(dc, vep++); - - if (lines == 0) - break; - -#define VC2_SRUN_EOL 0x8000 /* end of line */ -#define VC2_SRUN_SBSC 0x0080 /* zero if SB/SC follows */ -#define VC2_SRUN_MASK 0x7f00 -#define VC2_SRUN_SHIFT 8 -#define VC2_SA_MASK 0x007f -#define VC2_SA_SHIFT 0 -#define VC2_SA_VISIBLE (1 << (14 % 7)) - do { - /* Iterate over state runs in line sequence table */ - data = vc2_read_ram(dc, linep++); - - if ((((data & VC2_SA_MASK) >> VC2_SA_SHIFT) & - VC2_SA_VISIBLE) == 0) - cols += (data & VC2_SRUN_MASK) >> VC2_SRUN_SHIFT; - if ((data & VC2_SRUN_SBSC) == 0) - data = vc2_read_ram(dc, linep++); - } while ((data & VC2_SRUN_EOL) == 0); - - if (cols != 0) { - cols <<= 1; /* was in 2 pixels unit */ - if (cols > dc->dc_xres) - dc->dc_xres = cols; - dc->dc_yres += lines; - } - } -} - -void -newport_setup_hw(struct newport_devconfig *dc) -{ - uint16_t tmp; - int i; - uint32_t scratch; - - /* Get various revisions */ - rex3_write(dc, REX3_REG_DCBMODE, REX3_DCBMODE_DW_1 | - (NEWPORT_DCBADDR_CMAP_0 << REX3_DCBMODE_DCBADDR_SHIFT) | - (CMAP_DCBCRS_REVISION << REX3_DCBMODE_DCBCRS_SHIFT) | - (1 << REX3_DCBMODE_CSWIDTH_SHIFT) | - (1 << REX3_DCBMODE_CSHOLD_SHIFT) | - (1 << REX3_DCBMODE_CSSETUP_SHIFT)); - scratch = rex3_read(dc, REX3_REG_DCBDATA0) >> 24; - - dc->dc_boardrev = (scratch >> 4) & 0x07; - /* cmaprev = scratch & 0x07; */ - dc->dc_xmaprev = xmap9_read(dc, XMAP9_DCBCRS_REVISION) & 0x07; - dc->dc_depth = ((dc->dc_boardrev > 1) && (scratch & 0x80)) ? 8 : 24; - - scratch = vc2_read_ireg(dc, VC2_IREG_CONFIG); - dc->dc_vc2rev = (scratch & VC2_IREG_CONFIG_REVISION) >> 5; - - /* Setup VC2 to a known state */ - tmp = vc2_read_ireg(dc, VC2_IREG_CONTROL) & VC2_CONTROL_INTERLACE; - vc2_write_ireg(dc, VC2_IREG_CONTROL, tmp | - VC2_CONTROL_DISPLAY_ENABLE | VC2_CONTROL_VTIMING_ENABLE | - VC2_CONTROL_DID_ENABLE | VC2_CONTROL_CURSORFUNC_ENABLE); - - /* Setup XMAP9s */ - xmap9_write(dc, XMAP9_DCBCRS_CONFIG, - XMAP9_CONFIG_8BIT_SYSTEM | XMAP9_CONFIG_RGBMAP_CI); - - xmap9_write(dc, XMAP9_DCBCRS_CURSOR_CMAP, 0); - - xmap9_write_mode(dc, 0, - XMAP9_MODE_GAMMA_BYPASS | XMAP9_MODE_PIXSIZE_8BPP); - xmap9_write(dc, XMAP9_DCBCRS_MODE_SELECT, 0); - - /* Setup REX3 */ - rex3_write(dc, REX3_REG_XYWIN, (4096 << 16) | 4096); - rex3_write(dc, REX3_REG_TOPSCAN, 0x3ff); /* XXX Why? XXX */ - - /* Setup CMAP */ - for (i = 0; i < 256; i++) - newport_cmap_setrgb(dc, i, rasops_cmap[i * 3], - rasops_cmap[i * 3 + 1], rasops_cmap[i * 3 + 2]); -} - -/**** Attach routines ****/ -int -newport_match(struct device *parent, void *vcf, void *aux) -{ - struct gio_attach_args *ga = aux; - - if (ga->ga_product != GIO_PRODUCT_FAKEID_NEWPORT) - return 0; - - return 1; -} - -void -newport_attach(struct device *parent, struct device *self, void *aux) -{ - struct newport_softc *sc = (struct newport_softc *)self; - struct gio_attach_args *ga = aux; - struct newport_devconfig *dc; - struct wsemuldisplaydev_attach_args waa; - const char *descr; - extern struct consdev wsdisplay_cons; - int fail = 0; - - if (cn_tab == &wsdisplay_cons && - ga->ga_addr == newport_console_dc.dc_addr) { - waa.console = 1; - dc = &newport_console_dc; - sc->sc_nscreens = 1; - } else { - waa.console = 0; - dc = malloc(sizeof(struct newport_devconfig), - M_DEVBUF, M_WAITOK | M_ZERO); - newport_attach_common(dc, ga); - if (newport_init_screen(dc) != 0) - fail = 1; - } - sc->sc_dc = dc; - dc->dc_sc = sc; - - descr = ga->ga_descr; - if (descr == NULL || *descr == '\0') - descr = "NG1"; - printf(": %s (board rev %d, xmap rev %d, vc2 rev %d)\n", - descr, dc->dc_boardrev, dc->dc_xmaprev, dc->dc_vc2rev); - printf("%s: %dx%d, %dbpp\n", - self->dv_xname, dc->dc_xres, dc->dc_yres, dc->dc_depth); -#ifdef DEBUG - printf("%s: REX3 config = %06x\n", - self->dv_xname, rex3_read(dc, REX3_REG_CONFIG)); -#endif - - if (fail) { - printf("%s: failed to initialize screen\n", self->dv_xname); - free(dc, M_DEVBUF, sizeof *dc); - return; - } - - sc->sc_scrlist[0] = &dc->dc_wsd; - sc->sc_wsl.nscreens = 1; - sc->sc_wsl.screens = sc->sc_scrlist; - - waa.scrdata = &sc->sc_wsl; - waa.accessops = &newport_accessops; - waa.accesscookie = dc; - waa.defaultscreens = 0; - - config_found(self, &waa, wsemuldisplaydevprint); -} - -int -newport_cnprobe(struct gio_attach_args *ga) -{ - return newport_match(NULL, NULL, ga); -} - -int -newport_cnattach(struct gio_attach_args *ga) -{ - struct rasops_info *ri = &newport_console_dc.dc_ri; - uint32_t defattr; - int rc; - - newport_attach_common(&newport_console_dc, ga); - rc = newport_init_screen(&newport_console_dc); - if (rc != 0) - return rc; - - ri->ri_ops.pack_attr(ri, 0, 0, 0, &defattr); - wsdisplay_cnattach(&newport_console_dc.dc_wsd, ri, 0, 0, defattr); - - return 0; -} - -void -newport_attach_common(struct newport_devconfig *dc, struct gio_attach_args *ga) -{ - dc->dc_addr = ga->ga_addr; - dc->dc_st = ga->ga_iot; - dc->dc_sh = ga->ga_ioh; - - newport_setup_hw(dc); - newport_get_resolution(dc); -} - -int -newport_init_screen(struct newport_devconfig *dc) -{ - struct rasops_info *ri = &dc->dc_ri; - int rc; - - memset(ri, 0, sizeof(struct rasops_info)); - ri->ri_hw = dc; - ri->ri_flg = RI_CENTER | RI_FULLCLEAR; - /* for the proper operation of rasops computations, pretend 8bpp */ - ri->ri_depth = 8; - ri->ri_stride = dc->dc_xres; - ri->ri_width = dc->dc_xres; - ri->ri_height = dc->dc_yres; - - rasops_init(ri, 160, 160); - - ri->ri_do_cursor = newport_do_cursor; - ri->ri_ops.copyrows = newport_copyrows; - ri->ri_ops.eraserows = newport_eraserows; - ri->ri_ops.copycols = newport_copycols; - ri->ri_ops.erasecols = newport_erasecols; - ri->ri_ops.putchar = newport_putchar; - - strlcpy(dc->dc_wsd.name, "std", sizeof(dc->dc_wsd.name)); - dc->dc_wsd.ncols = ri->ri_cols; - dc->dc_wsd.nrows = ri->ri_rows; - dc->dc_wsd.textops = &ri->ri_ops; - dc->dc_wsd.fontwidth = ri->ri_font->fontwidth; - dc->dc_wsd.fontheight = ri->ri_font->fontheight; - dc->dc_wsd.capabilities = ri->ri_caps; - - rc = newport_fill_rectangle(dc, 0, 0, ri->ri_width - 1, - ri->ri_height - 1, WSCOL_BLACK); - -#ifdef notyet - dc->dc_mode = WSDISPLAYIO_MODE_EMUL; -#endif - - return rc; -} - -/**** wsdisplay textops ****/ - -int -newport_do_cursor(struct rasops_info *ri) -{ - struct newport_devconfig *dc = ri->ri_hw; - int x, y, w, h; - - w = ri->ri_font->fontwidth; - h = ri->ri_font->fontheight; - x = ri->ri_ccol * w + ri->ri_xorigin; - y = ri->ri_crow * h + ri->ri_yorigin; - - return newport_bitblt(dc, x, y, x, y, w, h, - OPENGL_LOGIC_OP_COPY_INVERTED); -} - -int -newport_putchar(void *c, int row, int col, u_int ch, uint32_t attr) -{ - struct rasops_info *ri = c; - struct newport_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - uint8_t *bitmap; - uint32_t pattern; - int x = col * font->fontwidth + ri->ri_xorigin; - int y = row * font->fontheight + ri->ri_yorigin; - int i; - int bg, fg, ul; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, &ul); - - if ((ch == ' ' || ch == 0) && ul == 0) { - return newport_fill_rectangle(dc, x, y, x + font->fontwidth - 1, - y + font->fontheight - 1, bg); - } - - if (rex3_wait_gfifo(dc, __func__) != 0) - return EAGAIN; - - rex3_write(dc, REX3_REG_DRAWMODE0, REX3_DRAWMODE0_OPCODE_DRAW | - REX3_DRAWMODE0_ADRMODE_BLOCK | REX3_DRAWMODE0_STOPONX | - REX3_DRAWMODE0_ENZPATTERN | REX3_DRAWMODE0_ZPOPAQUE); - - rex3_write(dc, REX3_REG_DRAWMODE1, REX3_DRAWMODE1_PLANES_CI | - REX3_DRAWMODE1_DD_DD8 | REX3_DRAWMODE1_RWPACKED | - REX3_DRAWMODE1_HD_HD8 | REX3_DRAWMODE1_COMPARE_LT | - REX3_DRAWMODE1_COMPARE_EQ | REX3_DRAWMODE1_COMPARE_GT | - (OPENGL_LOGIC_OP_COPY << REX3_DRAWMODE1_LOGICOP_SHIFT)); - - rex3_write(dc, REX3_REG_XYSTARTI, (x << REX3_XYSTARTI_XSHIFT) | y); - rex3_write(dc, REX3_REG_XYENDI, - (x + font->fontwidth - 1) << REX3_XYENDI_XSHIFT); - - rex3_write(dc, REX3_REG_COLORI, ri->ri_devcmap[fg] & 0xff); - rex3_write(dc, REX3_REG_COLORBACK, ri->ri_devcmap[bg] & 0xff); - - rex3_write(dc, REX3_REG_WRMASK, 0xffffffff); - - bitmap = (uint8_t *)font->data + - (ch - font->firstchar) * ri->ri_fontscale; - if (font->fontwidth <= 8) { - for (i = font->fontheight; i != 0; i--) { - if (ul && i == 1) - pattern = 0xff000000; - else - pattern = *bitmap << 24; - rex3_write_go(dc, REX3_REG_ZPATTERN, pattern); - bitmap += font->stride; - } - } else { - for (i = font->fontheight; i != 0; i--) { - if (ul && i == 1) - pattern = 0xffff0000; - else - pattern = *(uint16_t *)bitmap << 16; - rex3_write_go(dc, REX3_REG_ZPATTERN, pattern); - bitmap += font->stride; - } - } - - return 0; -} - -int -newport_copycols(void *c, int row, int srccol, int dstcol, int ncols) -{ - struct rasops_info *ri = c; - struct newport_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int32_t xs, xd, y, width, height; - - xs = ri->ri_xorigin + font->fontwidth * srccol; - xd = ri->ri_xorigin + font->fontwidth * dstcol; - y = ri->ri_yorigin + font->fontheight * row; - width = font->fontwidth * ncols; - height = font->fontheight; - return newport_bitblt(dc, xs, y, xd, y, width, height, - OPENGL_LOGIC_OP_COPY); -} - -int -newport_erasecols(void *c, int row, int startcol, int ncols, uint32_t attr) -{ - struct rasops_info *ri = c; - struct newport_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int sx, sy, dx, dy; - int bg, fg; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, NULL); - - sx = ri->ri_xorigin + startcol * font->fontwidth; - sy = ri->ri_yorigin + row * font->fontheight; - dx = sx + ncols * font->fontwidth - 1; - dy = sy + font->fontheight - 1; - - return newport_fill_rectangle(dc, sx, sy, dx, dy, bg); -} - -int -newport_copyrows(void *c, int srcrow, int dstrow, int nrows) -{ - struct rasops_info *ri = c; - struct newport_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int32_t x, ys, yd, width, height; - - x = ri->ri_xorigin; - ys = ri->ri_yorigin + font->fontheight * srcrow; - yd = ri->ri_yorigin + font->fontheight * dstrow; - width = ri->ri_emuwidth; - height = font->fontheight * nrows; - - return newport_bitblt(dc, x, ys, x, yd, width, height, - OPENGL_LOGIC_OP_COPY); -} - -int -newport_eraserows(void *c, int startrow, int nrows, uint32_t attr) -{ - struct rasops_info *ri = c; - struct newport_devconfig *dc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int bg, fg; - - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, NULL); - - if (nrows == ri->ri_rows && (ri->ri_flg & RI_FULLCLEAR)) { - return newport_fill_rectangle(dc, 0, 0, ri->ri_width - 1, - ri->ri_height - 1, bg); - } - - return newport_fill_rectangle(dc, ri->ri_xorigin, - ri->ri_yorigin + startrow * font->fontheight, - ri->ri_xorigin + ri->ri_emuwidth - 1, - ri->ri_yorigin + (startrow + nrows) * font->fontheight - 1, bg); -} - -/**** wsdisplay accessops ****/ - -int -newport_alloc_screen(void *v, const struct wsscreen_descr *type, - void **cookiep, int *curxp, int *curyp, uint32_t *attrp) -{ - struct newport_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - struct newport_softc *sc = dc->dc_sc; - - if (sc->sc_nscreens > 0) - return ENOMEM; - - sc->sc_nscreens++; - - *cookiep = ri; - *curxp = *curyp = 0; - ri->ri_ops.pack_attr(ri, 0, 0, 0, &dc->dc_defattr); - *attrp = dc->dc_defattr; - - return 0; -} - -void -newport_free_screen(void *v, void *cookie) -{ -} - -int -newport_show_screen(void *v, void *cookie, int waitok, - void (*cb)(void *, int, int), void *cbarg) -{ - return 0; -} - -int -newport_ioctl(void *v, u_long cmd, caddr_t data, int flag, struct proc *p) -{ - struct newport_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - struct wsdisplay_fbinfo *fb; -#ifdef notyet - int nmode; -#endif - - switch (cmd) { - case WSDISPLAYIO_GTYPE: - *(u_int *)data = WSDISPLAY_TYPE_NEWPORT; - break; - case WSDISPLAYIO_GINFO: - fb = (struct wsdisplay_fbinfo *)data; - fb->width = ri->ri_width; - fb->height = ri->ri_height; - fb->depth = dc->dc_depth; /* real depth */ - if (dc->dc_depth > 8) - fb->cmsize = 0; - else - fb->cmsize = 1 << ri->ri_depth; - break; -#ifdef notyet - case WSDISPLAYIO_SMODE: - nmode = *(int *)data; - if (nmode != dc->dc_mode) { - if (nmode == WSDISPLAYIO_MODE_EMUL) { - if (rex3_wait_gfifo(dc, __func__) != 0) - return EAGAIN; - dc->dc_mode = nmode; - newport_setup_hw(dc); - } else - dc->dc_mode = nmode; - } - break; -#endif - default: - return -1; - } - - return 0; -} - -paddr_t -newport_mmap(void *v, off_t offset, int prot) -{ - return -1; -} - -int -newport_load_font(void *v, void *emulcookie, struct wsdisplay_font *font) -{ - struct newport_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - - return rasops_load_font(ri, emulcookie, font); -} - -int -newport_list_font(void *v, struct wsdisplay_font *font) -{ - struct newport_devconfig *dc = v; - struct rasops_info *ri = &dc->dc_ri; - - return rasops_list_font(ri, font); -} diff --git a/sys/arch/sgi/gio/newportreg.h b/sys/arch/sgi/gio/newportreg.h deleted file mode 100644 index 457d36d1cdb..00000000000 --- a/sys/arch/sgi/gio/newportreg.h +++ /dev/null @@ -1,263 +0,0 @@ -/* $OpenBSD: newportreg.h,v 1.2 2013/04/20 20:26:26 miod Exp $ */ -/* $NetBSD: newportreg.h,v 1.5 2011/02/20 07:59:50 matt Exp $ */ - -/* - * Copyright (c) 2003 Ilpo Ruotsalainen - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -/* REX3 */ - -#define NEWPORT_REX3_OFFSET 0xf0000 - -#define REX3_REG_DRAWMODE1 0x0000 -#define REX3_DRAWMODE1_PLANES_MASK 0x00000007 -#define REX3_DRAWMODE1_PLANES_NONE 0x00000000 -#define REX3_DRAWMODE1_PLANES_RGB 0x00000001 -#define REX3_DRAWMODE1_PLANES_CI 0x00000001 -#define REX3_DRAWMODE1_PLANES_RGBA 0x00000002 -#define REX3_DRAWMODE1_PLANES_OLAY 0x00000004 -#define REX3_DRAWMODE1_PLANES_PUP 0x00000005 -#define REX3_DRAWMODE1_PLANES_CID 0x00000006 -#define REX3_DRAWMODE1_DD_MASK 0x00000018 -#define REX3_DRAWMODE1_DD_DD4 0x00000000 -#define REX3_DRAWMODE1_DD_DD8 0x00000008 -#define REX3_DRAWMODE1_DD_DD12 0x00000010 -#define REX3_DRAWMODE1_DD_DD24 0x00000018 -#define REX3_DRAWMODE1_DBLSRC 0x00000020 -#define REX3_DRAWMODE1_YFLIP 0x00000040 -#define REX3_DRAWMODE1_RWPACKED 0x00000080 -#define REX3_DRAWMODE1_HD_MASK 0x00000300 -#define REX3_DRAWMODE1_HD_HD4 0x00000000 -#define REX3_DRAWMODE1_HD_HD8 0x00000100 -#define REX3_DRAWMODE1_HD_HD12 0x00000200 -#define REX3_DRAWMODE1_HD_HD24 0x00000300 -#define REX3_DRAWMODE1_RWDOUBLE 0x00000400 -#define REX3_DRAWMODE1_SWAPENDIAN 0x00000800 -#define REX3_DRAWMODE1_COMPARE_MASK 0x00007000 -#define REX3_DRAWMODE1_COMPARE_LT 0x00001000 -#define REX3_DRAWMODE1_COMPARE_EQ 0x00002000 -#define REX3_DRAWMODE1_COMPARE_GT 0x00004000 -#define REX3_DRAWMODE1_RGBMODE 0x00008000 -#define REX3_DRAWMODE1_DITHER 0x00010000 -#define REX3_DRAWMODE1_FASTCLEAR 0x00020000 -#define REX3_DRAWMODE1_BLEND 0x00040000 -#define REX3_DRAWMODE1_SFACTOR_MASK 0x00380000 -#define REX3_DRAWMODE1_SFACTOR_ZERO 0x00000000 -#define REX3_DRAWMODE1_SFACTOR_ONE 0x00080000 -#define REX3_DRAWMODE1_SFACTOR_DC 0x00100000 -#define REX3_DRAWMODE1_SFACTOR_MDC 0x00180000 -#define REX3_DRAWMODE1_SFACTOR_SA 0x00200000 -#define REX3_DRAWMODE1_SFACTOR_MSA 0x00280000 -#define REX3_DRAWMODE1_DFACTOR_MASK 0x01c00000 -#define REX3_DRAWMODE1_DFACTOR_ZERO 0x00000000 -#define REX3_DRAWMODE1_DFACTOR_ONE 0x00400000 -#define REX3_DRAWMODE1_DFACTOR_SC 0x00800000 -#define REX3_DRAWMODE1_DFACTOR_MSC 0x00c00000 -#define REX3_DRAWMODE1_DFACTOR_SA 0x01000000 -#define REX3_DRAWMODE1_DFACTOR_MSA 0x01400000 -#define REX3_DRAWMODE1_BACKBLEND 0x02000000 -#define REX3_DRAWMODE1_PREFETCH 0x04000000 -#define REX3_DRAWMODE1_BLENDALPHA 0x08000000 -#define REX3_DRAWMODE1_LOGICOP_SHIFT 28 - -#define REX3_REG_DRAWMODE0 0x0004 -#define REX3_DRAWMODE0_OPCODE_MASK 0x00000003 -#define REX3_DRAWMODE0_OPCODE_NOOP 0x00000000 -#define REX3_DRAWMODE0_OPCODE_READ 0x00000001 -#define REX3_DRAWMODE0_OPCODE_DRAW 0x00000002 -#define REX3_DRAWMODE0_OPCODE_SCR2SCR 0x00000003 -#define REX3_DRAWMODE0_ADRMODE_MASK 0x0000001c -#define REX3_DRAWMODE0_ADRMODE_SPAN 0x00000000 -#define REX3_DRAWMODE0_ADRMODE_BLOCK 0x00000004 -#define REX3_DRAWMODE0_ADRMODE_I_LINE 0x00000008 -#define REX3_DRAWMODE0_ADRMODE_F_LINE 0x0000000c -#define REX3_DRAWMODE0_ADRMODE_A_LINE 0x00000010 -#define REX3_DRAWMODE0_DOSETUP 0x00000020 -#define REX3_DRAWMODE0_COLORHOST 0x00000040 -#define REX3_DRAWMODE0_ALPHAHOST 0x00000080 -#define REX3_DRAWMODE0_STOPONX 0x00000100 -#define REX3_DRAWMODE0_STOPONY 0x00000200 -#define REX3_DRAWMODE0_SKIPFIRST 0x00000400 -#define REX3_DRAWMODE0_SKIPLAST 0x00000800 -#define REX3_DRAWMODE0_ENZPATTERN 0x00001000 -#define REX3_DRAWMODE0_ENLSPATTERN 0x00002000 -#define REX3_DRAWMODE0_LSADVLAST 0x00004000 -#define REX3_DRAWMODE0_LENGTH32 0x00008000 -#define REX3_DRAWMODE0_ZPOPAQUE 0x00010000 -#define REX3_DRAWMODE0_LSOPAQUE 0x00020000 -#define REX3_DRAWMODE0_SHADE 0x00040000 -#define REX3_DRAWMODE0_LRONLY 0x00080000 -#define REX3_DRAWMODE0_XYOFFSET 0x00100000 -#define REX3_DRAWMODE0_CICLAMP 0x00200000 -#define REX3_DRAWMODE0_ENDPTFILTER 0x00400000 -#define REX3_DRAWMODE0_YSTRIDE 0x00800000 -#define REX3_REG_LSMODE 0x0008 - -#define REX3_REG_LSPATTERN 0x000c - -#define REX3_REG_LSPATSAVE 0x0010 - -#define REX3_REG_ZPATTERN 0x0014 - -#define REX3_REG_COLORBACK 0x0018 - -#define REX3_REG_XSTART 0x0100 - -#define REX3_REG_XYMOVE 0x0114 -#define REX3_XYMOVE_XSHIFT 16 - -#define REX3_REG_XSTARTI 0x0148 - -#define REX3_REG_XYSTARTI 0x0150 -#define REX3_XYSTARTI_XSHIFT 16 - -#define REX3_REG_XYENDI 0x0154 -#define REX3_XYENDI_XSHIFT 16 - -#define REX3_REG_WRMASK 0x0220 - -#define REX3_REG_COLORI 0x0224 - -#define REX3_REG_DCBMODE 0x0238 -#define REX3_DCBMODE_DW_MASK 0x00000003 -#define REX3_DCBMODE_DW_4 0x00000000 -#define REX3_DCBMODE_DW_1 0x00000001 -#define REX3_DCBMODE_DW_2 0x00000002 -#define REX3_DCBMODE_DW_3 0x00000003 -#define REX3_DCBMODE_ENDATAPACK 0x00000004 -#define REX3_DCBMODE_ENCRSINC 0x00000008 -#define REX3_DCBMODE_DCBCRS_MASK 0x00000070 -#define REX3_DCBMODE_DCBCRS_SHIFT 4 -#define REX3_DCBMODE_DCBADDR_MASK 0x00000780 -#define REX3_DCBMODE_DCBADDR_SHIFT 7 -#define REX3_DCBMODE_ENSYNCACK 0x00000800 -#define REX3_DCBMODE_ENASYNCACK 0x00001000 -#define REX3_DCBMODE_CSWIDTH_MASK 0x0003e000 -#define REX3_DCBMODE_CSWIDTH_SHIFT 13 -#define REX3_DCBMODE_CSHOLD_MASK 0x007c0000 -#define REX3_DCBMODE_CSHOLD_SHIFT 18 -#define REX3_DCBMODE_CSSETUP_MASK 0x0f800000 -#define REX3_DCBMODE_CSSETUP_SHIFT 23 -#define REX3_DCBMODE_SWAPENDIAN 0x10000000 - -#define REX3_REG_DCBDATA0 0x0240 -#define REX3_REG_DCBDATA1 0x0244 - -/* Not really a register, but in the same space */ -#define REX3_REG_GO 0x0800 - -#define REX3_REG_TOPSCAN 0x1320 -#define REX3_REG_XYWIN 0x1324 - -#define REX3_REG_CONFIG 0x1330 - -#define REX3_REG_STATUS 0x1338 -#define REX3_STATUS_GFXBUSY 0x00000008 -#define REX3_STATUS_FIFOLEVEL_MASK 0x00001F80 -#define REX3_STATUS_FIFOLEVEL_SHIFT 7 - -/* VC2 */ - -#define VC2_DCBCRS_INDEX 0 -#define VC2_DCBCRS_IREG 1 -#define VC2_DCBCRS_RAM 3 - -#define VC2_IREG_VIDEO_ENTRY 0x00 - -#define VC2_IREG_CURSOR_ENTRY 0x01 - -#define VC2_IREG_CURSOR_X 0x02 - -#define VC2_IREG_CURSOR_Y 0x03 - -#define VC2_IREG_SCANLINE_LENGTH 0x06 - -#define VC2_IREG_RAM_ADDRESS 0x07 - -#define VC2_IREG_CONTROL 0x10 -#define VC2_CONTROL_VINTR_ENABLE 0x0001 -#define VC2_CONTROL_DISPLAY_ENABLE 0x0002 -#define VC2_CONTROL_VTIMING_ENABLE 0x0004 -#define VC2_CONTROL_DID_ENABLE 0x0008 -#define VC2_CONTROL_CURSORFUNC_ENABLE 0x0010 -#define VC2_CONTROL_GENSYNC_ENABLE 0x0020 -#define VC2_CONTROL_INTERLACE 0x0040 -#define VC2_CONTROL_CURSOR_ENABLE 0x0080 -#define VC2_CONTROL_CROSSHAIR_CURSOR 0x0100 -#define VC2_CONTROL_LARGE_CURSOR 0x0200 -#define VC2_CONTROL_GENLOCK_1 0x0400 - -#define VC2_IREG_CONFIG 0x1f -#define VC2_IREG_CONFIG_SOFTRESET 0x01 /* active low */ -#define VC2_IREG_CONFIG_SLOWCLOCK 0x02 -#define VC2_IREG_CONFIG_CURSORERROR 0x04 -#define VC2_IREG_CONFIG_DIDERROR 0x08 -#define VC2_IREG_CONFIG_VTGERROR 0x10 -#define VC2_IREG_CONFIG_REVISION 0x70 - -/* CMAP */ - -#define CMAP_DCBCRS_ADDRESS_LOW 0 -#define CMAP_DCBCRS_ADDRESS_HIGH 1 -#define CMAP_DCBCRS_PALETTE 2 -#define CMAP_DCBCRS_REVISION 6 - -/* XMAP9 */ - -#define XMAP9_DCBCRS_CONFIG 0 -#define XMAP9_CONFIG_PUP_ENABLE 0x01 -#define XMAP9_CONFIG_ODD_PIXEL 0x02 -#define XMAP9_CONFIG_8BIT_SYSTEM 0x04 -#define XMAP9_CONFIG_SLOW_PCLK 0x08 -#define XMAP9_CONFIG_RGBMAP_CI 0x00 -#define XMAP9_CONFIG_RGBMAP_0 0x10 -#define XMAP9_CONFIG_RGBMAP_1 0x20 -#define XMAP9_CONFIG_RGBMAP_2 0x30 -#define XMAP9_CONFIG_EXPRESS_MODE 0x40 -#define XMAP9_CONFIG_VIDEO_ENABLE 0x80 -#define XMAP9_DCBCRS_REVISION 1 -#define XMAP9_DCBCRS_FIFOAVAIL 2 -#define XMAP9_DCBCRS_CURSOR_CMAP 3 -#define XMAP9_DCBCRS_PUP_CMAP 4 -#define XMAP9_DCBCRS_MODE_SETUP 5 -#define XMAP9_MODE_GAMMA_BYPASS 0x000004 -#define XMAP9_MODE_PIXSIZE_8BPP 0x000400 -#define XMAP9_DCBCRS_MODE_SELECT 7 - -/* DCB addresses */ - -#define NEWPORT_DCBADDR_VC2 0 -#define NEWPORT_DCBADDR_CMAP_BOTH 1 -#define NEWPORT_DCBADDR_CMAP_0 2 -#define NEWPORT_DCBADDR_CMAP_1 3 -#define NEWPORT_DCBADDR_XMAP_BOTH 4 -#define NEWPORT_DCBADDR_XMAP_0 5 -#define NEWPORT_DCBADDR_XMAP_1 6 -#define NEWPORT_DCBADDR_RAMDAC 7 -#define NEWPORT_DCBADDR_VIDEO_CC1 8 -#define NEWPORT_DCBADDR_VIDEO_AB1 9 diff --git a/sys/arch/sgi/gio/newportvar.h b/sys/arch/sgi/gio/newportvar.h deleted file mode 100644 index 9cc160d9d10..00000000000 --- a/sys/arch/sgi/gio/newportvar.h +++ /dev/null @@ -1,34 +0,0 @@ -/* $OpenBSD: newportvar.h,v 1.1 2012/04/16 22:31:36 miod Exp $ */ -/* $NetBSD: newportvar.h,v 1.3 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2003 Ilpo Ruotsalainen - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>> - */ - -int newport_cnattach(struct gio_attach_args *); -int newport_cnprobe(struct gio_attach_args *); diff --git a/sys/arch/sgi/gio/pci_gio.c b/sys/arch/sgi/gio/pci_gio.c deleted file mode 100644 index ac359747ae8..00000000000 --- a/sys/arch/sgi/gio/pci_gio.c +++ /dev/null @@ -1,497 +0,0 @@ -/* $OpenBSD: pci_gio.c,v 1.3 2014/10/02 18:55:49 miod Exp $ */ -/* $NetBSD: pci_gio.c,v 1.9 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2006 Stephen M. Rumble - * 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. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * Glue for PCI devices that are connected to the GIO bus by various little - * GIO<->PCI ASICs. - * - * We presently recognize the following boards: - * o Phobos G100/G130/G160 (dc, lxtphy) - * o Set Engineering GFE (tl, nsphy) - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/malloc.h> -#include <sys/extent.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> - -#include <mips64/archtype.h> -#include <sgi/sgi/ip22.h> - -#include <sgi/gio/giovar.h> -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giodevs.h> - -#include <sgi/localbus/imcvar.h> - -#include <dev/pci/pcivar.h> -#include <dev/pci/pcireg.h> -#include <dev/pci/pcidevs.h> - -#include "cardbus.h" - -#if NCARDBUS > 0 -#include <dev/cardbus/rbus.h> -#endif - -int giopci_debug = 0; -#define DPRINTF(_x) if (giopci_debug) printf _x - -struct giopci_softc { - struct device sc_dev; - int sc_slot; - - bus_space_tag_t sc_cfgt; - bus_space_handle_t sc_cfgh; - uint32_t sc_cfg_len; - - struct mips_pci_chipset sc_pc; - - bus_dma_tag_t sc_dmat; - bus_size_t sc_dma_boundary; - struct machine_bus_dma_tag sc_dmat_store; -}; - -int giopci_match(struct device *, void *, void *); -void giopci_attach(struct device *, struct device *, void *); - -const struct cfattach giopci_ca = { - sizeof(struct giopci_softc), giopci_match, giopci_attach -}; - -struct cfdriver giopci_cd = { - NULL, "giopci", DV_DULL -}; - -void giopci_attach_hook(struct device *, struct device *, - struct pcibus_attach_args *); -int giopci_bus_maxdevs(void *, int); -pcitag_t giopci_make_tag(void *, int, int, int); -void giopci_decompose_tag(void *, pcitag_t, int *, int *, int *); -int giopci_conf_size(void *, pcitag_t); -pcireg_t giopci_conf_read(void *, pcitag_t, int); -void giopci_conf_write(void *, pcitag_t, int, pcireg_t); -int giopci_probe_device_hook(void *, struct pci_attach_args *); -int giopci_get_widget(void *); -int giopci_get_dl(void *, pcitag_t, struct sgi_device_location *); -int giopci_intr_map(struct pci_attach_args *, pci_intr_handle_t *); -const char *giopci_intr_string(void *, pci_intr_handle_t); -void *giopci_intr_establish(void *, pci_intr_handle_t, int, int (*)(void *), - void *, const char *); -void giopci_intr_disestablish(void *, void *); -int giopci_intr_line(void *, pci_intr_handle_t); -int giopci_ppb_setup(void *, pcitag_t, bus_addr_t *, bus_addr_t *, - bus_addr_t *, bus_addr_t *); -void *giopci_rbus_parent_io(struct pci_attach_args *); -void *giopci_rbus_parent_mem(struct pci_attach_args *); - -static const struct mips_pci_chipset giopci_pci_chipset = { - .pc_attach_hook = giopci_attach_hook, - .pc_bus_maxdevs = giopci_bus_maxdevs, - .pc_make_tag = giopci_make_tag, - .pc_decompose_tag = giopci_decompose_tag, - .pc_conf_size = giopci_conf_size, - .pc_conf_read = giopci_conf_read, - .pc_conf_write = giopci_conf_write, - .pc_probe_device_hook = giopci_probe_device_hook, - .pc_get_widget = giopci_get_widget, - .pc_get_dl = giopci_get_dl, - .pc_intr_map = giopci_intr_map, - .pc_intr_string = giopci_intr_string, - .pc_intr_establish = giopci_intr_establish, - .pc_intr_disestablish = giopci_intr_disestablish, - .pc_intr_line = giopci_intr_line, - .pc_ppb_setup = giopci_ppb_setup, -#if NCARDBUS > 0 - .pc_rbus_parent_io = giopci_rbus_parent_io, - .pc_rbus_parent_mem = giopci_rbus_parent_mem -#endif -}; - -int giopci_dmamap_create(bus_dma_tag_t, bus_size_t, int, bus_size_t, - bus_size_t, int, bus_dmamap_t *); -int giopci_print(void *, const char *); - -#define PHOBOS_PCI_OFFSET 0x00100000 -#define PHOBOS_PCI_LENGTH 0x00000080 /* verified on G130 */ -#define PHOBOS_TULIP_START 0x00101000 -#define PHOBOS_TULIP_END 0x001fffff - -#define SETENG_MAGIC_OFFSET 0x00020000 -#define SETENG_MAGIC_VALUE 0x00001000 -#define SETENG_PCI_OFFSET 0x00080000 -#define SETENG_PCI_LENGTH 0x00000080 /* ~arbitrary */ -#define SETENG_TLAN_START 0x00100000 -#define SETENG_TLAN_END 0x001fffff - -int -giopci_match(struct device *parent, void *vcf, void *aux) -{ - struct gio_attach_args *ga = aux; - - switch (GIO_PRODUCT_PRODUCTID(ga->ga_product)) { - case GIO_PRODUCT_PHOBOS_G160: - case GIO_PRODUCT_PHOBOS_G130: - case GIO_PRODUCT_PHOBOS_G100: - case GIO_PRODUCT_SETENG_GFE: - return 1; - } - - return 0; -} - -void -giopci_attach(struct device *parent, struct device *self, void *aux) -{ - struct giopci_softc *sc = (struct giopci_softc *)self; - pci_chipset_tag_t pc = &sc->sc_pc; - struct gio_attach_args *ga = aux; - uint32_t cfg_off, cfg_len, arb, reg; - struct pcibus_attach_args pba; - uint32_t m_start, m_end; - struct extent *ex; - pcireg_t csr; - - printf(": %s\n", - gio_product_string(GIO_PRODUCT_PRODUCTID(ga->ga_product))); - - sc->sc_cfgt = ga->ga_iot; - sc->sc_dmat = ga->ga_dmat; - sc->sc_slot = ga->ga_slot; - - if (sys_config.system_type != SGI_IP20 && - sys_config.system_subtype == IP22_INDIGO2) - arb = GIO_ARB_RT | GIO_ARB_MST | GIO_ARB_PIPE; - else - arb = GIO_ARB_RT | GIO_ARB_MST; - - if (gio_arb_config(ga->ga_slot, arb)) { - printf("%s: failed to configure GIO bus arbiter\n", - self->dv_xname); - return; - } - - imc_disable_sysad_parity(); - - switch (GIO_PRODUCT_PRODUCTID(ga->ga_product)) { - case GIO_PRODUCT_PHOBOS_G160: - case GIO_PRODUCT_PHOBOS_G130: - case GIO_PRODUCT_PHOBOS_G100: - cfg_off = PHOBOS_PCI_OFFSET; - cfg_len = PHOBOS_PCI_LENGTH; - m_start = PHOBOS_TULIP_START; - m_end = PHOBOS_TULIP_END; - sc->sc_dma_boundary = 0; - break; - - case GIO_PRODUCT_SETENG_GFE: - cfg_off = SETENG_PCI_OFFSET; - cfg_len = SETENG_PCI_LENGTH; - m_start = SETENG_TLAN_START; - m_end = SETENG_TLAN_END; - sc->sc_dma_boundary = 0x1000; - - bus_space_write_4(ga->ga_iot, ga->ga_ioh, - SETENG_MAGIC_OFFSET, SETENG_MAGIC_VALUE); - - break; - } - - if (bus_space_subregion(ga->ga_iot, ga->ga_ioh, cfg_off, cfg_len, - &sc->sc_cfgh)) { - printf("%s: unable to map PCI configuration space\n", - self->dv_xname); - return; - } - - sc->sc_cfg_len = cfg_len; - - bcopy(&giopci_pci_chipset, pc, sizeof(giopci_pci_chipset)); - pc->pc_conf_v = pc->pc_intr_v = sc; - - /* - * Setup a bus_dma tag if necessary. - */ - - if (sc->sc_dma_boundary != 0) { - bcopy(ga->ga_dmat, &sc->sc_dmat_store, - sizeof(struct machine_bus_dma_tag)); - sc->sc_dmat_store._dmamap_create = giopci_dmamap_create; - sc->sc_dmat_store._cookie = sc; - } - - /* - * Setup resource extent for memory BARs. - */ - - ex = extent_create(self->dv_xname, 0, (u_long)-1L, M_DEVBUF, - NULL, 0, EX_NOWAIT | EX_FILLED); - if (ex == NULL || extent_free(ex, ga->ga_addr + m_start, - m_end + 1 - m_start, EX_NOWAIT) != 0) { - printf("%s: unable to setup PCI resource management\n", - self->dv_xname); - return; - } - - /* - * Reset all BARs. Note that we are assuming there is only - * one device, which is neither a bridge nor a multifunction - * device. - * This is necessary because they contain garbage upon poweron, - * and although the bridge chip does not support I/O mappings, - * the chips behind it (at least on Phobos boards) have I/O BARs. - */ - - for (reg = PCI_MAPREG_START; reg < PCI_MAPREG_END; reg += 4) - bus_space_write_4(sc->sc_cfgt, sc->sc_cfgh, reg, 0); - - csr = - bus_space_read_4(sc->sc_cfgt, sc->sc_cfgh, PCI_COMMAND_STATUS_REG); - bus_space_write_4(sc->sc_cfgt, sc->sc_cfgh, PCI_COMMAND_STATUS_REG, - (csr & ~(PCI_COMMAND_IO_ENABLE | PCI_COMMAND_MEM_ENABLE)) | - PCI_COMMAND_MASTER_ENABLE); - - bzero(&pba, sizeof(pba)); - pba.pba_busname = "pci"; - pba.pba_iot = pba.pba_memt = ga->ga_iot; - if (sc->sc_dma_boundary == 0) - pba.pba_dmat = ga->ga_dmat; - else - pba.pba_dmat = &sc->sc_dmat_store; - pba.pba_pc = pc; - pba.pba_ioex = NULL; - pba.pba_memex = ex; - pba.pba_domain = pci_ndomains++; - pba.pba_bus = 0; - - config_found(self, &pba, giopci_print); -} - -int -giopci_print(void *aux, const char *pnp) -{ - struct pcibus_attach_args *pba = aux; - - if (pnp != NULL) - printf("%s at %s", pba->pba_busname, pnp); - printf(" bus %d", pba->pba_bus); - - return UNCONF; -} - -/* - * pci_chipset_t routines - */ - -void -giopci_attach_hook(struct device *parent, struct device *self, - struct pcibus_attach_args *pba) -{ -} - -pcitag_t -giopci_make_tag(void *v, int bus, int dev, int fnc) -{ - return (bus << 16) | (dev << 11) | (fnc << 8); -} - -void -giopci_decompose_tag(void *v, pcitag_t tag, int *busp, int *devp, int *fncp) -{ - if (busp != NULL) - *busp = (tag >> 16) & 0xff; - if (devp != NULL) - *devp = (tag >> 11) & 0x1f; - if (fncp != NULL) - *fncp = (tag >> 8) & 0x7; -} - -int -giopci_bus_maxdevs(void *v, int busno) -{ - return busno == 0 ? 1 : 0; -} - -int -giopci_conf_size(void *v, pcitag_t tag) -{ - struct giopci_softc *sc = (struct giopci_softc *)v; - - return sc->sc_cfg_len; -} - -pcireg_t -giopci_conf_read(void *v, pcitag_t tag, int reg) -{ - struct giopci_softc *sc = v; - int bus, dev, func; - pcireg_t data; - - giopci_decompose_tag(v, tag, &bus, &dev, &func); - if (bus != 0 || dev != 0 || func != 0) - return reg == PCI_ID_REG ? 0xffffffff : 0; - - if (reg >= sc->sc_cfg_len) - return 0; - - DPRINTF(("giopci_conf_read: reg 0x%x = 0x", reg)); - data = bus_space_read_4(sc->sc_cfgt, sc->sc_cfgh, reg); - DPRINTF(("%08x\n", data)); - - return data; -} - -void -giopci_conf_write(void *v, pcitag_t tag, int reg, pcireg_t data) -{ - struct giopci_softc *sc = v; - int bus, dev, func; - - giopci_decompose_tag(v, tag, &bus, &dev, &func); - if (bus != 0 || dev != 0 || func != 0) - return; - - if (reg >= sc->sc_cfg_len) - return; - - DPRINTF(("giopci_conf_write: reg 0x%x = 0x%08x\n", reg, data)); - bus_space_write_4(sc->sc_cfgt, sc->sc_cfgh, reg, data); -} - -int -giopci_probe_device_hook(void *unused, struct pci_attach_args *notused) -{ - return 0; -} - -/* will not actually be used */ -int -giopci_get_widget(void *unused) -{ - return 0; -} - -/* will not actually be used */ -int -giopci_get_dl(void *v, pcitag_t tag, struct sgi_device_location *sdl) -{ - int bus, device, fn; - - memset(sdl, 0, sizeof *sdl); - giopci_decompose_tag(v, tag, &bus, &device, &fn); - if (bus != 0) - return 0; - sdl->device = device; - sdl->fn = fn; - return 1; -} - -int -giopci_intr_map(struct pci_attach_args *pa, pci_intr_handle_t *ihp) -{ - struct giopci_softc *sc = (struct giopci_softc *)pa->pa_pc->pc_intr_v; - int intr; - - if (pa->pa_rawintrpin == 0) - intr = -1; - else - intr = gio_intr_map(sc->sc_slot); - - *ihp = intr; - return intr < 0 ? 1 : 0; -} - -const char * -giopci_intr_string(void *v, pci_intr_handle_t ih) -{ - static char str[10]; - - snprintf(str, sizeof(str), "irq %d", (int)ih); - return str; -} - -void * -giopci_intr_establish(void *v, pci_intr_handle_t ih, int level, - int (*func)(void *), void *arg, const char *name) -{ - return gio_intr_establish((int)ih, level, func, arg, name); -} - -void -giopci_intr_disestablish(void *v, void *ih) -{ - panic("%s", __func__); -} - -int -giopci_intr_line(void *v, pci_intr_handle_t ih) -{ - return (int)ih; -} - -int -giopci_ppb_setup(void *cookie, pcitag_t tag, bus_addr_t *iostart, - bus_addr_t *ioend, bus_addr_t *memstart, bus_addr_t *memend) -{ - panic("%s", __func__); -} - -#if NCARDBUS > 0 -void * -giopci_rbus_parent_io(struct pci_attach_args *pa) -{ - panic("%s"); -} - -void * -giopci_rbus_parent_mem(struct pci_attach_args *pa) -{ - panic("%s"); -} -#endif /* NCARDBUS > 0 */ - -/* - * DMA routines - */ - -int -giopci_dmamap_create(bus_dma_tag_t t, bus_size_t size, int nsegments, - bus_size_t maxsegsz, bus_size_t boundary, int flags, bus_dmamap_t *dmamp) -{ - struct giopci_softc *sc = (struct giopci_softc *)t->_cookie; - - if (boundary == 0 || boundary > sc->sc_dma_boundary) - boundary = sc->sc_dma_boundary; - - return bus_dmamap_create(sc->sc_dmat, size, nsegments, maxsegsz, - boundary, flags, dmamp); -} diff --git a/sys/arch/sgi/hpc/Makefile b/sys/arch/sgi/hpc/Makefile deleted file mode 100644 index 90df0c5adeb..00000000000 --- a/sys/arch/sgi/hpc/Makefile +++ /dev/null @@ -1,12 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2014/05/22 19:39:37 miod Exp $ - -AWK= awk - -PROG= makemap.awk -MAP= ../../../dev/pckbc/wskbdmap_mfii.c - -all: wskbdmap_sgi.c - -wskbdmap_sgi.c: ${MAP} ${PROG} - /bin/rm -f $@ - ${AWK} -f ${PROG} ${MAP} > $@ diff --git a/sys/arch/sgi/hpc/dpclock.c b/sys/arch/sgi/hpc/dpclock.c deleted file mode 100644 index 55f50a482f8..00000000000 --- a/sys/arch/sgi/hpc/dpclock.c +++ /dev/null @@ -1,337 +0,0 @@ -/* $OpenBSD: dpclock.c,v 1.4 2020/05/21 01:49:49 visa Exp $ */ -/* $NetBSD: dpclock.c,v 1.3 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2001 Erik Reid - * Copyright (c) 2001 Rafal K. Boni - * Copyright (c) 2001 Christopher Sekiya - * Copyright (c) 1998, 1999, 2000 The NetBSD Foundation, Inc. - * All rights reserved. - * - * Portions of this code are derived from software contributed to The - * NetBSD Foundation by Jason R. Thorpe of the Numerical Aerospace - * Simulation Facility, NASA Ames Research Center. - * - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ -/* - * Copyright (c) 1988 University of Utah. - * Copyright (c) 1982, 1990, 1993 - * The Regents of the University of California. All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * the Systems Programming Group of the University of Utah Computer - * Science Department. - * - * 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. - * 3. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - * - * from: Utah $Hdr: clock.c 1.18 91/01/21$ - * - * @(#)clock.c 8.2 (Berkeley) 1/12/94 - */ - -#include <sys/param.h> -#include <sys/kernel.h> -#include <sys/systm.h> -#include <sys/device.h> - -#include <machine/bus.h> - -#include <dev/clock_subr.h> -#include <dev/ic/dp8573areg.h> -#include <sgi/hpc/hpcvar.h> - -#define IRIX_BASE_YEAR 1940 - -struct dpclock_softc { - struct device sc_dev; - struct todr_chip_handle sc_todr; - - bus_space_tag_t sc_iot; - bus_space_handle_t sc_ioh; -}; - -int dpclock_match(struct device *, void *, void *); -void dpclock_attach(struct device *, struct device *, void *); - -struct cfdriver dpclock_cd = { - NULL, "dpclock", DV_DULL -}; - -const struct cfattach dpclock_ca = { - sizeof(struct dpclock_softc), dpclock_match, dpclock_attach -}; - -#define dpclock_read(sc,r) \ - bus_space_read_1((sc)->sc_iot, (sc)->sc_ioh, ((r) << 2) + 3) -#define dpclock_write(sc,r,v) \ - bus_space_write_1((sc)->sc_iot, (sc)->sc_ioh, ((r) << 2) + 3, (v)) - -static inline int frombcd(int); -static inline int tobcd(int); -static inline int leapyear(int year); - -static inline int -frombcd(int x) -{ - return (x >> 4) * 10 + (x & 0xf); -} -static inline int -tobcd(int x) -{ - return (x / 10 * 16) + (x % 10); -} -/* - * This inline avoids some unnecessary modulo operations - * as compared with the usual macro: - * ( ((year % 4) == 0 && - * (year % 100) != 0) || - * ((year % 400) == 0) ) - * It is otherwise equivalent. - * (borrowed from kern/clock_subr.c) - */ -static inline int -leapyear(int year) -{ - int rv = 0; - - if ((year & 3) == 0) { - rv = 1; - if ((year % 100) == 0) { - rv = 0; - if ((year % 400) == 0) - rv = 1; - } - } - return (rv); -} - -int dpclock_gettime(struct todr_chip_handle *, struct timeval *); -int dpclock_settime(struct todr_chip_handle *, struct timeval *); - -int -dpclock_match(struct device *parent, void *vcf, void *aux) -{ - struct hpc_attach_args *haa = aux; - - if (strcmp(haa->ha_name, dpclock_cd.cd_name) != 0) - return 0; - - return 1; -} - -void -dpclock_attach(struct device *parent, struct device *self, void *aux) -{ - struct dpclock_softc *sc = (void *)self; - struct hpc_attach_args *haa = aux; - uint8_t st, mode, pflag; - - sc->sc_iot = haa->ha_st; - if (bus_space_subregion(haa->ha_st, haa->ha_sh, haa->ha_devoff, - 4 * DP8573A_NREG, &sc->sc_ioh) != 0) { - printf(": can't map registers\n"); - return; - } - - st = dpclock_read(sc, DP8573A_STATUS); - dpclock_write(sc, DP8573A_STATUS, st | DP8573A_STATUS_REGSEL); - mode = dpclock_read(sc, DP8573A_RT_MODE); - if ((mode & DP8573A_RT_MODE_CLKSS) == 0) { - printf(": clock stopped"); - dpclock_write(sc, DP8573A_RT_MODE, - mode | DP8573A_RT_MODE_CLKSS); - dpclock_write(sc, DP8573A_INT0_CTL, 0); - dpclock_write(sc, DP8573A_INT1_CTL, DP8573A_INT1_CTL_PWRINT); - } - dpclock_write(sc, DP8573A_STATUS, st & ~DP8573A_STATUS_REGSEL); - pflag = dpclock_read(sc, DP8573A_PFLAG); - if (pflag & DP8573A_PFLAG_OFSS) { - dpclock_write(sc, DP8573A_PFLAG, pflag); - pflag = dpclock_read(sc, DP8573A_PFLAG); - if (pflag & DP8573A_PFLAG_OFSS) { - /* - * If the `oscillator failure' condition sticks, - * the battery needs replacement and the clock - * is not ticking. Do not claim sys_tod. - */ - printf("%s oscillator failure\n", - (mode & DP8573A_RT_MODE_CLKSS) == 0 ? "," : ":"); - return; - } - } - if (pflag & DP8573A_PFLAG_TESTMODE) { - dpclock_write(sc, DP8573A_RAM_1F, 0); - dpclock_write(sc, DP8573A_PFLAG, - pflag & ~DP8573A_PFLAG_TESTMODE); - } - - printf("\n"); - - sc->sc_todr.cookie = self; - sc->sc_todr.todr_gettime = dpclock_gettime; - sc->sc_todr.todr_settime = dpclock_settime; - todr_attach(&sc->sc_todr); -} - -/* - * Get the time of day, based on the clock's value and/or the base value. - */ -int -dpclock_gettime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dpclock_softc *sc = handle->cookie; - uint i; - uint8_t regs[DP8573A_NREG]; - - i = dpclock_read(sc, DP8573A_TIMESAVE_CTL); - dpclock_write(sc, DP8573A_TIMESAVE_CTL, i | DP8573A_TIMESAVE_CTL_EN); - dpclock_write(sc, DP8573A_TIMESAVE_CTL, i); - - for (i = 0; i < nitems(regs); i++) - regs[i] = dpclock_read(sc, i); - - dt.dt_sec = frombcd(regs[DP8573A_SAVE_SEC]); - dt.dt_min = frombcd(regs[DP8573A_SAVE_MIN]); - - if (regs[DP8573A_RT_MODE] & DP8573A_RT_MODE_1224) { - dt.dt_hour = frombcd(regs[DP8573A_SAVE_HOUR] & - DP8573A_HOUR_12HR_MASK) + - ((regs[DP8573A_SAVE_HOUR] & DP8573A_RT_MODE_1224) ? 0 : 12); - - /* - * In AM/PM mode, hour range is 01-12, so adding in 12 hours - * for PM gives us 01-24, whereas we want 00-23, so map hour - * 24 to hour 0. - */ - if (dt.dt_hour == 24) - dt.dt_hour = 0; - } else { - dt.dt_hour = frombcd(regs[DP8573A_SAVE_HOUR] & - DP8573A_HOUR_24HR_MASK); - } - - dt.dt_day = frombcd(regs[DP8573A_SAVE_DOM]); - dt.dt_mon = frombcd(regs[DP8573A_SAVE_MONTH]); - dt.dt_year = frombcd(regs[DP8573A_YEAR]) + IRIX_BASE_YEAR; - - tv->tv_sec = clock_ymdhms_to_secs(&dt); - tv->tv_usec = 0; - return 0; -} - -/* - * Reset the TODR based on the time value. - */ -int -dpclock_settime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dpclock_softc *sc = handle->cookie; - uint i; - uint st, r, delta; - uint8_t regs[DP8573A_NREG]; - - clock_secs_to_ymdhms(tv->tv_sec, &dt); - - r = dpclock_read(sc, DP8573A_TIMESAVE_CTL); - dpclock_write(sc, DP8573A_TIMESAVE_CTL, r | DP8573A_TIMESAVE_CTL_EN); - dpclock_write(sc, DP8573A_TIMESAVE_CTL, r); - - for (i = 0; i < nitems(regs); i++) - regs[i] = dpclock_read(sc, i); - - regs[DP8573A_SUBSECOND] = 0; - regs[DP8573A_SECOND] = tobcd(dt.dt_sec); - regs[DP8573A_MINUTE] = tobcd(dt.dt_min); - regs[DP8573A_HOUR] = tobcd(dt.dt_hour) & DP8573A_HOUR_24HR_MASK; - regs[DP8573A_DOW] = tobcd(dt.dt_wday + 1); - regs[DP8573A_DOM] = tobcd(dt.dt_day); - regs[DP8573A_MONTH] = tobcd(dt.dt_mon); - regs[DP8573A_YEAR] = tobcd(dt.dt_year - IRIX_BASE_YEAR); - - st = dpclock_read(sc, DP8573A_STATUS); - dpclock_write(sc, DP8573A_STATUS, st | DP8573A_STATUS_REGSEL); - r = dpclock_read(sc, DP8573A_RT_MODE); - dpclock_write(sc, DP8573A_RT_MODE, r & ~DP8573A_RT_MODE_CLKSS); - - for (i = 0; i < 10; i++) - dpclock_write(sc, DP8573A_COUNTERS + i, - regs[DP8573A_COUNTERS + i]); - - /* - * We now need to set the leap year counter to the correct value. - * Unfortunately it is only two bits wide, while eight years can - * happen between two leap years. Skirting this is left as an - * exercise to the reader with an Indigo in working condition - * by year 2100. - */ - delta = 0; - while (delta < 3 && !leapyear(dt.dt_year - delta)) - delta++; - - r &= ~(DP8573A_RT_MODE_LYLSB | DP8573A_RT_MODE_LYMSB); - dpclock_write(sc, DP8573A_RT_MODE, r | delta | DP8573A_RT_MODE_CLKSS); - - dpclock_write(sc, DP8573A_STATUS, st & ~DP8573A_STATUS_REGSEL); - - return 0; -} diff --git a/sys/arch/sgi/hpc/dsclock.c b/sys/arch/sgi/hpc/dsclock.c deleted file mode 100644 index 38d07c30a3c..00000000000 --- a/sys/arch/sgi/hpc/dsclock.c +++ /dev/null @@ -1,226 +0,0 @@ -/* $OpenBSD: dsclock.c,v 1.5 2020/05/21 01:50:42 visa Exp $ */ -/* $NetBSD: dsclock.c,v 1.5 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2001 Rafal K. Boni - * Copyright (c) 2001 Christopher Sekiya - * Copyright (c) 1998, 1999, 2000 The NetBSD Foundation, Inc. - * All rights reserved. - * - * Portions of this code are derived from software contributed to The - * NetBSD Foundation by Jason R. Thorpe of the Numerical Aerospace - * Simulation Facility, NASA Ames Research Center. - * - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - - -#include <sys/param.h> -#include <sys/kernel.h> -#include <sys/systm.h> -#include <sys/device.h> - -#include <machine/bus.h> - -#include <dev/clock_subr.h> -#include <dev/ic/ds1286reg.h> -#include <sgi/hpc/hpcvar.h> -#include <sgi/sgi/ip22.h> - -struct dsclock_softc { - struct device sc_dev; - struct todr_chip_handle sc_todr; - - bus_space_tag_t sc_iot; - bus_space_handle_t sc_ioh; - - uint sc_base; -}; - -int dsclock_match(struct device *, void *, void *); -void dsclock_attach(struct device *, struct device *, void *); - -struct cfdriver dsclock_cd = { - NULL, "dsclock", DV_DULL -}; - -const struct cfattach dsclock_ca = { - sizeof(struct dsclock_softc), dsclock_match, dsclock_attach -}; - -#define ds1286_read(sc,r) \ - bus_space_read_1((sc)->sc_iot, (sc)->sc_ioh, ((r) << 2) + 3) -#define ds1286_write(sc,r,v) \ - bus_space_write_1((sc)->sc_iot, (sc)->sc_ioh, ((r) << 2) + 3, (v)) - -static inline int frombcd(int); -static inline int tobcd(int); - -static inline int -frombcd(int x) -{ - return (x >> 4) * 10 + (x & 0xf); -} -static inline int -tobcd(int x) -{ - return (x / 10 * 16) + (x % 10); -} - -int dsclock_gettime(struct todr_chip_handle *, struct timeval *); -int dsclock_settime(struct todr_chip_handle *, struct timeval *); - -int -dsclock_match(struct device *parent, void *vcf, void *aux) -{ - struct hpc_attach_args *haa = aux; - - if (strcmp(haa->ha_name, dsclock_cd.cd_name) != 0) - return 0; - - return 1; -} - -void -dsclock_attach(struct device *parent, struct device *self, void *aux) -{ - struct dsclock_softc *sc = (void *)self; - struct hpc_attach_args *haa = aux; - ds1286_todregs regs; - - sc->sc_iot = haa->ha_st; - if (bus_space_subregion(haa->ha_st, haa->ha_sh, haa->ha_devoff, - 4 * 8192, &sc->sc_ioh) != 0) { - printf(": can't map registers\n"); - return; - } - - printf("\n"); - - /* - * Try and figure out what year the chip time is relative to. - * Different Indy PROM versions appear to use different base: - * PROM Monitor SGI Version 5.1 Rev B3 IP24 Sep 17, 1993 (BE) - * uses 1970, while - * PROM Monitor SGI Version 5.3 Rev B10 R4X00/R5000 IP24 Feb 12, 1996 (BE) - * uses 1940. - */ - - DS1286_GETTOD(sc, ®s); - sc->sc_base = bios_year - frombcd(regs[DS1286_YEAR]); - /* year might have changed between the ARCBios call and now... */ - if ((sc->sc_base % 10) == 9) - sc->sc_base++; - - /* - * If the data in the chip does not make sense, assume the usual - * IRIX timebase (1940 because it's a leap year). - */ - if (sc->sc_base != 1940 && sc->sc_base != POSIX_BASE_YEAR) - sc->sc_base = 1940; - - sc->sc_todr.cookie = self; - sc->sc_todr.todr_gettime = dsclock_gettime; - sc->sc_todr.todr_settime = dsclock_settime; - todr_attach(&sc->sc_todr); -} - -/* - * Get the time of day, based on the clock's value and/or the base value. - */ -int -dsclock_gettime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dsclock_softc *sc = handle->cookie; - ds1286_todregs regs; - int s; - - s = splhigh(); - DS1286_GETTOD(sc, ®s) - splx(s); - - dt.dt_sec = frombcd(regs[DS1286_SEC]); - dt.dt_min = frombcd(regs[DS1286_MIN]); - - if (regs[DS1286_HOUR] & DS1286_HOUR_12MODE) { - dt.dt_hour = frombcd(regs[DS1286_HOUR] & DS1286_HOUR_12HR_MASK) - + ((regs[DS1286_HOUR] & DS1286_HOUR_12HR_PM) ? 12 : 0); - - /* - * In AM/PM mode, hour range is 01-12, so adding in 12 hours - * for PM gives us 01-24, whereas we want 00-23, so map hour - * 24 to hour 0. - */ - if (dt.dt_hour == 24) - dt.dt_hour = 0; - } else { - dt.dt_hour = frombcd(regs[DS1286_HOUR] & - DS1286_HOUR_24HR_MASK); - } - - dt.dt_day = frombcd(regs[DS1286_DOM]); - dt.dt_mon = frombcd(regs[DS1286_MONTH] & DS1286_MONTH_MASK); - dt.dt_year = frombcd(regs[DS1286_YEAR]) + sc->sc_base; - - tv->tv_sec = clock_ymdhms_to_secs(&dt); - tv->tv_usec = 0; - return 0; -} - -/* - * Reset the TODR based on the time value. - */ -int -dsclock_settime(struct todr_chip_handle *handle, struct timeval *tv) -{ - struct clock_ymdhms dt; - struct dsclock_softc *sc = handle->cookie; - ds1286_todregs regs; - int s; - - clock_secs_to_ymdhms(tv->tv_sec, &dt); - - s = splhigh(); - DS1286_GETTOD(sc, ®s); - splx(s); - - regs[DS1286_SUBSEC] = 0; - regs[DS1286_SEC] = tobcd(dt.dt_sec); - regs[DS1286_MIN] = tobcd(dt.dt_min); - regs[DS1286_HOUR] = tobcd(dt.dt_hour) & DS1286_HOUR_24HR_MASK; - regs[DS1286_DOW] = tobcd(dt.dt_wday + 1); - regs[DS1286_DOM] = tobcd(dt.dt_day); - - /* Leave wave-generator bits as set originally */ - regs[DS1286_MONTH] &= ~DS1286_MONTH_MASK; - regs[DS1286_MONTH] |= tobcd(dt.dt_mon) & DS1286_MONTH_MASK; - - regs[DS1286_YEAR] = tobcd(dt.dt_year - sc->sc_base); - - s = splhigh(); - DS1286_PUTTOD(sc, ®s); - splx(s); - - return 0; -} diff --git a/sys/arch/sgi/hpc/files.hpc b/sys/arch/sgi/hpc/files.hpc deleted file mode 100644 index 9f6f9994ddd..00000000000 --- a/sys/arch/sgi/hpc/files.hpc +++ /dev/null @@ -1,48 +0,0 @@ -# $OpenBSD: files.hpc,v 1.7 2018/02/14 23:51:49 jsg Exp $ -# $NetBSD: files.hpc,v 1.14 2009/05/14 01:10:19 macallan Exp $ - -# IP20 RTC -device dpclock -attach dpclock at hpc -file arch/sgi/hpc/dpclock.c dpclock - -# IP22/24 RTC -device dsclock -attach dsclock at hpc -file arch/sgi/hpc/dsclock.c dsclock - -device sq: ether, ifnet, ifmedia -attach sq at hpc -file arch/sgi/hpc/if_sq.c sq - -define hpcdma -file arch/sgi/hpc/hpcdma.c hpcdma - -device wdsc: wd33c93ctrl, scsi, hpcdma -attach wdsc at hpc -file arch/sgi/hpc/wdsc.c wdsc - -device zs {[channel = -1]} -attach zs at hpc with zs_hpc -file arch/sgi/hpc/zs.c zs needs-flag -file dev/ic/z8530sc.c zs - -device zstty: tty -attach zstty at zs -file dev/ic/z8530tty.c zstty needs-flag - -device zskbd: wskbddev -attach zskbd at zs -file arch/sgi/hpc/z8530kbd.c zskbd needs-flag -file arch/sgi/hpc/wskbdmap_sgi.c zskbd - -device zsms: wsmousedev -attach zsms at zs -file arch/sgi/hpc/z8530ms.c zsms - -attach pckbc at hpc with pckbc_hpc -file arch/sgi/hpc/pckbc_hpc.c pckbc_hpc - -device panel -attach panel at hpc -file arch/sgi/hpc/panel.c panel diff --git a/sys/arch/sgi/hpc/hpc.c b/sys/arch/sgi/hpc/hpc.c deleted file mode 100644 index c3a2b72ab17..00000000000 --- a/sys/arch/sgi/hpc/hpc.c +++ /dev/null @@ -1,1044 +0,0 @@ -/* $OpenBSD: hpc.c,v 1.18 2015/09/18 20:50:02 miod Exp $ */ -/* $NetBSD: hpc.c,v 1.66 2011/07/01 18:53:46 dyoung Exp $ */ -/* $NetBSD: ioc.c,v 1.9 2011/07/01 18:53:47 dyoung Exp $ */ - -/* - * Copyright (c) 2003 Christopher Sekiya - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ -/* - * Copyright (c) 2000 Soren S. Jorvang - * Copyright (c) 2001 Rafal K. Boni - * Copyright (c) 2001 Jason R. Thorpe - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * Combined driver for the HPC (High performance Peripheral Controller) - * and IOC2 (I/O Controller) chips. - * - * It would theoretically be better to attach an IOC driver to HPC on - * IOC systems (IP22/24/26/28), and attach the few onboard devices - * which attach directly to HPC on IP20, to IOC. But since IOC depends - * too much on HPC, the complexity this would introduce is not worth - * the hassle. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/timeout.h> - -#include <mips64/archtype.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <mips64/cache.h> -#include <machine/cpu.h> - -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giovar.h> - -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/hpcvar.h> -#include <sgi/localbus/imcvar.h> -#include <sgi/localbus/intreg.h> -#include <sgi/localbus/intvar.h> -#include <sgi/hpc/iocreg.h> -#include <sgi/sgi/ip22.h> - -#include <dev/ic/smc93cx6var.h> - -struct hpc_device { - const char *hd_name; - bus_addr_t hd_base; - bus_addr_t hd_devoff; - bus_addr_t hd_dmaoff; - int hd_irq; - int hd_sysmask; -}; - -#define HPCDEV_IP20 (1U << 1) /* Indigo R4k */ -#define HPCDEV_IP22 (1U << 2) /* Indigo2 */ -#define HPCDEV_IP24 (1U << 3) /* Indy, Challenge S */ -#define HPCDEV_IP24_INDY (1U << 4) /* Indy only */ - -/* - * On-board HPC1 devices (IP20 only) - */ -static const struct hpc_device hpc1_onboard[] = { - /* probe order is important for IP20 zs */ - { "zs", /* serial 0/1 duart 1 */ - HPC_BASE_ADDRESS_0, - 0x0d10, 0, - INT2_L0_INTR(INT2_L0_IP20_SERIAL), - HPCDEV_IP20 }, - { "zs", /* kbd/ms duart 0 */ - HPC_BASE_ADDRESS_0, - 0x0d00, 0, - INT2_L0_INTR(INT2_L0_IP20_SERIAL), - HPCDEV_IP20 }, - { "sq", /* onboard Ethernet */ - HPC_BASE_ADDRESS_0, - HPC1_ENET_DEVREGS, HPC1_ENET_REGS, - INT2_L0_INTR(INT2_L0_ENET), - HPCDEV_IP20 }, - { "wdsc", /* onboard SCSI */ - HPC_BASE_ADDRESS_0, - HPC1_SCSI0_DEVREGS, HPC1_SCSI0_REGS, - INT2_L0_INTR(INT2_L0_SCSI1), - HPCDEV_IP20 }, - { NULL } -}; - -/* - * On-board HPC3 devices (IP22, IP24) - */ -static const struct hpc_device hpc3_onboard[] = { - { "zs", /* serial 0/1 duart 0 */ - HPC_BASE_ADDRESS_0, - IOC_BASE + IOC_SERIAL_REGS, 0, - INT2_MAP1_INTR(INT2_MAP_SERIAL), - HPCDEV_IP22 | HPCDEV_IP24 }, - { "pckbc", /* PS/2 keyboard/mouse controller */ - HPC_BASE_ADDRESS_0, - IOC_BASE + IOC_KB_REGS, 0, - INT2_MAP1_INTR(INT2_MAP_PCKBC), - HPCDEV_IP22 | HPCDEV_IP24_INDY }, - { "sq", /* onboard Ethernet */ - HPC_BASE_ADDRESS_0, - HPC3_ENET_DEVREGS, HPC3_ENET_REGS, - INT2_L0_INTR(INT2_L0_ENET), - HPCDEV_IP22 | HPCDEV_IP24 }, - { "wdsc", /* onboard SCSI */ - HPC_BASE_ADDRESS_0, - HPC3_SCSI0_DEVREGS, HPC3_SCSI0_REGS, - INT2_L0_INTR(INT2_L0_IP22_SCSI0), - HPCDEV_IP22 | HPCDEV_IP24 }, - { "wdsc", /* Indigo2/Challenge M secondary onboard SCSI */ - HPC_BASE_ADDRESS_0, - HPC3_SCSI1_DEVREGS, HPC3_SCSI1_REGS, - INT2_L0_INTR(INT2_L0_SCSI1), - HPCDEV_IP22 }, - { "haltwo", /* onboard audio */ - HPC_BASE_ADDRESS_0, - HPC3_PBUS_CH0_DEVREGS, HPC3_PBUS_DMAREGS, - INT2_L1_INTR(INT2_L1_IP22_HPC_DMA), - HPCDEV_IP22 | HPCDEV_IP24_INDY }, - { "pione", /* onboard parallel port */ - HPC_BASE_ADDRESS_0, - IOC_BASE + IOC_PLP_REGS, 0, - INT2_L0_INTR(INT2_L0_IP22_PARALLEL), - HPCDEV_IP22 | HPCDEV_IP24 }, - { "panel", /* Indy front panel */ - HPC_BASE_ADDRESS_0, - IOC_BASE + IOC_PANEL, 0, - INT2_L1_INTR(INT2_L1_IP22_PANEL), - HPCDEV_IP22 | HPCDEV_IP24 }, - { NULL } -}; - -/* - * Expansion HPC1 devices - */ -static const struct hpc_device hpc1_devices[] = { - { "sq", /* E++ GIO adapter */ - 0, - HPC1_ENET_DEVREGS, HPC1_ENET_REGS, - -1, - HPCDEV_IP20 | HPCDEV_IP24 }, - { "wdsc", /* GIO32 SCSI adapter */ - 0, - HPC1_SCSI0_DEVREGS, HPC1_SCSI0_REGS, - -1, - HPCDEV_IP20 | HPCDEV_IP24 }, - { NULL } -}; - -/* - * Expansion HPC3 devices - */ -static const struct hpc_device hpc3_devices[] = { - { "sq", /* Challenge S IO+ secondary ethernet */ - HPC_BASE_ADDRESS_1, - HPC3_ENET_DEVREGS, HPC3_ENET_REGS, - INT2_L0_INTR(INT2_L0_GIO_SLOT0), - HPCDEV_IP24 }, - - { NULL } -}; - -struct hpc_softc { - struct device sc_dev; - - bus_addr_t sc_base; - - bus_space_tag_t sc_ct; - bus_space_handle_t sc_ch; - bus_dma_tag_t sc_dmat; - - struct timeout sc_blink_tmo; -}; - -static struct hpc_values hpc1_values = { - .revision = 1, - .scsi0_regs = HPC1_SCSI0_REGS, - .scsi0_regs_size = HPC1_SCSI0_REGS_SIZE, - .scsi0_cbp = HPC1_SCSI0_CBP, - .scsi0_ndbp = HPC1_SCSI0_NDBP, - .scsi0_bc = HPC1_SCSI0_BC, - .scsi0_ctl = HPC1_SCSI0_CTL, - .scsi0_gio = HPC1_SCSI0_GIO, - .scsi0_dev = HPC1_SCSI0_DEV, - .scsi0_dmacfg = HPC1_SCSI0_DMACFG, - .scsi0_piocfg = HPC1_SCSI0_PIOCFG, - .scsi1_regs = 0, - .scsi1_regs_size = 0, - .scsi1_cbp = 0, - .scsi1_ndbp = 0, - .scsi1_bc = 0, - .scsi1_ctl = 0, - .scsi1_gio = 0, - .scsi1_dev = 0, - .scsi1_dmacfg = 0, - .scsi1_piocfg = 0, - .enet_regs = HPC1_ENET_REGS, - .enet_regs_size = HPC1_ENET_REGS_SIZE, - .enet_intdelay = HPC1_ENET_INTDELAY, - .enet_intdelayval = HPC1_ENET_INTDELAY_OFF, - .enetr_cbp = HPC1_ENETR_CBP, - .enetr_ndbp = HPC1_ENETR_NDBP, - .enetr_bc = HPC1_ENETR_BC, - .enetr_ctl = HPC1_ENETR_CTL, - .enetr_ctl_active = HPC1_ENETR_CTL_ACTIVE, - .enetr_reset = HPC1_ENETR_RESET, - .enetr_dmacfg = 0, - .enetr_piocfg = 0, - .enetx_cbp = HPC1_ENETX_CBP, - .enetx_ndbp = HPC1_ENETX_NDBP, - .enetx_bc = HPC1_ENETX_BC, - .enetx_ctl = HPC1_ENETX_CTL, - .enetx_ctl_active = HPC1_ENETX_CTL_ACTIVE, - .enetx_dev = 0, - .enetr_fifo = HPC1_ENETR_FIFO, - .enetr_fifo_size = HPC1_ENETR_FIFO_SIZE, - .enetx_fifo = HPC1_ENETX_FIFO, - .enetx_fifo_size = HPC1_ENETX_FIFO_SIZE, - .enet_devregs = HPC1_ENET_DEVREGS, - .enet_devregs_size = HPC1_ENET_DEVREGS_SIZE, - .pbus_fifo = 0, - .pbus_fifo_size = 0, - .pbus_bbram = 0, -#define MAX_SCSI_XFER (roundup(MAXPHYS, PAGE_SIZE)) - .scsi_dma_segs = (MAX_SCSI_XFER / 4096), - .scsi_dma_segs_size = 4096, - .scsi_dma_datain_cmd = (HPC1_SCSI_DMACTL_ACTIVE | HPC1_SCSI_DMACTL_DIR), - .scsi_dma_dataout_cmd = HPC1_SCSI_DMACTL_ACTIVE, - .scsi_dmactl_flush = HPC1_SCSI_DMACTL_FLUSH, - .scsi_dmactl_active = HPC1_SCSI_DMACTL_ACTIVE, - .scsi_dmactl_reset = HPC1_SCSI_DMACTL_RESET -}; - -static struct hpc_values hpc3_values = { - .revision = 3, - .scsi0_regs = HPC3_SCSI0_REGS, - .scsi0_regs_size = HPC3_SCSI0_REGS_SIZE, - .scsi0_cbp = HPC3_SCSI0_CBP, - .scsi0_ndbp = HPC3_SCSI0_NDBP, - .scsi0_bc = HPC3_SCSI0_BC, - .scsi0_ctl = HPC3_SCSI0_CTL, - .scsi0_gio = HPC3_SCSI0_GIO, - .scsi0_dev = HPC3_SCSI0_DEV, - .scsi0_dmacfg = HPC3_SCSI0_DMACFG, - .scsi0_piocfg = HPC3_SCSI0_PIOCFG, - .scsi1_regs = HPC3_SCSI1_REGS, - .scsi1_regs_size = HPC3_SCSI1_REGS_SIZE, - .scsi1_cbp = HPC3_SCSI1_CBP, - .scsi1_ndbp = HPC3_SCSI1_NDBP, - .scsi1_bc = HPC3_SCSI1_BC, - .scsi1_ctl = HPC3_SCSI1_CTL, - .scsi1_gio = HPC3_SCSI1_GIO, - .scsi1_dev = HPC3_SCSI1_DEV, - .scsi1_dmacfg = HPC3_SCSI1_DMACFG, - .scsi1_piocfg = HPC3_SCSI1_PIOCFG, - .enet_regs = HPC3_ENET_REGS, - .enet_regs_size = HPC3_ENET_REGS_SIZE, - .enet_intdelay = 0, - .enet_intdelayval = 0, - .enetr_cbp = HPC3_ENETR_CBP, - .enetr_ndbp = HPC3_ENETR_NDBP, - .enetr_bc = HPC3_ENETR_BC, - .enetr_ctl = HPC3_ENETR_CTL, - .enetr_ctl_active = HPC3_ENETR_CTL_ACTIVE, - .enetr_reset = HPC3_ENETR_RESET, - .enetr_dmacfg = HPC3_ENETR_DMACFG, - .enetr_piocfg = HPC3_ENETR_PIOCFG, - .enetx_cbp = HPC3_ENETX_CBP, - .enetx_ndbp = HPC3_ENETX_NDBP, - .enetx_bc = HPC3_ENETX_BC, - .enetx_ctl = HPC3_ENETX_CTL, - .enetx_ctl_active = HPC3_ENETX_CTL_ACTIVE, - .enetx_dev = HPC3_ENETX_DEV, - .enetr_fifo = HPC3_ENETR_FIFO, - .enetr_fifo_size = HPC3_ENETR_FIFO_SIZE, - .enetx_fifo = HPC3_ENETX_FIFO, - .enetx_fifo_size = HPC3_ENETX_FIFO_SIZE, - .enet_devregs = HPC3_ENET_DEVREGS, - .enet_devregs_size = HPC3_ENET_DEVREGS_SIZE, - .pbus_fifo = HPC3_PBUS_FIFO, - .pbus_fifo_size = HPC3_PBUS_FIFO_SIZE, - .pbus_bbram = HPC3_PBUS_BBRAM, - .scsi_dma_segs = (MAX_SCSI_XFER / 8192), - .scsi_dma_segs_size = 8192, - .scsi_dma_datain_cmd = HPC3_SCSI_DMACTL_ACTIVE, - .scsi_dma_dataout_cmd =(HPC3_SCSI_DMACTL_ACTIVE | HPC3_SCSI_DMACTL_DIR), - .scsi_dmactl_flush = HPC3_SCSI_DMACTL_FLUSH, - .scsi_dmactl_active = HPC3_SCSI_DMACTL_ACTIVE, - .scsi_dmactl_reset = HPC3_SCSI_DMACTL_RESET -}; - -int hpc_match(struct device *, void *, void *); -void hpc_attach(struct device *, struct device *, void *); -int hpc_print(void *, const char *); - -int hpc_revision(struct hpc_softc *, struct gio_attach_args *); -int hpc_submatch(struct device *, void *, void *); -int hpc_power_intr(void *); -void hpc_blink(void *); -void hpc_blink_ioc(void *); -int hpc_read_eeprom(int, bus_space_tag_t, bus_space_handle_t, uint8_t *, - size_t); - -struct hpc_dma_desc *hpc_sync_dma_desc_par(struct hpc_dma_desc *, - struct hpc_dma_desc *); -struct hpc_dma_desc *hpc_sync_dma_desc_ecc(struct hpc_dma_desc *, - struct hpc_dma_desc *); -void hpc_update_dma_desc_par(struct hpc_dma_desc *, struct hpc_dma_desc *); -void hpc_update_dma_desc_ecc(struct hpc_dma_desc *, struct hpc_dma_desc *); - -/* globals since they depend upon the system type, not the hpc version */ -struct hpc_dma_desc *(*hpc_sync_dma_desc_fn)(struct hpc_dma_desc *, - struct hpc_dma_desc *); -void (*hpc_update_dma_desc_fn)(struct hpc_dma_desc *, struct hpc_dma_desc *); - -const struct cfattach hpc_ca = { - sizeof(struct hpc_softc), hpc_match, hpc_attach -}; - -struct cfdriver hpc_cd = { - NULL, "hpc", DV_DULL -}; - -void hpc3_space_barrier(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, int); - -bus_space_t hpc3bus_tag = { - PHYS_TO_XKPHYS(0, CCA_NC), - NULL, - imc_read_1, imc_write_1, - imc_read_2, imc_write_2, - imc_read_4, imc_write_4, - imc_read_8, imc_write_8, - imc_read_raw_2, imc_write_raw_2, - imc_read_raw_4, imc_write_raw_4, - imc_read_raw_8, imc_write_raw_8, - imc_space_map, imc_space_unmap, imc_space_region, - imc_space_vaddr, hpc3_space_barrier -}; - -int -hpc_match(struct device *parent, void *vcf, void *aux) -{ - struct gio_attach_args* ga = aux; - uint32_t dummy; - - /* Make sure it's actually there and readable */ - if (guarded_read_4(PHYS_TO_XKPHYS(ga->ga_addr, CCA_NC), &dummy) == 0) - return 1; - - return 0; -} - -void -hpc_attach(struct device *parent, struct device *self, void *aux) -{ - struct hpc_softc *sc = (struct hpc_softc *)self; - struct gio_attach_args* ga = aux; - struct hpc_attach_args ha; - const struct hpc_device *hd; - struct hpc_values *hv; - uint32_t probe32; - uint8_t probe8; - uint32_t hpctype; - int isonboard; - int isioplus; - int giofast; - int needprobe; - int sysmask = 0; - - sc->sc_base = ga->ga_addr; - sc->sc_ct = ga->ga_iot; - sc->sc_ch = PHYS_TO_XKPHYS(sc->sc_base, CCA_NC); - sc->sc_dmat = ga->ga_dmat; - - /* setup HPC DMA helpers if not done already */ - if (hpc_sync_dma_desc_fn == NULL) { - if (ip22_ecc) { - hpc_sync_dma_desc_fn = hpc_sync_dma_desc_ecc; - hpc_update_dma_desc_fn = hpc_update_dma_desc_ecc; - } else { - hpc_sync_dma_desc_fn = hpc_sync_dma_desc_par; - hpc_update_dma_desc_fn = hpc_update_dma_desc_par; - } - } - - switch (sys_config.system_type) { - case SGI_IP20: - sysmask = HPCDEV_IP20; - break; - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - switch (sys_config.system_subtype) { - default: - case IP22_INDIGO2: - sysmask = HPCDEV_IP22; - break; - case IP22_CHALLS: - sysmask = HPCDEV_IP24; - break; - case IP22_INDY: - sysmask = HPCDEV_IP24 | HPCDEV_IP24_INDY; - break; - } - break; - }; - - if ((hpctype = hpc_revision(sc, ga)) == 0) { - printf(": could not identify HPC revision\n"); - return; - } - - if (hpctype != 3) - hpc_old = 1; - - /* force big-endian mode */ - if (hpctype == 15) - bus_space_write_4(sc->sc_ct, sc->sc_ch, HPC1_BIGENDIAN, 0); - - /* - * Select the proper bus_space_tag for child devices. HPC3 need a - * specific barrier function. - */ - if (hpctype == 3) - sc->sc_ct = &hpc3bus_tag; - - /* - * All machines have only one HPC on the mainboard itself. ''Extra'' - * HPCs require bus arbiter and other magic to run happily. - */ - isonboard = (sc->sc_base == HPC_BASE_ADDRESS_0); - isioplus = (sc->sc_base == HPC_BASE_ADDRESS_1 && hpctype == 3 && - (sysmask & HPCDEV_IP24) != 0); - - printf(": SGI HPC%d%s (%s)\n", (hpctype == 3) ? 3 : 1, - (hpctype == 15) ? ".5" : "", (isonboard) ? "onboard" : - (isioplus) ? "IO+ mezzanine" : "GIO slot"); - - /* - * Configure the IOC. - */ - if (isonboard && sys_config.system_type != SGI_IP20) { - /* Reset IOC */ - bus_space_write_4(sc->sc_ct, sc->sc_ch, IOC_BASE + IOC_RESET, - IOC_RESET_PARALLEL | IOC_RESET_PCKBC | IOC_RESET_EISA | - IOC_RESET_ISDN | IOC_RESET_LED_GREEN ); - - /* - * Set the two serial ports to PC mode. - */ - bus_space_write_4(sc->sc_ct, sc->sc_ch, IOC_BASE + IOC_WRITE, - bus_space_read_4(sc->sc_ct, sc->sc_ch, - IOC_BASE + IOC_WRITE) | - IOC_WRITE_PC_UART2 | IOC_WRITE_PC_UART1); - - /* XXX: the firmware should have taken care of this already */ -#if 0 - if (sys_config.system_subtype != IP22_INDIGO2) { - bus_space_write_4(sc->sc_ct, sc->sc_ch, - IOC_BASE + IOC_GCSEL, 0xff); - bus_space_write_4(sc->sc_ct, sc->sc_ch, - IOC_BASE + IOC_GCREG, 0xff); - } -#endif - } - - /* - * Configure the bus arbiter appropriately. - * - * In the case of Challenge S, we must tell the IO+ board which - * DMA channel to use (we steal it from one of the slots). SGI allows - * an HPC1.5 in slot 1, in which case IO+ must use EXP0, or any - * other DMA-capable board in slot 0, which leaves us to use EXP1. Of - * course, this means that only one GIO board may use DMA. - * - * Note that this never happens on Indigo2. - */ - if (isioplus) { - int arb_slot; - - if (guarded_read_4(PHYS_TO_XKPHYS(HPC_BASE_ADDRESS_2, CCA_NC), - &probe32) != 0) - arb_slot = GIO_SLOT_EXP1; - else - arb_slot = GIO_SLOT_EXP0; - - if (gio_arb_config(arb_slot, GIO_ARB_LB | GIO_ARB_MST | - GIO_ARB_64BIT | GIO_ARB_HPC2_64BIT)) { - printf("%s: failed to configure GIO bus arbiter\n", - sc->sc_dev.dv_xname); - return; - } - - printf("%s: using EXP%d's DMA channel\n", - sc->sc_dev.dv_xname, - (arb_slot == GIO_SLOT_EXP0) ? 0 : 1); - - bus_space_write_4(sc->sc_ct, sc->sc_ch, - HPC3_PBUS_CFGPIO_REGS, 0x0003ffff); - - if (arb_slot == GIO_SLOT_EXP0) - bus_space_write_4(sc->sc_ct, sc->sc_ch, - HPC3_PBUS_CH0_DEVREGS, 0x20202020); - else - bus_space_write_4(sc->sc_ct, sc->sc_ch, - HPC3_PBUS_CH0_DEVREGS, 0x30303030); - } else if (!isonboard) { - int arb_slot; - - arb_slot = (sc->sc_base == HPC_BASE_ADDRESS_1) ? - GIO_SLOT_EXP0 : GIO_SLOT_EXP1; - - if (gio_arb_config(arb_slot, GIO_ARB_RT | GIO_ARB_MST)) { - printf("%s: failed to configure GIO bus arbiter\n", - sc->sc_dev.dv_xname); - return; - } - } - - hpc_read_eeprom(hpctype, sc->sc_ct, sc->sc_ch, - ha.hpc_eeprom, sizeof(ha.hpc_eeprom)); - - if (hpctype == 3) { - hv = &hpc3_values; - if (isonboard) { - hd = hpc3_onboard; - if (sys_config.system_subtype == IP22_INDIGO2) { - /* wild guess */ - giofast = 1; - } else { - /* - * According to IRIX hpc3.h, the fast GIO bit - * is active high, but the register value has - * been found to be 0xf8 on slow GIO systems - * and 0xf1 on fast ones, which tends to prove - * the opposite... - */ - if (bus_space_read_4(sc->sc_ct, sc->sc_ch, - IOC_BASE + IOC_GCREG) & IOC_GCREG_GIO_33MHZ) - giofast = 0; - else - giofast = 1; - } - } else { - hd = hpc3_devices; - /* - * XXX should IO+ Mezzanine use the same settings as - * XXX the onboard HPC3? - */ - giofast = 0; - } - needprobe = 0; - } else { - hv = &hpc1_values; - hv->revision = hpctype; - giofast = 0; - if (isonboard) { - hd = hpc1_onboard; - needprobe = 0; - } else { - hd = hpc1_devices; - /* - * Until a reliable way of telling E++ and GIO32 SCSI - * boards apart is found, we will need to do basic - * chip existence checks before attempting to attach. - */ - needprobe = 1; - } - } - for (; hd->hd_name != NULL; hd++) { - if ((hd->hd_sysmask & sysmask) == 0 || - (hd->hd_base != 0 && hd->hd_base != sc->sc_base)) - continue; - - ha.ha_name = hd->hd_name; - ha.ha_base = sc->sc_base; - ha.ha_devoff = hd->hd_devoff; - ha.ha_dmaoff = hd->hd_dmaoff; - /* - * Compute the interrupt line for HPC1 expansion boards. - * This allows the hpc1_devices[] array to remain compact. - */ - if (hd->hd_irq < 0) { - if (sys_config.system_type == SGI_IP20) - ha.ha_irq = INT2_L0_INTR(INT2_L0_GIO_LVL1); - else { - if (sc->sc_base == HPC_BASE_ADDRESS_1) - ha.ha_irq = - INT2_MAP0_INTR(INT2_MAP_GIO_SLOT0); - else - ha.ha_irq = - INT2_MAP0_INTR(INT2_MAP_GIO_SLOT1); - } - } else - ha.ha_irq = hd->hd_irq; - - ha.ha_st = sc->sc_ct; - ha.ha_sh = sc->sc_ch; - ha.ha_dmat = sc->sc_dmat; - ha.hpc_regs = hv; - ha.ha_giofast = giofast; - - /* - * On hpc@gio boards such as the E++, we want to avoid - * `wdsc not configured' messages (or sq on SCSI boards). - * The following checks are borrowed from the sq(4) and - * wdsc(4) respective probes. - */ - if (needprobe) { - paddr_t pa; - volatile uint32_t *reg; - - if (strcmp(hd->hd_name, "sq") == 0) { - /* - * E++ registers aren't accessible until - * the reset register is written to. - */ - pa = sc->sc_ch + hd->hd_dmaoff + - hv->enetr_reset; - reg = (volatile uint32_t *) - PHYS_TO_XKPHYS(pa, CCA_NC); - if (guarded_read_4((vaddr_t)reg, &probe32) != 0) - continue; - *reg = 0x01; - delay(20); - *reg = 0x00; - - pa = sc->sc_ch + hd->hd_devoff + - (7 << 2); /* SEEQ_TXSTAT */ - reg = (volatile uint32_t *) - PHYS_TO_XKPHYS(pa, CCA_NC); - if (guarded_read_4((vaddr_t)reg, &probe32) != 0) - continue; - if ((probe32 & 0xff) != 0x80) /*TXSTAT_OLDNEW*/ - continue; - } else - /* if (strcmp(hd->hd_name, "wdsc") == 0) */ { - /* - * wdsc registers may not be accessible - * until the dma engine is reset. - */ - pa = sc->sc_ch + hd->hd_dmaoff + - hv->scsi0_ctl; - reg = (volatile uint32_t *) - PHYS_TO_XKPHYS(pa, CCA_NC); - if (guarded_read_4((vaddr_t)reg, &probe32) != 0) - continue; - *reg = hv->scsi_dmactl_reset; - delay(1000); - *reg = 0; - delay(1000); - - pa = sc->sc_ch + hd->hd_devoff + 3; - if (guarded_read_1(PHYS_TO_XKPHYS(pa, CCA_NC), - &probe8) != 0) - continue; - if (probe8 == 0xff) - continue; - } - } - - config_found_sm(self, &ha, hpc_print, hpc_submatch); - } - - /* - * Attach the clock chip as well if on hpc0. - */ - if (isonboard) { - if (sys_config.system_type == SGI_IP20) { - ha.ha_name = "dpclock"; - ha.ha_devoff = HPC1_PBUS_BBRAM; - } else { - ha.ha_name = "dsclock"; - ha.ha_devoff = HPC3_PBUS_BBRAM; - } - ha.ha_base = sc->sc_base; - ha.ha_dmaoff = 0; - ha.ha_irq = -1; - ha.ha_st = sc->sc_ct; - ha.ha_sh = sc->sc_ch; - ha.ha_dmat = sc->sc_dmat; - ha.hpc_regs = NULL; - ha.ha_giofast = giofast; - - config_found_sm(self, &ha, hpc_print, hpc_submatch); - - if (sys_config.system_type == SGI_IP20) { - timeout_set(&sc->sc_blink_tmo, hpc_blink, sc); - hpc_blink(sc); - } else { - timeout_set(&sc->sc_blink_tmo, hpc_blink_ioc, sc); - hpc_blink_ioc(sc); - } - } -} - -/* - * HPC revision detection isn't as simple as it should be. Devices probe - * differently depending on their slots, but luckily there is only one - * instance in which we have to decide the major revision (HPC1 vs HPC3). - * - * The HPC is found in the following configurations: - * o Indigo R4k - * One on-board HPC1 or HPC1.5. - * Up to two additional HPC1.5's in GIO slots 0 and 1. - * o Indy - * One on-board HPC3. - * Up to two additional HPC1.5's in GIO slots 0 and 1. - * o Challenge S - * One on-board HPC3. - * Up to one additional HPC3 on the IO+ board (if installed). - * Up to one additional HPC1.5 in slot 1 of the IO+ board. - * o Indigo2, Challenge M - * One on-board HPC3. - * - * All we really have to worry about is the IP24 case. - */ -int -hpc_revision(struct hpc_softc *sc, struct gio_attach_args *ga) -{ - uint32_t reg; - - /* No hardware ever supported the last hpc base address. */ - if (ga->ga_addr == HPC_BASE_ADDRESS_3) - return 0; - - switch (sys_config.system_type) { - case SGI_IP20: - if (guarded_read_4(PHYS_TO_XKPHYS(ga->ga_addr + HPC1_BIGENDIAN, - CCA_NC), ®) != 0) { - if (((reg >> HPC1_REVSHIFT) & HPC1_REVMASK) == - HPC1_REV15) - return 15; - else - return 1; - } - return 1; - - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - if (ga->ga_addr == HPC_BASE_ADDRESS_0) - return 3; - - if (sys_config.system_subtype == IP22_INDIGO2) - return 0; - - /* - * If IP24, probe slot 0 to determine if HPC1.5 or HPC3. Slot 1 - * must be HPC1.5. - */ - - if (ga->ga_addr == HPC_BASE_ADDRESS_2) - return 15; - - /* - * Probe for it. We use one of the PBUS registers. Note - * that this probe succeeds with my E++ adapter in slot 1 - * (bad), but it appears to always do the right thing in - * slot 0 (good!) and we're only worried about that one - * anyhow. - */ - if (guarded_read_4(PHYS_TO_XKPHYS(ga->ga_addr + - HPC3_PBUS_CH7_BP, CCA_NC), ®) != 0) - return 15; - else - return 3; - } - - return 0; -} - -int -hpc_submatch(struct device *parent, void *vcf, void *aux) -{ - struct cfdata *cf = (struct cfdata *)vcf; - struct hpc_attach_args *ha = (struct hpc_attach_args *)aux; - - if (cf->cf_loc[0 /*HPCCF_OFFSET*/] != -1 && - (bus_addr_t)cf->cf_loc[0 /*HPCCF_OFFSET*/] != ha->ha_devoff) - return 0; - - return (*cf->cf_attach->ca_match)(parent, cf, aux); -} - -int -hpc_print(void *aux, const char *pnp) -{ - struct hpc_attach_args *ha = aux; - - if (pnp) - printf("%s at %s", ha->ha_name, pnp); - - printf(" offset 0x%08lx", ha->ha_devoff); - if (ha->ha_irq >= 0) - printf(" irq %d", ha->ha_irq); - - return UNCONF; -} - -void * -hpc_intr_establish(int irq, int level, int (*handler)(void *), void *arg, - const char *what) -{ - return int2_intr_establish(irq, level, handler, arg, what); -} - -int -hpc_is_intr_pending(int irq) -{ - return int2_is_intr_pending(irq); -} - -void -hpc_intr_disable(void *v) -{ - int2_intr_disable(v); -} - -void -hpc_intr_enable(void *v) -{ - int2_intr_enable(v); -} - -/* - * bus_space_barrier() function for HPC3 (which have a write buffer) - */ -void -hpc3_space_barrier(bus_space_tag_t t, bus_space_handle_t h, bus_size_t offs, - bus_size_t sz, int how) -{ - mips_sync(); - /* just read a side-effect free register */ - (void)*(volatile uint32_t *) - PHYS_TO_XKPHYS(HPC_BASE_ADDRESS_0 + HPC3_INTRSTAT_40, CCA_NC); -} - -void -hpc_blink(void *arg) -{ - struct hpc_softc *sc = arg; - - bus_space_write_1(sc->sc_ct, sc->sc_ch, HPC1_AUX_REGS, - bus_space_read_1(sc->sc_ct, sc->sc_ch, HPC1_AUX_REGS) ^ - HPC1_AUX_CONSLED); - - timeout_add(&sc->sc_blink_tmo, - (((averunnable.ldavg[0] + FSCALE) * hz) >> (FSHIFT + 1))); -} - -void -hpc_blink_ioc(void *arg) -{ - struct hpc_softc *sc = arg; - uint32_t value; - - /* This is a bit odd. To strobe the green LED, we have to toggle the - red control bit. */ - value = bus_space_read_4(sc->sc_ct, sc->sc_ch, IOC_BASE + IOC_RESET) & - 0xff; - value ^= IOC_RESET_LED_RED; - bus_space_write_4(sc->sc_ct, sc->sc_ch, IOC_BASE + IOC_RESET, value); - - timeout_add(&sc->sc_blink_tmo, - (((averunnable.ldavg[0] + FSCALE) * hz) >> (FSHIFT + 1))); -} - -/* - * Read the eeprom associated with one of the HPC's. - * - * NB: An eeprom is not always present, but the HPC should be able to - * handle this gracefully. Any consumers should validate the data to - * ensure it's reasonable. - */ -int -hpc_read_eeprom(int hpctype, bus_space_tag_t t, bus_space_handle_t h, - uint8_t *buf, size_t len) -{ - struct seeprom_descriptor sd; - bus_space_handle_t bsh; - bus_size_t offset; - - if (!len || len & 0x1) - return (1); - - offset = (hpctype == 3) ? HPC3_EEPROM_DATA : HPC1_AUX_REGS; - - if (bus_space_subregion(t, h, offset, 1, &bsh) != 0) - return (1); - - sd.sd_chip = C56_66; - sd.sd_tag = t; - sd.sd_bsh = bsh; - sd.sd_regsize = 1; - sd.sd_control_offset = 0; - sd.sd_status_offset = 0; - sd.sd_dataout_offset = 0; - sd.sd_DI = 0x10; /* EEPROM -> CPU */ - sd.sd_DO = 0x08; /* CPU -> EEPROM */ - sd.sd_CK = 0x04; - sd.sd_CS = 0x02; - sd.sd_MS = 0; - sd.sd_RDY = 0; - - if (read_seeprom(&sd, (uint16_t *)buf, 0, len / 2) != 1) - return (1); - - bus_space_unmap(t, bsh, 1); - - return 0; -} - -/* - * Routines to update HPC DMA descriptors. - */ - -struct hpc_dma_desc * -hpc_sync_dma_desc(struct hpc_dma_desc *desc, struct hpc_dma_desc *store) -{ - return (*hpc_sync_dma_desc_fn)(desc, store); -} - -void -hpc_update_dma_desc(struct hpc_dma_desc *desc, struct hpc_dma_desc *store) -{ - (*hpc_update_dma_desc_fn)(desc, store); -} - -/* - * Parity MC flavour: descriptors are in non-cacheable memory, to which - * accesses are allowed. No cache operation is needed. - */ - -struct hpc_dma_desc * -hpc_sync_dma_desc_par(struct hpc_dma_desc *desc, struct hpc_dma_desc *store) -{ - /* nothing to do */ - return desc; -} - -void -hpc_update_dma_desc_par(struct hpc_dma_desc *desc, struct hpc_dma_desc *store) -{ - /* nothing to do */ - KDASSERT(desc == store); -} - -/* - * ECC MC flavour: descriptor are in cacheable memory, and need to be - * evicted from cache before reading, and flushed from cache after updating. - * - * In addition, on R1000 systems, an actual copy of the descriptor needs - * to be performed, to prevent speculative execution from writing to the - * cached descriptor. - */ - -struct hpc_dma_desc * -hpc_sync_dma_desc_ecc(struct hpc_dma_desc *desc, struct hpc_dma_desc *store) -{ - Mips_IOSyncDCache(curcpu(), - (vaddr_t)desc, sizeof(struct hpc_dma_desc), CACHE_SYNC_R); - - store->hdd_bufptr = desc->hdd_bufptr; - store->hdd_ctl = desc->hdd_ctl; - store->hdd_descptr = desc->hdd_descptr; - - return store; -} - -void -hpc_update_dma_desc_ecc(struct hpc_dma_desc *desc, struct hpc_dma_desc *store) -{ - desc->hdd_bufptr = store->hdd_bufptr; - desc->hdd_ctl = store->hdd_ctl; - desc->hdd_descptr = store->hdd_descptr; - - Mips_IOSyncDCache(curcpu(), - (vaddr_t)desc, sizeof(struct hpc_dma_desc), CACHE_SYNC_X); -} diff --git a/sys/arch/sgi/hpc/hpcdma.c b/sys/arch/sgi/hpc/hpcdma.c deleted file mode 100644 index 53dc86994ce..00000000000 --- a/sys/arch/sgi/hpc/hpcdma.c +++ /dev/null @@ -1,208 +0,0 @@ -/* $OpenBSD: hpcdma.c,v 1.1 2012/03/28 20:44:23 miod Exp $ */ -/* $NetBSD: hpcdma.c,v 1.21 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2001 Wayne Knowles - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Wayne Knowles - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the NetBSD - * Foundation, Inc. and its contributors. - * 4. Neither the name of The NetBSD Foundation nor the names of its - * contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * - * 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. - */ - -/* - * Support for SCSI DMA provided by the HPC. - * - * Note: We use SCSI0 offsets, etc. here. Since the layout of SCSI0 - * and SCSI1 are the same, this is no problem. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/buf.h> - -#include <uvm/uvm_extern.h> - -#include <machine/bus.h> - -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/hpcvar.h> -#include <sgi/hpc/hpcdma.h> - -/* - * Allocate DMA Chain descriptor list - */ -void -hpcdma_init(struct hpc_attach_args *haa, struct hpc_dma_softc *sc, int ndesc) -{ - bus_dma_segment_t seg; - int rseg, allocsz; - - sc->sc_bst = haa->ha_st; - sc->sc_dmat = haa->ha_dmat; - sc->sc_ndesc = ndesc; - sc->sc_flags = 0; - - if (bus_space_subregion(haa->ha_st, haa->ha_sh, haa->ha_dmaoff, - sc->hpc->scsi0_regs_size, &sc->sc_bsh) != 0) { - printf(": can't map DMA registers\n"); - return; - } - - /* Alloc 1 additional descriptor - needed for DMA bug fix */ - allocsz = sizeof(struct hpc_dma_desc) * (ndesc + 1); - - /* - * Allocate a block of memory for dma chaining pointers - */ - if (bus_dmamem_alloc(sc->sc_dmat, allocsz, 0, 0, &seg, 1, &rseg, - BUS_DMA_NOWAIT)) { - printf(": can't allocate sglist\n"); - return; - } - /* Map pages into kernel memory */ - if (bus_dmamem_map(sc->sc_dmat, &seg, rseg, allocsz, - (caddr_t *)&sc->sc_desc_kva, BUS_DMA_NOWAIT)) { - printf(": can't map sglist\n"); - bus_dmamem_free(sc->sc_dmat, &seg, rseg); - return; - } - - if (bus_dmamap_create(sc->sc_dmat, allocsz, 1 /*seg*/, allocsz, 0, - BUS_DMA_WAITOK, &sc->sc_dmamap) != 0) { - printf(": failed to create dmamap\n"); - return; - } - - if (bus_dmamap_load(sc->sc_dmat, sc->sc_dmamap, - sc->sc_desc_kva, allocsz, NULL, BUS_DMA_NOWAIT)) { - printf(": can't load sglist\n"); - return; - } - - sc->sc_desc_pa = sc->sc_dmamap->dm_segs[0].ds_addr; -} - - -void -hpcdma_sglist_create(struct hpc_dma_softc *sc, bus_dmamap_t dmamap) -{ - struct hpc_dma_desc *hva; - bus_addr_t hpa; - bus_dma_segment_t *segp; - int i; - - KASSERT(dmamap->dm_nsegs <= sc->sc_ndesc); - - hva = sc->sc_desc_kva; - hpa = sc->sc_desc_pa; - segp = dmamap->dm_segs; - -#ifdef DMA_DEBUG - printf("DMA_SGLIST<"); -#endif - for (i = dmamap->dm_nsegs; i; i--) { -#ifdef DMA_DEBUG - printf("%p:%ld, ", (void *)segp->ds_addr, segp->ds_len); -#endif - hpa += sizeof(struct hpc_dma_desc); /* next chain desc */ - if (sc->hpc->revision == 3) { - hva->hpc3_hdd_bufptr = segp->ds_addr; - hva->hpc3_hdd_ctl = segp->ds_len; - hva->hdd_descptr = hpa; - } else /* HPC 1/1.5 */ { - /* - * there doesn't seem to be any good way of doing this - * via an abstraction layer - */ - hva->hpc1_hdd_bufptr = segp->ds_addr; - hva->hpc1_hdd_ctl = segp->ds_len; - hva->hdd_descptr = hpa; - } - ++hva; - ++segp; - } - - /* Work around HPC3 DMA bug */ - if (sc->hpc->revision == 3) { - hva->hpc3_hdd_bufptr = 0; - hva->hpc3_hdd_ctl = HPC3_HDD_CTL_EOCHAIN; - hva->hdd_descptr = 0; - } else { - hva--; - hva->hpc1_hdd_bufptr |= HPC1_HDD_CTL_EOCHAIN; - hva->hdd_descptr = 0; - } - -#ifdef DMA_DEBUG - printf(">\n"); -#endif - bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, - 0, sizeof(struct hpc_dma_desc) * (dmamap->dm_nsegs + 1), - BUS_DMASYNC_PREWRITE); - - /* Load DMA Descriptor list */ - bus_space_write_4(sc->sc_bst, sc->sc_bsh, sc->hpc->scsi0_ndbp, - sc->sc_desc_pa); -} - -void -hpcdma_cntl(struct hpc_dma_softc *sc, uint32_t mode) -{ - bus_space_write_4(sc->sc_bst, sc->sc_bsh, sc->hpc->scsi0_ctl, mode); -} - -void -hpcdma_reset(struct hpc_dma_softc *sc) -{ - bus_space_write_4(sc->sc_bst, sc->sc_bsh, sc->hpc->scsi0_ctl, - sc->hpc->scsi_dmactl_reset); - delay(100); - bus_space_write_4(sc->sc_bst, sc->sc_bsh, sc->hpc->scsi0_ctl, 0); - delay(1000); -} - -void -hpcdma_flush(struct hpc_dma_softc *sc) -{ - uint32_t mode; - - mode = bus_space_read_4(sc->sc_bst, sc->sc_bsh, sc->hpc->scsi0_ctl); - bus_space_write_4(sc->sc_bst, sc->sc_bsh, - sc->hpc->scsi0_ctl, mode | sc->hpc->scsi_dmactl_flush); - - /* Wait for Active bit to drop */ - while (bus_space_read_4(sc->sc_bst, sc->sc_bsh, sc->hpc->scsi0_ctl) & - sc->hpc->scsi_dmactl_active) { - bus_space_barrier(sc->sc_bst, sc->sc_bsh, sc->hpc->scsi0_ctl, 4, - BUS_SPACE_BARRIER_READ); - } -} diff --git a/sys/arch/sgi/hpc/hpcdma.h b/sys/arch/sgi/hpc/hpcdma.h deleted file mode 100644 index 007e9ccfb1b..00000000000 --- a/sys/arch/sgi/hpc/hpcdma.h +++ /dev/null @@ -1,63 +0,0 @@ -/* $OpenBSD: hpcdma.h,v 1.2 2021/03/11 11:17:00 jsg Exp $ */ -/* $NetBSD: hpcdma.h,v 1.11 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2001 Wayne Knowles - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Wayne Knowles - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the NetBSD - * Foundation, Inc. and its contributors. - * 4. Neither the name of The NetBSD Foundation nor the names of its - * contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * - * 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. - */ - -struct hpc_dma_softc { - bus_space_tag_t sc_bst; - bus_space_handle_t sc_bsh; - bus_dma_tag_t sc_dmat; - - uint32_t sc_flags; -#define HPCDMA_READ 0x20 /* direction of transfer */ -#define HPCDMA_LOADED 0x40 /* bus_dmamap loaded */ -#define HPCDMA_ACTIVE 0x80 /* DMA engine is busy */ - uint32_t sc_dmacmd; - int sc_ndesc; - bus_dmamap_t sc_dmamap; - struct hpc_dma_desc *sc_desc_kva; /* Virtual address */ - bus_addr_t sc_desc_pa; /* DMA address */ - ssize_t sc_dlen; /* number of bytes transferred */ - struct hpc_values *hpc; /* constants for HPC1/3 */ -}; - - -void hpcdma_init(struct hpc_attach_args *, struct hpc_dma_softc *, int); -void hpcdma_sglist_create(struct hpc_dma_softc *, bus_dmamap_t); -void hpcdma_cntl(struct hpc_dma_softc *, uint32_t); -void hpcdma_reset(struct hpc_dma_softc *); -void hpcdma_flush(struct hpc_dma_softc *); diff --git a/sys/arch/sgi/hpc/hpcreg.h b/sys/arch/sgi/hpc/hpcreg.h deleted file mode 100644 index 7ca01674968..00000000000 --- a/sys/arch/sgi/hpc/hpcreg.h +++ /dev/null @@ -1,457 +0,0 @@ -/* $OpenBSD: hpcreg.h,v 1.2 2015/09/05 21:13:24 miod Exp $ */ -/* $NetBSD: hpcreg.h,v 1.20 2011/01/25 12:21:04 tsutsui Exp $ */ - -/* - * Copyright (c) 2001 Rafal K. Boni - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * HPC locations are identical across all HPC-supported - * platforms. - */ -#define HPC_BASE_ADDRESS_0 0x1fb80000 /* Primary onboard */ -#define HPC_BASE_ADDRESS_1 0x1fb00000 -#define HPC_BASE_ADDRESS_2 0x1f980000 -#define HPC_BASE_ADDRESS_3 0x1f900000 /* NB: Never supported in h/w */ - -/* - * HPC3 descriptor layout. - */ -struct hpc_dma_desc { - uint32_t hdd_bufptr; /* Physical address of buffer */ - uint32_t hdd_ctl; /* Control flags and byte count */ - uint32_t hdd_descptr; /* Physical address of next descr. */ -#if defined(CPU_R8000) || defined (CPU_R10000) - uint32_t hdd_pad[29]; /* Pad out to largest cache line */ -#else - uint32_t hdd_pad; /* Pad out to quadword alignment */ -#endif -}; - -#define HPC1_DMA_BOUNDARY 0x1000 -#define HPC3_DMA_BOUNDARY 0x2000 - -/* - * The hdd_bufptr and hdd_ctl fields are swapped between HPC1 and - * HPC3. These fields are referenced by macro for readability. - */ -#define hpc1_hdd_ctl hdd_bufptr -#define hpc1_hdd_bufptr hdd_ctl -#define hpc3_hdd_ctl hdd_ctl -#define hpc3_hdd_bufptr hdd_bufptr - -/* - * Control flags - */ -#define HPC3_HDD_CTL_EOCHAIN 0x80000000 /* End of descriptor chain */ -#define HPC3_HDD_CTL_EOPACKET 0x40000000 /* Ethernet: end of packet */ -#define HPC3_HDD_CTL_INTR 0x20000000 /* Interrupt when finished */ -#define HPC3_HDD_CTL_XMITDONE 0x00008000 /* Ethernet transmit done */ -#define HPC3_HDD_CTL_OWN 0x00004000 /* CPU owns this frame */ - -#define HPC3_HDD_CTL_BYTECNT(x) ((x) & 0x3fff) /* Byte count: for ethernet - * rcv channel also doubles as - * length of packet received - */ - -/* - * HPC memory map, as offsets from HPC base - * - * XXXrkb: should each section be used as a base and have the specific - * registers offset from there?? - * - * XXX: define register values as well as their offsets. - * - */ -#define HPC3_PBUS_DMAREGS 0x00000000 /* DMA registers for PBus */ -#define HPC3_PBUS_DMAREGS_SIZE 0x0000ffff /* channels 0 - 7 */ - -#define HPC3_PBUS_CH0_BP 0x00000000 /* Chan 0 Buffer Ptr */ -#define HPC3_PBUS_CH0_DP 0x00000004 /* Chan 0 Descriptor Ptr */ -#define HPC3_PBUS_CH0_CTL 0x00001000 /* Chan 0 Control Register */ - -#define HPC3_PBUS_CH1_BP 0x00002000 /* Chan 1 Buffer Ptr */ -#define HPC3_PBUS_CH1_DP 0x00002004 /* Chan 1 Descriptor Ptr */ -#define HPC3_PBUS_CH1_CTL 0x00003000 /* Chan 1 Control Register */ - -#define HPC3_PBUS_CH2_BP 0x00004000 /* Chan 2 Buffer Ptr */ -#define HPC3_PBUS_CH2_DP 0x00004004 /* Chan 2 Descriptor Ptr */ -#define HPC3_PBUS_CH2_CTL 0x00005000 /* Chan 2 Control Register */ - -#define HPC3_PBUS_CH3_BP 0x00006000 /* Chan 3 Buffer Ptr */ -#define HPC3_PBUS_CH3_DP 0x00006004 /* Chan 3 Descriptor Ptr */ -#define HPC3_PBUS_CH3_CTL 0x00007000 /* Chan 3 Control Register */ - -#define HPC3_PBUS_CH4_BP 0x00008000 /* Chan 4 Buffer Ptr */ -#define HPC3_PBUS_CH4_DP 0x00008004 /* Chan 4 Descriptor Ptr */ -#define HPC3_PBUS_CH4_CTL 0x00009000 /* Chan 4 Control Register */ - -#define HPC3_PBUS_CH5_BP 0x0000a000 /* Chan 5 Buffer Ptr */ -#define HPC3_PBUS_CH5_DP 0x0000a004 /* Chan 5 Descriptor Ptr */ -#define HPC3_PBUS_CH5_CTL 0x0000b000 /* Chan 5 Control Register */ - -#define HPC3_PBUS_CH6_BP 0x0000c000 /* Chan 6 Buffer Ptr */ -#define HPC3_PBUS_CH6_DP 0x0000c004 /* Chan 6 Descriptor Ptr */ -#define HPC3_PBUS_CH6_CTL 0x0000d000 /* Chan 6 Control Register */ - -#define HPC3_PBUS_CH7_BP 0x0000e000 /* Chan 7 Buffer Ptr */ -#define HPC3_PBUS_CH7_DP 0x0000e004 /* Chan 7 Descriptor Ptr */ -#define HPC3_PBUS_CH7_CTL 0x0000f000 /* Chan 7 Control Register */ - -#define HPC3_SCSI0_REGS 0x00010000 /* SCSI channel 0 registers */ -#define HPC3_SCSI0_REGS_SIZE 0x00001fff - -#define HPC3_SCSI0_CBP 0x00000000 /* Current buffer ptr */ -#define HPC3_SCSI0_NDBP 0x00000004 /* Next descriptor ptr */ - -#define HPC3_SCSI0_BC 0x00001000 /* DMA byte count & flags */ -#define HPC3_SCSI0_CTL 0x00001004 /* DMA control flags */ -#define HPC3_SCSI0_GIO 0x00001008 /* GIO DMA FIFO pointer */ -#define HPC3_SCSI0_DEV 0x0000100c /* Device DMA FIFO pointer */ -#define HPC3_SCSI0_DMACFG 0x00001010 /* DMA configuration */ -#define HPC3_SCSI0_PIOCFG 0x00001014 /* PIO configuration */ - -#define HPC3_SCSI1_REGS 0x00012000 /* SCSI channel 1 registers */ -#define HPC3_SCSI1_REGS_SIZE 0x00001fff - -#define HPC3_SCSI1_CBP 0x00000000 /* Current buffer ptr */ -#define HPC3_SCSI1_NDBP 0x00000004 /* Next descriptor ptr */ - -#define HPC3_SCSI1_BC 0x00001000 /* DMA byte count & flags */ -#define HPC3_SCSI1_CTL 0x00001004 /* DMA control flags */ -#define HPC3_SCSI1_GIO 0x00001008 /* GIO DMA FIFO pointer */ -#define HPC3_SCSI1_DEV 0x0000100c /* Device DMA FIFO pointer */ -#define HPC3_SCSI1_DMACFG 0x00001010 /* DMA configuration */ -#define HPC3_SCSI1_PIOCFG 0x00001014 /* PIO configuration */ - -/* HPC3_SCSIx_CTL "SCSI control register" flags: */ -#define HPC3_SCSI_DMACTL_IRQ 0x01 /* IRQ asserted, dma done or parity */ -#define HPC3_SCSI_DMACTL_ENDIAN 0x02 /* DMA endian mode, 0=BE, 1=LE */ -#define HPC3_SCSI_DMACTL_DIR 0x04 /* DMA direction, 0=dev->mem, 1=mem->dev */ -#define HPC3_SCSI_DMACTL_FLUSH 0x08 /* Flush DMA FIFO's */ -#define HPC3_SCSI_DMACTL_ACTIVE 0x10 /* DMA channel is active */ -#define HPC3_SCSI_DMACTL_AMASK 0x20 /* DMA active inhibits PIO */ -#define HPC3_SCSI_DMACTL_RESET 0x40 /* Reset dma channel and ext. controller */ -#define HPC3_SCSI_DMACTL_PERR 0x80 /* Parity error: interface to controller */ - -/* HPC_PBUS_CHx_CTL read: */ -#define HPC3_PBUS_DMACTL_IRQ 0x01 /* IRQ asserted, DMA done */ -#define HPC3_PBUS_DMACTL_ISACT 0x02 /* DMA channel is active */ - -/* HPC_PBUS_CHx_CTL write: */ -#define HPC3_PBUS_DMACTL_ENDIAN 0x02 /* DMA endianness, 0=BE 1=LE */ -#define HPC3_PBUS_DMACTL_RECEIVE 0x04 /* DMA direction, 1=dev->mem, 0=mem->dev*/ -#define HPC3_PBUS_DMACTL_FLUSH 0x08 /* Flush DMA FIFO */ -#define HPC3_PBUS_DMACTL_ACT 0x10 /* Activate DMA channel */ -#define HPC3_PBUS_DMACTL_ACT_LD 0x20 /* Load enable for ACT */ -#define HPC3_PBUS_DMACTL_RT 0x40 /* Enable real time GIO service for DMA */ -#define HPC3_PBUS_DMACTL_HIGHWATER_SHIFT 8 -#define HPC3_PBUS_DMACTL_FIFOBEG_SHIFT 16 -#define HPC3_PBUS_DMACTL_FIFOEND_SHIFT 24 - -#define HPC3_ENET_REGS 0x00014000 /* Ethernet registers */ -#define HPC3_ENET_REGS_SIZE 0x00003fff - -#define HPC3_ENETR_CBP 0x00000000 /* Recv: Current buffer ptr */ -#define HPC3_ENETR_NDBP 0x00000004 /* Recv: Next descriptor ptr */ - -#define HPC3_ENETR_BC 0x00001000 /* Recv: DMA byte cnt/flags */ -#define HPC3_ENETR_CTL 0x00001004 /* Recv: DMA control flags */ - -#define HPC3_ENETR_CTL_STAT_5_0 0x003f /* Seeq irq status: bits 0-5 */ -#define HPC3_ENETR_CTL_STAT_6 0x0040 /* Irq status: late_rxdc */ -#define HPC3_ENETR_CTL_STAT_7 0x0080 /* Irq status: old/new bit */ -#define HPC3_ENETR_CTL_LENDIAN 0x0100 /* DMA channel endian mode */ -#define HPC3_ENETR_CTL_ACTIVE 0x0200 /* DMA channel active? */ -#define HPC3_ENETR_CTL_ACTIVE_MSK 0x0400 /* DMA channel active? */ -#define HPC3_ENETR_CTL_RBO 0x0800 /* Recv buffer overflow */ - -#define HPC3_ENETR_GIO 0x00001008 /* Recv: GIO DMA FIFO ptr */ -#define HPC3_ENETR_DEV 0x0000100c /* Recv: Device DMA FIFO ptr */ -#define HPC3_ENETR_RESET 0x00001014 /* Recv: Ethernet chip reset */ - -#define HPC3_ENETR_RESET_CH 0x0001 /* Reset controller & chan */ -#define HPC3_ENETR_RESET_CLRINT 0x0002 /* Clear channel interrupt */ -#define HPC3_ENETR_RESET_LOOPBK 0x0004 /* External loopback enable */ -#define HPC3_ENETR_RESET_CLRRBO 0x0008 /* Clear RBO condition (??) */ - -#define HPC3_ENETR_DMACFG 0x00001018 /* Recv: DMA configuration */ - -#define HPC3_ENETR_DMACFG_D1(_x) (((_x) << 0) & 0x000f) /* D1 gio_clk cycles */ -#define HPC3_ENETR_DMACFG_D2(_x) (((_x) << 4) & 0x00f0) /* D2 gio_clk cycles */ -#define HPC3_ENETR_DMACFG_D3(_x) (((_x) << 8) & 0x0f00) /* D3 gio_clk cycles */ -#define HPC3_ENETR_DMACFG_WRCTL 0x01000 /* Enable IPG write */ - -/* - * The following three bits work around bugs in the Seeq 8003; if you - * don't set them, the Seeq gets wonky pretty often. - */ -#define HPC3_ENETR_DMACFG_FIX_RXDC 0x02000 /* Clear EOP bits on RXDC */ -#define HPC3_ENETR_DMACFG_FIX_EOP 0x04000 /* Enable rxintr timeout */ -#define HPC3_ENETR_DMACFG_FIX_INTR 0x08000 /* Enable EOP timeout */ -#define HPC3_ENETR_DMACFG_TIMEOUT 0x30000 /* Timeout value for above two*/ - -#define HPC3_ENETR_PIOCFG 0x0000101c /* Recv: PIO configuration */ - -#define HPC3_ENETR_PIOCFG_P1(_x) (((_x) << 0) & 0x000f) /* P1 gio_clk cycles */ -#define HPC3_ENETR_PIOCFG_P2(_x) (((_x) << 4) & 0x00f0) /* P2 gio_clk cycles */ -#define HPC3_ENETR_PIOCFG_P3(_x) (((_x) << 8) & 0x0f00) /* P3 gio_clk cycles */ - -#define HPC3_ENETX_CBP 0x00002000 /* Xmit: Current buffer ptr */ -#define HPC3_ENETX_NDBP 0x00002004 /* Xmit: Next descriptor ptr */ - -#define HPC3_ENETX_BC 0x00003000 /* Xmit: DMA byte cnt/flags */ -#define HPC3_ENETX_CTL 0x00003004 /* Xmit: DMA control flags */ - -#define HPC3_ENETX_CTL_STAT_5_0 0x003f /* Seeq irq status: bits 0-5 */ -#define HPC3_ENETX_CTL_STAT_6 0x0040 /* Irq status: late_rxdc */ -#define HPC3_ENETX_CTL_STAT_7 0x0080 /* Irq status: old/new bit */ -#define HPC3_ENETX_CTL_LENDIAN 0x0100 /* DMA channel endian mode */ -#define HPC3_ENETX_CTL_ACTIVE 0x0200 /* DMA channel active? */ -#define HPC3_ENETX_CTL_ACTIVE_MSK 0x0400 /* DMA channel active? */ -#define HPC3_ENETX_CTL_RBO 0x0800 /* Recv buffer overflow */ - -#define HPC3_ENETX_GIO 0x00003008 /* Xmit: GIO DMA FIFO ptr */ -#define HPC3_ENETX_DEV 0x0000300c /* Xmit: Device DMA FIFO ptr */ - -#define HPC3_PBUS_FIFO 0x00020000 /* PBus DMA FIFO */ -#define HPC3_PBUS_FIFO_SIZE 0x00007fff /* PBus DMA FIFO size */ - -#define HPC3_SCSI0_FIFO 0x00028000 /* SCSI0 DMA FIFO */ -#define HPC3_SCSI0_FIFO_SIZE 0x00001fff /* SCSI0 DMA FIFO size */ - -#define HPC3_SCSI1_FIFO 0x0002a000 /* SCSI1 DMA FIFO */ -#define HPC3_SCSI1_FIFO_SIZE 0x00001fff /* SCSI1 DMA FIFO size */ - -#define HPC3_ENETR_FIFO 0x0002c000 /* Ether recv DMA FIFO */ -#define HPC3_ENETR_FIFO_SIZE 0x00001fff /* Ether recv DMA FIFO size */ - -#define HPC3_ENETX_FIFO 0x0002e000 /* Ether xmit DMA FIFO */ -#define HPC3_ENETX_FIFO_SIZE 0x00001fff /* Ether xmit DMA FIFO size */ - -/* - * HPCBUG: The interrupt status is split amongst two registers, and they're - * not even consecutive in the HPC address space. This is documented as a - * bug by SGI. - */ -#define HPC3_INTRSTAT_40 0x00030000 /* Interrupt stat, bits 4:0 */ -#define HPC3_INTRSTAT_95 0x0003000c /* Interrupt stat, bits 9:5 */ - -#define HPC3_GIO_MISC 0x00030004 /* GIO64 misc register */ - -#define HPC3_EEPROM_DATA 0x0003000b /* Serial EEPROM data reg. */ - /* (byte) */ - -#define HPC3_GIO_BUSERR 0x00030010 /* GIO64 bus error intr stat */ - -#define HPC3_SCSI0_DEVREGS 0x00044000 /* SCSI channel 0 chip regs */ -#define HPC3_SCSI1_DEVREGS 0x0004c000 /* SCSI channel 1 chip regs */ - -#define HPC3_ENET_DEVREGS 0x00054000 /* Ethernet chip registers */ -#define HPC3_ENET_DEVREGS_SIZE 0x000004ff /* Size of chip registers */ - -#define HPC3_PBUS_DEVREGS 0x00054000 /* PBus PIO chip registers */ -#define HPC3_PBUS_DEVREGS_SIZE 0x000003ff /* PBus PIO chip registers */ - -#define HPC3_PBUS_CH0_DEVREGS 0x00058000 /* PBus ch. 0 chip registers */ -#define HPC3_PBUS_CH0_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH1_DEVREGS 0x00058400 /* PBus ch. 1 chip registers */ -#define HPC3_PBUS_CH1_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH2_DEVREGS 0x00058800 /* PBus ch. 2 chip registers */ -#define HPC3_PBUS_CH2_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH3_DEVREGS 0x00058c00 /* PBus ch. 3 chip registers */ -#define HPC3_PBUS_CH3_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH4_DEVREGS 0x00059000 /* PBus ch. 4 chip registers */ -#define HPC3_PBUS_CH4_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH5_DEVREGS 0x00059400 /* PBus ch. 5 chip registers */ -#define HPC3_PBUS_CH5_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH6_DEVREGS 0x00059800 /* PBus ch. 6 chip registers */ -#define HPC3_PBUS_CH6_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH7_DEVREGS 0x00059c00 /* PBus ch. 7 chip registers */ -#define HPC3_PBUS_CH7_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH8_DEVREGS 0x0005a000 /* PBus ch. 8 chip registers */ -#define HPC3_PBUS_CH8_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH9_DEVREGS 0x0005a400 /* PBus ch. 9 chip registers */ -#define HPC3_PBUS_CH9_DEVREGS_SIZE 0x03ff - -#define HPC3_PBUS_CH8_DEVREGS_2 0x0005a800 /* PBus ch. 8 chip registers */ -#define HPC3_PBUS_CH8_DEVREGS_2_SIZE 0x03ff - -#define HPC3_PBUS_CH9_DEVREGS_2 0x0005ac00 /* PBus ch. 9 chip registers */ -#define HPC3_PBUS_CH9_DEVREGS_2_SIZE 0x03ff - -#define HPC3_PBUS_CH8_DEVREGS_3 0x0005b000 /* PBus ch. 8 chip registers */ -#define HPC3_PBUS_CH8_DEVREGS_3_SIZE 0x03ff - -#define HPC3_PBUS_CH9_DEVREGS_3 0x0005b400 /* PBus ch. 9 chip registers */ -#define HPC3_PBUS_CH9_DEVREGS_3_SIZE 0x03ff - -#define HPC3_PBUS_CH8_DEVREGS_4 0x0005b800 /* PBus ch. 8 chip registers */ -#define HPC3_PBUS_CH8_DEVREGS_4_SIZE 0x03ff - -#define HPC3_PBUS_CH9_DEVREGS_4 0x0005bc00 /* PBus ch. 9 chip registers */ -#define HPC3_PBUS_CH9_DEVREGS_4_SIZE 0x03ff - -#define HPC3_PBUS_CFGDMA_REGS 0x0005c000 /* PBus DMA config registers */ -#define HPC3_PBUS_CFGDMA_REGS_SIZE 0x0fff - -#define HPC3_PBUS_CH0_CFGDMA 0x0005c000 /* PBus Ch. 0 DMA config */ -#define HPC3_PBUS_CH0_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CH1_CFGDMA 0x0005c200 /* PBus Ch. 1 DMA config */ -#define HPC3_PBUS_CH1_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CH2_CFGDMA 0x0005c400 /* PBus Ch. 2 DMA config */ -#define HPC3_PBUS_CH2_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CH3_CFGDMA 0x0005c600 /* PBus Ch. 3 DMA config */ -#define HPC3_PBUS_CH3_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CH4_CFGDMA 0x0005c800 /* PBus Ch. 4 DMA config */ -#define HPC3_PBUS_CH4_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CH5_CFGDMA 0x0005ca00 /* PBus Ch. 5 DMA config */ -#define HPC3_PBUS_CH5_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CH6_CFGDMA 0x0005cc00 /* PBus Ch. 6 DMA config */ -#define HPC3_PBUS_CH6_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CH7_CFGDMA 0x0005ce00 /* PBus Ch. 7 DMA config */ -#define HPC3_PBUS_CH7_CFGDMA_SIZE 0x01ff - -#define HPC3_PBUS_CFGPIO_REGS 0x0005d000 /* PBus PIO config registers */ -#define HPC3_PBUS_CFGPIO_REGS_SIZE 0x0fff - -#define HPC3_PBUS_CH0_CFGPIO 0x0005d000 /* PBus Ch. 0 PIO config */ -#define HPC3_PBUS_CH1_CFGPIO 0x0005d100 /* PBus Ch. 1 PIO config */ -#define HPC3_PBUS_CH2_CFGPIO 0x0005d200 /* PBus Ch. 2 PIO config */ -#define HPC3_PBUS_CH3_CFGPIO 0x0005d300 /* PBus Ch. 3 PIO config */ -#define HPC3_PBUS_CH4_CFGPIO 0x0005d400 /* PBus Ch. 4 PIO config */ -#define HPC3_PBUS_CH5_CFGPIO 0x0005d500 /* PBus Ch. 5 PIO config */ -#define HPC3_PBUS_CH6_CFGPIO 0x0005d600 /* PBus Ch. 6 PIO config */ -#define HPC3_PBUS_CH7_CFGPIO 0x0005d700 /* PBus Ch. 7 PIO config */ -#define HPC3_PBUS_CH8_CFGPIO 0x0005d800 /* PBus Ch. 8 PIO config */ -#define HPC3_PBUS_CH9_CFGPIO 0x0005d900 /* PBus Ch. 9 PIO config */ -#define HPC3_PBUS_CH8_CFGPIO_2 0x0005da00 /* PBus Ch. 8 PIO config */ -#define HPC3_PBUS_CH9_CFGPIO_2 0x0005db00 /* PBus Ch. 9 PIO config */ -#define HPC3_PBUS_CH8_CFGPIO_3 0x0005dc00 /* PBus Ch. 8 PIO config */ -#define HPC3_PBUS_CH9_CFGPIO_3 0x0005dd00 /* PBus Ch. 9 PIO config */ -#define HPC3_PBUS_CH8_CFGPIO_4 0x0005de00 /* PBus Ch. 8 PIO config */ -#define HPC3_PBUS_CH9_CFGPIO_4 0x0005df00 /* PBus Ch. 9 PIO config */ - -#define HPC3_PBUS_PROM_WE 0x0005e000 /* PBus boot-prom write - * enable register - */ - -#define HPC3_PBUS_PROM_SWAP 0x0005e800 /* PBus boot-prom chip-select - * swap register - */ - -#define HPC3_PBUS_GEN_OUT 0x0005f000 /* PBus general-purpose output - * register - */ - -#define HPC3_PBUS_BBRAM 0x00060000 /* PBus battery-backed RAM - * external registers - */ - -/* HPC1/HPC1.5 differs from HPC3 in several details. */ - -#define HPC1_HDD_CTL_EOCHAIN 0x80000000 /* End of descriptor chain */ -#define HPC1_HDD_CTL_EOPACKET 0x80000000 /* Ethernet: end of packet */ -#define HPC1_HDD_CTL_INTR 0x00008000 /* Interrupt when finished */ -#define HPC1_HDD_CTL_OWN 0x40000000 /* CPU owns this frame */ -#define HPC1_HDD_CTL_BYTECNT(x) ((x) & 0x1fff) /* Byte count: for ethernet */ -#define HPC1_BIGENDIAN 0x000000c0 /* Endianness:5 revision:2 */ -#define HPC1_REVSHIFT 0x00000006 /* Revision rshft */ -#define HPC1_REVMASK 0x00000003 /* Revision mask */ -#define HPC1_REV15 0x00000001 /* HPC Revision 1.5 */ -#define HPC1_SCSI0_REGS 0x00000088 -#define HPC1_SCSI0_REGS_SIZE 0x00000018 -#define HPC1_SCSI0_CBP 0x00000004 /* Current buffer ptr */ -#define HPC1_SCSI0_NDBP 0x00000008 /* Next descriptor ptr */ -#define HPC1_SCSI0_BC 0x00000000 /* DMA byte count & flags */ -#define HPC1_SCSI0_CTL 0x0000000c /* DMA control flags */ -#define HPC1_SCSI0_DEV 0x00000014 /* Device DMA FIFO pointer */ -#define HPC1_SCSI0_DMACFG 0x00000010 /* DMA configuration */ -#define HPC1_SCSI0_GIO 0x00001008 /* GIO DMA FIFO pointer */ -#define HPC1_SCSI0_PIOCFG 0x00001014 /* PIO configuration */ -#define HPC1_SCSI_DMACTL_RESET 0x01 /* Reset dma channel and ext. controller */ -#define HPC1_SCSI_DMACTL_FLUSH 0x02 /* Flush DMA FIFO's */ -#define HPC1_SCSI_DMACTL_DIR 0x10 /* DMA direction: 1=dev->mem, 0=mem->dev */ -#define HPC1_SCSI_DMACTL_ACTIVE 0x80 /* DMA channel is active */ -#define HPC1_ENET_REGS 0x00000000 /* Ethernet registers */ -#define HPC1_ENET_REGS_SIZE 0x00000100 -#define HPC1_ENET_INTDELAY 0x0000002c /* Interrupt Delay Count */ -#define HPC1_ENET_INTDELAY_OFF 0x01000000 /* Disable Interrupt Delay */ -#define HPC1_ENETR_CBP 0x00000054 /* Recv: Current buffer ptr */ -#define HPC1_ENETR_NDBP 0x00000050 /* Recv: Next descriptor ptr */ -#define HPC1_ENETR_BC 0x00000048 /* Recv: DMA byte cnt/flags */ -#define HPC1_ENETR_CTL 0x00000038 /* Recv: DMA control flags */ -#define HPC1_ENETR_CTL_ACTIVE 0x00004000 /* DMA channel active? */ -#define HPC1_ENETR_RESET 0x0000003c /* Recv: Ethernet chip reset */ -#define HPC1_ENETR_RESET_CH 0x0001 /* Reset controller & chan */ -#define HPC1_ENETR_RESET_CLRINT 0x0002 /* Clear channel interrupt */ -#define HPC1_ENETR_RESET_LOOPBK 0x0004 /* External loopback enable */ -#define HPC1_ENETR_RESET_CLRRBO 0x0008 /* Clear RBO condition (??) */ -#define HPC1_ENETX_CBP 0x00000020 /* Xmit: Current buffer ptr */ -#define HPC1_ENETX_NDBP 0x00000010 /* Xmit: Next descriptor ptr */ -#define HPC1_ENETX_CFXBP 0x00000024 /* Xmit: Current first buf */ -#define HPC1_ENETX_PFXBP 0x00000028 /* Xmit: Prev. first buf */ -#define HPC1_ENETX_BC 0x00000014 /* Xmit: DMA byte cnt/flags */ -#define HPC1_ENETX_CTL 0x00000034 /* Xmit: DMA control flags */ -#define HPC1_ENETX_CTL_ACTIVE 0x00400000 -#define HPC1_ENETR_FIFO 0x0002c000 /* Ether recv DMA FIFO */ -#define HPC1_ENETR_FIFO_SIZE 0x00001fff /* Ether recv DMA FIFO size */ -#define HPC1_ENETX_FIFO 0x0002e000 /* Ether xmit DMA FIFO */ -#define HPC1_ENETX_FIFO_SIZE 0x00001fff /* Ether xmit DMA FIFO size */ -#define HPC1_SCSI0_DEVREGS 0x0000011f /* (actually 122) */ -#define HPC1_ENET_DEVREGS 0x00000100 /* Ethernet chip registers */ -#define HPC1_ENET_DEVREGS_SIZE 0x00000020 /* Size of chip registers */ -#define HPC1_PBUS_BBRAM 0x00000e00 /* PBus battery-backed RAM */ -#define HPC1_LPT_REGS 0x000000a8 /* LPT HPC Registers */ -#define HPC1_LPT_REGS_SIZE 0x00000018 -#define HPC1_LPT_BC 0x00000000 /* Byte Count */ -#define HPC1_LPT_CBP 0x00000004 /* Current Buffer Ptr */ -#define HPC1_LPT_NDBP 0x00000008 /* Next Buffer Ptr */ -#define HPC1_LPT_CTL 0x0000000c /* DMA Control Flags */ -#define HPC1_LPT_DEV 0x00000010 /* DMA Fifo Ptr */ -#define HPC1_LPT_DMACFG 0x00000014 /* DMA Configuration */ -#define HPC1_LPT_DEVREGS 0x00000132 /* Ext. Parallel Registers */ -#define HPC1_LPT_DEVREGS_SIZE 0x00000001 /* Size of External Registers */ - -/* AUX regs on the primary HPC */ -#define HPC1_AUX_REGS 0x000001bf /* EEPROM/LED Control (byte) */ -#define HPC1_AUX_CONSLED 0x01 /* Console LED */ diff --git a/sys/arch/sgi/hpc/hpcvar.h b/sys/arch/sgi/hpc/hpcvar.h deleted file mode 100644 index ce938f05dbc..00000000000 --- a/sys/arch/sgi/hpc/hpcvar.h +++ /dev/null @@ -1,123 +0,0 @@ -/* $OpenBSD: hpcvar.h,v 1.10 2015/09/18 20:50:02 miod Exp $ */ -/* $NetBSD: hpcvar.h,v 1.12 2011/01/25 12:21:04 tsutsui Exp $ */ - -/* - * Copyright (c) 2001 Rafal K. Boni - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* HPC 1.5/3 differ a bit, thus we need an abstraction layer */ - -struct hpc_values { - int revision; - uint32_t scsi0_regs; - uint32_t scsi0_regs_size; - uint32_t scsi0_cbp; - uint32_t scsi0_ndbp; - uint32_t scsi0_bc; - uint32_t scsi0_ctl; - uint32_t scsi0_gio; - uint32_t scsi0_dev; - uint32_t scsi0_dmacfg; - uint32_t scsi0_piocfg; - uint32_t scsi1_regs; - uint32_t scsi1_regs_size; - uint32_t scsi1_cbp; - uint32_t scsi1_ndbp; - uint32_t scsi1_bc; - uint32_t scsi1_ctl; - uint32_t scsi1_gio; - uint32_t scsi1_dev; - uint32_t scsi1_dmacfg; - uint32_t scsi1_piocfg; - uint32_t enet_regs; - uint32_t enet_regs_size; - uint32_t enet_intdelay; - uint32_t enet_intdelayval; - uint32_t enetr_cbp; - uint32_t enetr_ndbp; - uint32_t enetr_bc; - uint32_t enetr_ctl; - uint32_t enetr_ctl_active; - uint32_t enetr_reset; - uint32_t enetr_dmacfg; - uint32_t enetr_piocfg; - uint32_t enetx_cbp; - uint32_t enetx_ndbp; - uint32_t enetx_bc; - uint32_t enetx_ctl; - uint32_t enetx_ctl_active; - uint32_t enetx_dev; - uint32_t enetr_fifo; - uint32_t enetr_fifo_size; - uint32_t enetx_fifo; - uint32_t enetx_fifo_size; - uint32_t enet_devregs; - uint32_t enet_devregs_size; - uint32_t pbus_fifo; - uint32_t pbus_fifo_size; - uint32_t pbus_bbram; - uint32_t scsi_dma_segs; - uint32_t scsi_dma_segs_size; - uint32_t scsi_dma_datain_cmd; - uint32_t scsi_dma_dataout_cmd; - uint32_t scsi_dmactl_flush; - uint32_t scsi_dmactl_active; - uint32_t scsi_dmactl_reset; -}; - -struct hpc_attach_args { - const char *ha_name; /* name of device */ - bus_addr_t ha_base; /* address of hpc device */ - bus_addr_t ha_devoff; /* offset of device */ - bus_addr_t ha_dmaoff; /* offset of DMA regs */ - int ha_irq; /* interrupt line */ - - bus_space_tag_t ha_st; /* HPC space tag */ - bus_space_handle_t ha_sh; /* HPC space handle XXX */ - bus_dma_tag_t ha_dmat; /* HPC DMA tag */ - - struct hpc_values *hpc_regs; /* HPC register definitions */ - int ha_giofast; /* GIO bus speed */ - - uint8_t hpc_eeprom[256];/* HPC eeprom contents */ -}; - -void *hpc_intr_establish(int, int, int (*)(void *), void *, const char *); -int hpc_is_intr_pending(int); -void hpc_intr_disable(void *); -void hpc_intr_enable(void *); - -/* - * Routines to copy and update HPC DMA descriptors in uncached memory; - * needed for proper operation on ECC MC systems. - */ -struct hpc_dma_desc; - -struct hpc_dma_desc *hpc_sync_dma_desc(struct hpc_dma_desc *, - struct hpc_dma_desc *); -void hpc_update_dma_desc(struct hpc_dma_desc *, struct hpc_dma_desc *); - -extern bus_space_t hpc3bus_tag; diff --git a/sys/arch/sgi/hpc/if_sq.c b/sys/arch/sgi/hpc/if_sq.c deleted file mode 100644 index 42395c3be6d..00000000000 --- a/sys/arch/sgi/hpc/if_sq.c +++ /dev/null @@ -1,1546 +0,0 @@ -/* $OpenBSD: if_sq.c,v 1.31 2021/03/11 11:17:00 jsg Exp $ */ -/* $NetBSD: if_sq.c,v 1.42 2011/07/01 18:53:47 dyoung Exp $ */ - -/* - * Copyright (c) 2001 Rafal K. Boni - * Copyright (c) 1998, 1999, 2000 The NetBSD Foundation, Inc. - * All rights reserved. - * - * Portions of this code are derived from software contributed to The - * NetBSD Foundation by Jason R. Thorpe of the Numerical Aerospace - * Simulation Facility, NASA Ames Research Center. - * - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -#include "bpfilter.h" - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/timeout.h> -#include <sys/mbuf.h> -#include <sys/pool.h> -#include <sys/kernel.h> -#include <sys/socket.h> -#include <sys/ioctl.h> -#include <sys/errno.h> -#include <sys/syslog.h> - -#include <uvm/uvm_extern.h> - -#include <net/if.h> -#include <net/if_media.h> - -#if NBPFILTER > 0 -#include <net/bpf.h> -#endif - -#include <netinet/in.h> -#include <netinet/if_ether.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> /* guarded_read_4 */ -#include <machine/intr.h> -#include <mips64/arcbios.h> /* bios_enaddr */ -#include <sgi/sgi/ip22.h> - -#include <dev/ic/seeq8003reg.h> - -#include <sgi/hpc/hpcvar.h> -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/iocreg.h> /* IOC_READ / IOC_WRITE */ -#include <sgi/hpc/if_sqvar.h> - -/* - * Short TODO list: - * (1) Do counters for bad-RX packets. - * (2) Allow multi-segment transmits, instead of copying to a single, - * contiguous mbuf. - * (3) Verify sq_stop() turns off enough stuff; I was still getting - * seeq interrupts after sq_stop(). - * (5) Should the driver filter out its own transmissions in non-EDLC - * mode? - * (6) Multicast support -- multicast filter, address management, ... - * (7) Deal with RB0 (recv buffer overflow) on reception. Will need - * to figure out if RB0 is read-only as stated in one spot in the - * HPC spec or read-write (ie, is the 'write a one to clear it') - * the correct thing? - * - * Note that it is no use to implement EDLC auto-padding: the HPC glue will - * not start a packet transfer until it has been fed 64 bytes, which defeats - * the auto-padding purpose. - */ - -#ifdef SQ_DEBUG -int sq_debug = 0; -#define SQ_DPRINTF(x) do { if (sq_debug) printf x; } while (0) -#else -#define SQ_DPRINTF(x) do { } while (0) -#endif - -int sq_match(struct device *, void *, void *); -void sq_attach(struct device *, struct device *, void *); -int sq_init(struct ifnet *); -void sq_start(struct ifnet *); -void sq_stop(struct ifnet *); -void sq_watchdog(struct ifnet *); -int sq_ioctl(struct ifnet *, u_long, caddr_t); - -void sq_set_filter(struct sq_softc *); -int sq_intr(void *); -void sq_rxintr(struct sq_softc *); -void sq_txintr(struct sq_softc *); -void sq_txring_hpc1(struct sq_softc *); -void sq_txring_hpc3(struct sq_softc *); -void sq_reset(struct sq_softc *); -int sq_add_rxbuf(struct sq_softc *, int); -#ifdef SQ_DEBUG -void sq_trace_dump(struct sq_softc *); -#endif - -int sq_ifmedia_change_ip22(struct ifnet *); -int sq_ifmedia_change_singlemedia(struct ifnet *); -void sq_ifmedia_status_ip22(struct ifnet *, struct ifmediareq *); -void sq_ifmedia_status_singlemedia(struct ifnet *, struct ifmediareq *); - -const struct cfattach sq_ca = { - sizeof(struct sq_softc), sq_match, sq_attach -}; - -struct cfdriver sq_cd = { - NULL, "sq", DV_IFNET -}; - -/* XXX these values should be moved to <net/if_ether.h> ? */ -#define ETHER_PAD_LEN (ETHER_MIN_LEN - ETHER_CRC_LEN) - -#define sq_seeq_read(sc, off) \ - bus_space_read_1(sc->sc_regt, sc->sc_regh, ((off) << 2) | 3) -#define sq_seeq_write(sc, off, val) \ - bus_space_write_1(sc->sc_regt, sc->sc_regh, ((off) << 2) | 3, val) - -#define sq_hpc_read(sc, off) \ - bus_space_read_4(sc->sc_hpct, sc->sc_hpch, off) -#define sq_hpc_write(sc, off, val) \ - bus_space_write_4(sc->sc_hpct, sc->sc_hpch, off, val) - -/* MAC address offset for non-onboard implementations */ -#define SQ_HPC_EEPROM_ENADDR 250 - -#define SGI_OUI_0 0x08 -#define SGI_OUI_1 0x00 -#define SGI_OUI_2 0x69 - -int -sq_match(struct device *parent, void *vcf, void *aux) -{ - struct hpc_attach_args *ha = aux; - struct cfdata *cf = vcf; - vaddr_t reset, txstat; - uint32_t dummy; - - if (strcmp(ha->ha_name, cf->cf_driver->cd_name) != 0) - return 0; - - reset = PHYS_TO_XKPHYS(ha->ha_sh + ha->ha_dmaoff + - ha->hpc_regs->enetr_reset, CCA_NC); - txstat = PHYS_TO_XKPHYS(ha->ha_sh + ha->ha_devoff + (SEEQ_TXSTAT << 2), - CCA_NC); - - if (guarded_read_4(reset, &dummy) != 0) - return 0; - - *(volatile uint32_t *)reset = 0x1; - delay(20); - *(volatile uint32_t *)reset = 0x0; - - if (guarded_read_4(txstat, &dummy) != 0) - return 0; - - if ((*(volatile uint32_t *)txstat & 0xff) != TXSTAT_OLDNEW) - return 0; - - return 1; -} - -void -sq_attach(struct device *parent, struct device *self, void *aux) -{ - struct sq_softc *sc = (struct sq_softc *)self; - struct hpc_attach_args *haa = aux; - struct ifnet *ifp = &sc->sc_ac.ac_if; - uint64_t media; - int i, rc; - - sc->sc_hpct = haa->ha_st; - sc->sc_hpcbh = haa->ha_sh; - sc->hpc_regs = haa->hpc_regs; /* HPC register definitions */ - - if ((rc = bus_space_subregion(haa->ha_st, haa->ha_sh, - haa->ha_dmaoff, sc->hpc_regs->enet_regs_size, - &sc->sc_hpch)) != 0) { - printf(": can't map HPC DMA registers, error = %d\n", rc); - goto fail_0; - } - - sc->sc_regt = haa->ha_st; - if ((rc = bus_space_subregion(haa->ha_st, haa->ha_sh, - haa->ha_devoff, sc->hpc_regs->enet_devregs_size, - &sc->sc_regh)) != 0) { - printf(": can't map Seeq registers, error = %d\n", rc); - goto fail_0; - } - - sc->sc_dmat = haa->ha_dmat; - - if ((rc = bus_dmamem_alloc(sc->sc_dmat, sizeof(struct sq_control), - 0, 0, &sc->sc_cdseg, 1, &sc->sc_ncdseg, BUS_DMA_NOWAIT)) != 0) { - printf(": unable to allocate control data, error = %d\n", rc); - goto fail_0; - } - - if ((rc = bus_dmamem_map(sc->sc_dmat, &sc->sc_cdseg, sc->sc_ncdseg, - sizeof(struct sq_control), (caddr_t *)&sc->sc_control, - BUS_DMA_NOWAIT | (ip22_ecc ? 0 : BUS_DMA_COHERENT))) != 0) { - printf(": unable to map control data, error = %d\n", rc); - goto fail_1; - } - - if ((rc = bus_dmamap_create(sc->sc_dmat, - sizeof(struct sq_control), 1, sizeof(struct sq_control), - 0, BUS_DMA_NOWAIT, &sc->sc_cdmap)) != 0) { - printf(": unable to create DMA map for control data, error " - "= %d\n", rc); - goto fail_2; - } - - if ((rc = bus_dmamap_load(sc->sc_dmat, sc->sc_cdmap, - sc->sc_control, sizeof(struct sq_control), NULL, - BUS_DMA_NOWAIT)) != 0) { - printf(": unable to load DMA map for control data, error " - "= %d\n", rc); - goto fail_3; - } - - memset(sc->sc_control, 0, sizeof(struct sq_control)); - - /* Create transmit buffer DMA maps */ - for (i = 0; i < SQ_NTXDESC; i++) { - if ((rc = bus_dmamap_create(sc->sc_dmat, - MCLBYTES, 1, MCLBYTES, 0, - BUS_DMA_NOWAIT, &sc->sc_txmap[i])) != 0) { - printf(": unable to create tx DMA map %d, error = %d\n", - i, rc); - goto fail_4; - } - } - - /* Create receive buffer DMA maps */ - for (i = 0; i < SQ_NRXDESC; i++) { - if ((rc = bus_dmamap_create(sc->sc_dmat, - MCLBYTES, 1, MCLBYTES, 0, - BUS_DMA_NOWAIT, &sc->sc_rxmap[i])) != 0) { - printf(": unable to create rx DMA map %d, error = %d\n", - i, rc); - goto fail_5; - } - } - - /* Pre-allocate the receive buffers. */ - for (i = 0; i < SQ_NRXDESC; i++) { - if ((rc = sq_add_rxbuf(sc, i)) != 0) { - printf(": unable to allocate or map rx buffer %d\n," - " error = %d\n", i, rc); - goto fail_6; - } - } - - bcopy(&haa->hpc_eeprom[SQ_HPC_EEPROM_ENADDR], sc->sc_ac.ac_enaddr, - ETHER_ADDR_LEN); - - /* - * If our mac address is bogus, obtain it from ARCBIOS. This will - * be true of the onboard HPC3 on IP22, since there is no eeprom, - * but rather the DS1386 RTC's battery-backed ram is used. - */ - if (sc->sc_ac.ac_enaddr[0] != SGI_OUI_0 || - sc->sc_ac.ac_enaddr[1] != SGI_OUI_1 || - sc->sc_ac.ac_enaddr[2] != SGI_OUI_2) - enaddr_aton(bios_enaddr, sc->sc_ac.ac_enaddr); - - if ((hpc_intr_establish(haa->ha_irq, IPL_NET, sq_intr, sc, - self->dv_xname)) == NULL) { - printf(": unable to establish interrupt!\n"); - goto fail_6; - } - - /* - * Set up HPC Ethernet PIO and DMA configurations. - * - * The PROM appears to do most of this for the onboard HPC3, but - * not for the Challenge S's IOPLUS chip. We copy how the onboard - * chip is configured and assume that it's correct for both. - */ - if (haa->hpc_regs->revision == 3 && - sys_config.system_subtype != IP22_INDIGO2) { - uint32_t dmareg, pioreg; - - if (haa->ha_giofast) { - pioreg = - HPC3_ENETR_PIOCFG_P1(1) | - HPC3_ENETR_PIOCFG_P2(5) | - HPC3_ENETR_PIOCFG_P3(0); - dmareg = - HPC3_ENETR_DMACFG_D1(5) | - HPC3_ENETR_DMACFG_D2(1) | - HPC3_ENETR_DMACFG_D3(0); - } else { - pioreg = - HPC3_ENETR_PIOCFG_P1(1) | - HPC3_ENETR_PIOCFG_P2(6) | - HPC3_ENETR_PIOCFG_P3(1); - dmareg = - HPC3_ENETR_DMACFG_D1(6) | - HPC3_ENETR_DMACFG_D2(2) | - HPC3_ENETR_DMACFG_D3(0); - } - dmareg |= HPC3_ENETR_DMACFG_FIX_RXDC | - HPC3_ENETR_DMACFG_FIX_INTR | HPC3_ENETR_DMACFG_FIX_EOP | - HPC3_ENETR_DMACFG_TIMEOUT; - - sq_hpc_write(sc, HPC3_ENETR_PIOCFG, pioreg); - sq_hpc_write(sc, HPC3_ENETR_DMACFG, dmareg); - } - - /* Reset the chip to a known state. */ - sq_reset(sc); - - /* - * Determine if we're an 8003 or 80c03 by setting the first - * MAC address register to non-zero, and then reading it back. - * If it's zero, we have an 80c03, because we will have read - * the TxCollLSB register. - */ - sq_seeq_write(sc, SEEQ_TXCOLLS0, 0xa5); - if (sq_seeq_read(sc, SEEQ_TXCOLLS0) == 0) - sc->sc_type = SQ_TYPE_80C03; - else - sc->sc_type = SQ_TYPE_8003; - sq_seeq_write(sc, SEEQ_TXCOLLS0, 0x00); - - printf(": Seeq %s, address %s\n", - sc->sc_type == SQ_TYPE_80C03 ? "80c03" : "8003", - ether_sprintf(sc->sc_ac.ac_enaddr)); - - bcopy(sc->sc_dev.dv_xname, ifp->if_xname, IFNAMSIZ); - ifp->if_softc = sc; - ifp->if_start = sq_start; - ifp->if_ioctl = sq_ioctl; - ifp->if_watchdog = sq_watchdog; - ifp->if_flags = IFF_BROADCAST | IFF_MULTICAST; - - if_attach(ifp); - ifq_set_maxlen(&ifp->if_snd, SQ_NTXDESC - 1); - ether_ifattach(ifp); - - if (haa->hpc_regs->revision == 3) { - uint8_t mask, set; - if (/* sys_config.system_type != SGI_IP20 && */ /* implied */ - sys_config.system_subtype == IP22_CHALLS) { - /* - * Challenge S: onboard has AUI connector only, - * IO+ has TP connector only. - */ - if (haa->ha_base == HPC_BASE_ADDRESS_0) { - ifmedia_init(&sc->sc_ifmedia, 0, - sq_ifmedia_change_singlemedia, - sq_ifmedia_status_singlemedia); - /* - * Force 10Base5. - */ - media = IFM_ETHER | IFM_10_5; - mask = IOC_WRITE_ENET_AUTO; - set = IOC_WRITE_ENET_AUI; - } else { - ifmedia_init(&sc->sc_ifmedia, 0, - sq_ifmedia_change_singlemedia, - sq_ifmedia_status_singlemedia); - /* - * Force 10BaseT, and set the 10BaseT port - * to use UTP cable. - */ - media = IFM_ETHER | IFM_10_T; - mask = set = 0; - } - } else { - /* - * Indy, Indigo 2: onboard has AUI and TP connectors. - */ - ifmedia_init(&sc->sc_ifmedia, 0, - sq_ifmedia_change_ip22, sq_ifmedia_status_ip22); - ifmedia_add(&sc->sc_ifmedia, - IFM_ETHER | IFM_10_5, 0, NULL); - ifmedia_add(&sc->sc_ifmedia, - IFM_ETHER | IFM_10_T, 0, NULL); - - /* - * Force autoselect, and set the 10BaseT port - * to use UTP cable. - */ - media = IFM_ETHER | IFM_AUTO; - mask = IOC_WRITE_ENET_AUI; - set = IOC_WRITE_ENET_AUTO | IOC_WRITE_ENET_UTP; - } - - if (haa->ha_base == HPC_BASE_ADDRESS_0) { - bus_space_write_4(haa->ha_st, haa->ha_sh, - IOC_BASE + IOC_WRITE, - (bus_space_read_4(haa->ha_st, haa->ha_sh, - IOC_BASE + IOC_WRITE) & ~mask) | set); - bus_space_barrier(haa->ha_st, haa->ha_sh, - IOC_BASE + IOC_WRITE, 4, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - } - } else { - /* - * HPC1/1.5: IP20 on-board, or E++: AUI connector only, - * and career information unreliable. - */ - ifmedia_init(&sc->sc_ifmedia, 0, - sq_ifmedia_change_singlemedia, - sq_ifmedia_status_singlemedia); - media = IFM_ETHER | IFM_10_5; - sc->sc_flags |= SQF_NOLINKDOWN; - } - - ifmedia_add(&sc->sc_ifmedia, media, 0, NULL); - ifmedia_set(&sc->sc_ifmedia, media); - - /* supposedly connected, until TX says otherwise */ - sc->sc_flags |= SQF_LINKUP; - - /* Done! */ - return; - - /* - * Free any resources we've allocated during the failed attach - * attempt. Do this in reverse order and fall through. - */ - fail_6: - for (i = 0; i < SQ_NRXDESC; i++) { - if (sc->sc_rxmbuf[i] != NULL) { - bus_dmamap_unload(sc->sc_dmat, sc->sc_rxmap[i]); - m_freem(sc->sc_rxmbuf[i]); - } - } - fail_5: - for (i = 0; i < SQ_NRXDESC; i++) { - if (sc->sc_rxmap[i] != NULL) - bus_dmamap_destroy(sc->sc_dmat, sc->sc_rxmap[i]); - } - fail_4: - for (i = 0; i < SQ_NTXDESC; i++) { - if (sc->sc_txmap[i] != NULL) - bus_dmamap_destroy(sc->sc_dmat, sc->sc_txmap[i]); - } - bus_dmamap_unload(sc->sc_dmat, sc->sc_cdmap); - fail_3: - bus_dmamap_destroy(sc->sc_dmat, sc->sc_cdmap); - fail_2: - bus_dmamem_unmap(sc->sc_dmat, - (void *)sc->sc_control, sizeof(struct sq_control)); - fail_1: - bus_dmamem_free(sc->sc_dmat, &sc->sc_cdseg, sc->sc_ncdseg); - fail_0: - return; -} - -/* Set up data to get the interface up and running. */ -int -sq_init(struct ifnet *ifp) -{ - struct sq_softc *sc = ifp->if_softc; - int i; - - /* Cancel any in-progress I/O */ - sq_stop(ifp); - - sc->sc_nextrx = 0; - - sc->sc_nfreetx = SQ_NTXDESC; - sc->sc_nexttx = sc->sc_prevtx = 0; - - SQ_TRACE(SQ_RESET, sc, 0, 0); - - /* Set into 8003 or 80C03 mode, bank 0 to program Ethernet address */ - if (sc->sc_type == SQ_TYPE_80C03) - sq_seeq_write(sc, SEEQ_TXCMD, TXCMD_ENABLE_C); - sq_seeq_write(sc, SEEQ_TXCMD, TXCMD_BANK0); - - /* Now write the address */ - for (i = 0; i < ETHER_ADDR_LEN; i++) - sq_seeq_write(sc, i, sc->sc_ac.ac_enaddr[i]); - - sc->sc_rxcmd = RXCMD_IE_CRC | RXCMD_IE_DRIB | RXCMD_IE_SHORT | - RXCMD_IE_END | RXCMD_IE_GOOD; - - /* - * Set the receive filter -- this will add some bits to the - * prototype RXCMD register. Do this before setting the - * transmit config register, since we might need to switch - * banks. - */ - sq_set_filter(sc); - - if (sc->sc_type == SQ_TYPE_80C03) { - sq_seeq_write(sc, SEEQ_TXCMD, TXCMD_BANK2); - sq_seeq_write(sc, SEEQ_TXCTRL, 0); - sq_seeq_write(sc, SEEQ_TXCTRL, TXCTRL_SQE | TXCTRL_NOCARR); -#if 0 /* HPC expects a minimal packet size of ETHER_MIN_LEN anyway */ - sq_seeq_write(sc, SEEQ_CFG, CFG_TX_AUTOPAD); -#endif - sq_seeq_write(sc, SEEQ_TXCMD, TXCMD_BANK0); - } - - /* Set up Seeq transmit command register */ - sc->sc_txcmd = - TXCMD_IE_UFLOW | TXCMD_IE_COLL | TXCMD_IE_16COLL | TXCMD_IE_GOOD; - sq_seeq_write(sc, SEEQ_TXCMD, sc->sc_txcmd); - - /* Now write the receive command register. */ - sq_seeq_write(sc, SEEQ_RXCMD, sc->sc_rxcmd); - - /* Pass the start of the receive ring to the HPC */ - sq_hpc_write(sc, sc->hpc_regs->enetr_ndbp, SQ_CDRXADDR(sc, 0)); - - /* And turn on the HPC Ethernet receive channel */ - sq_hpc_write(sc, sc->hpc_regs->enetr_ctl, - sc->hpc_regs->enetr_ctl_active); - - /* - * Turn off delayed receive interrupts on HPC1. - * (see Hollywood HPC Specification 2.1.4.3) - */ - if (sc->hpc_regs->revision != 3) - sq_hpc_write(sc, HPC1_ENET_INTDELAY, HPC1_ENET_INTDELAY_OFF); - - ifp->if_flags |= IFF_RUNNING; - ifq_clr_oactive(&ifp->if_snd); - sq_start(ifp); - - return 0; -} - -void -sq_set_filter(struct sq_softc *sc) -{ - struct arpcom *ac = &sc->sc_ac; - struct ifnet *ifp = &sc->sc_ac.ac_if; - - sc->sc_rxcmd &= ~RXCMD_REC_MASK; - ifp->if_flags &= ~IFF_ALLMULTI; - - /* - * The 8003 has no hash table. If we have any multicast - * addresses on the list, enable reception of all multicast - * frames. - * - * XXX The 80c03 has a hash table. We should use it. - */ - if (ifp->if_flags & IFF_PROMISC || ac->ac_multicnt > 0) { - ifp->if_flags |= IFF_ALLMULTI; - if (ifp->if_flags & IFF_PROMISC) - sc->sc_rxcmd |= RXCMD_REC_ALL; - else - sc->sc_rxcmd |= RXCMD_REC_MULTI; - } - - /* - * Unless otherwise specified, always accept broadcast frames. - */ - if ((sc->sc_rxcmd & RXCMD_REC_MASK) == RXCMD_REC_NONE) - sc->sc_rxcmd |= RXCMD_REC_BROAD; -} - -int -sq_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) -{ - struct sq_softc *sc = ifp->if_softc; - struct ifreq *ifr = (struct ifreq *)data; - int s, error = 0; - - SQ_TRACE(SQ_IOCTL, sc, 0, 0); - - s = splnet(); - - switch (cmd) { - case SIOCSIFADDR: - ifp->if_flags |= IFF_UP; - if (!(ifp->if_flags & IFF_RUNNING)) - sq_init(ifp); - break; - - case SIOCSIFMEDIA: - case SIOCGIFMEDIA: - error = ifmedia_ioctl(ifp, ifr, &sc->sc_ifmedia, cmd); - break; - - case SIOCSIFFLAGS: - if (ifp->if_flags & IFF_UP) { - if (ifp->if_flags & IFF_RUNNING) - error = ENETRESET; - else - sq_init(ifp); - } else { - if (ifp->if_flags & IFF_RUNNING) - sq_stop(ifp); - } - break; - - default: - error = ether_ioctl(ifp, &sc->sc_ac, cmd, data); - break; - } - - if (error == ENETRESET) { - /* - * Multicast list has changed; set the hardware filter - * accordingly. - */ - if (ifp->if_flags & IFF_RUNNING) - error = sq_init(ifp); - else - error = 0; - } - - splx(s); - return error; -} - -void -sq_start(struct ifnet *ifp) -{ - struct sq_softc *sc = ifp->if_softc; - struct mbuf *m0, *m; - struct hpc_dma_desc *txd, *active, store; - bus_dmamap_t dmamap; - uint32_t status; - int err, len, totlen, nexttx, firsttx, lasttx = -1, ofree, seg; - - if (!(ifp->if_flags & IFF_RUNNING) || ifq_is_oactive(&ifp->if_snd)) - return; - - /* - * Remember the previous number of free descriptors and - * the first descriptor we'll use. - */ - ofree = sc->sc_nfreetx; - firsttx = sc->sc_nexttx; - - /* - * Loop through the send queue, setting up transmit descriptors - * until we drain the queue, or use up all available transmit - * descriptors. - */ - while (sc->sc_nfreetx != 0) { - /* - * Grab a packet off the queue. - */ - m0 = ifq_deq_begin(&ifp->if_snd); - if (m0 == NULL) - break; - m = NULL; - - dmamap = sc->sc_txmap[sc->sc_nexttx]; - - /* - * Load the DMA map. If this fails, the packet either - * didn't fit in the allotted number of segments, or we were - * short on resources. In this case, we'll copy and try - * again. - * Also copy it if we need to pad, so that we are sure there - * is room for the pad buffer. - * XXX the right way of doing this is to use a static buffer - * for padding and adding it to the transmit descriptor (see - * sys/dev/pci/if_tl.c for example). We can't do this here yet - * because we can't send packets with more than one fragment. - */ - len = m0->m_pkthdr.len; - if (len < ETHER_PAD_LEN || - bus_dmamap_load_mbuf(sc->sc_dmat, dmamap, m0, - BUS_DMA_NOWAIT) != 0) { - MGETHDR(m, M_DONTWAIT, MT_DATA); - if (m == NULL) { - ifq_deq_rollback(&ifp->if_snd, m0); - printf("%s: unable to allocate Tx mbuf\n", - sc->sc_dev.dv_xname); - break; - } - if (len > MHLEN) { - MCLGET(m, M_DONTWAIT); - if ((m->m_flags & M_EXT) == 0) { - ifq_deq_rollback(&ifp->if_snd, m0); - printf("%s: unable to allocate Tx " - "cluster\n", - sc->sc_dev.dv_xname); - m_freem(m); - break; - } - } - - m_copydata(m0, 0, len, mtod(m, void *)); - if (len < ETHER_PAD_LEN /* && - sc->sc_type != SQ_TYPE_80C03 */) { - memset(mtod(m, char *) + len, 0, - ETHER_PAD_LEN - len); - len = ETHER_PAD_LEN; - } - m->m_pkthdr.len = m->m_len = len; - - if ((err = bus_dmamap_load_mbuf(sc->sc_dmat, dmamap, - m, BUS_DMA_NOWAIT)) != 0) { - ifq_deq_rollback(&ifp->if_snd, m0); - printf("%s: unable to load Tx buffer, " - "error = %d\n", - sc->sc_dev.dv_xname, err); - break; - } - } - - /* - * Ensure we have enough descriptors free to describe - * the packet. - */ - if (dmamap->dm_nsegs > sc->sc_nfreetx) { - ifq_deq_rollback(&ifp->if_snd, m0); - /* - * Not enough free descriptors to transmit this - * packet. We haven't committed to anything yet, - * so just unload the DMA map, put the packet - * back on the queue, and punt. Notify the upper - * layer that there are no more slots left. - * - * XXX We could allocate an mbuf and copy, but - * XXX it is worth it? - */ - ifq_set_oactive(&ifp->if_snd); - bus_dmamap_unload(sc->sc_dmat, dmamap); - m_freem(m); - break; - } - - ifq_deq_commit(&ifp->if_snd, m0); -#if NBPFILTER > 0 - /* - * Pass the packet to any BPF listeners. - */ - if (ifp->if_bpf) - bpf_mtap(ifp->if_bpf, m0, BPF_DIRECTION_OUT); -#endif - if (m != NULL) { - m_freem(m0); - m0 = m; - } - - /* - * WE ARE NOW COMMITTED TO TRANSMITTING THE PACKET. - */ - - SQ_TRACE(SQ_ENQUEUE, sc, sc->sc_nexttx, 0); - - /* Sync the DMA map. */ - bus_dmamap_sync(sc->sc_dmat, dmamap, 0, dmamap->dm_mapsize, - BUS_DMASYNC_PREWRITE); - - /* - * Initialize the transmit descriptors. - */ - for (nexttx = sc->sc_nexttx, seg = 0, totlen = 0; - seg < dmamap->dm_nsegs; - seg++, nexttx = SQ_NEXTTX(nexttx)) { - txd = sc->sc_txdesc + nexttx; - active = hpc_sync_dma_desc(txd, &store); - if (sc->hpc_regs->revision == 3) { - active->hpc3_hdd_bufptr = - dmamap->dm_segs[seg].ds_addr; - active->hpc3_hdd_ctl = - dmamap->dm_segs[seg].ds_len; - } else { - active->hpc1_hdd_bufptr = - dmamap->dm_segs[seg].ds_addr; - active->hpc1_hdd_ctl = - dmamap->dm_segs[seg].ds_len; - } - active->hdd_descptr = SQ_CDTXADDR(sc, SQ_NEXTTX(nexttx)); - hpc_update_dma_desc(txd, active); - lasttx = nexttx; - totlen += dmamap->dm_segs[seg].ds_len; - } - - /* Last descriptor gets end-of-packet */ - KASSERT(lasttx != -1); - txd = sc->sc_txdesc + lasttx; - active = hpc_sync_dma_desc(txd, &store); - if (sc->hpc_regs->revision == 3) - active->hpc3_hdd_ctl |= HPC3_HDD_CTL_EOPACKET; - else - active->hpc1_hdd_ctl |= HPC1_HDD_CTL_EOPACKET; - hpc_update_dma_desc(txd, active); - - SQ_DPRINTF(("%s: transmit %d-%d, len %d\n", - sc->sc_dev.dv_xname, sc->sc_nexttx, lasttx, totlen)); - - if (ifp->if_flags & IFF_DEBUG) { - printf(" transmit chain:\n"); - for (seg = sc->sc_nexttx;; seg = SQ_NEXTTX(seg)) { - active = hpc_sync_dma_desc(&sc->sc_txdesc[seg], - &store); - printf(" descriptor %d:\n", seg); - printf(" hdd_bufptr: 0x%08x\n", - (sc->hpc_regs->revision == 3) ? - active->hpc3_hdd_bufptr : - active->hpc1_hdd_bufptr); - printf(" hdd_ctl: 0x%08x\n", - (sc->hpc_regs->revision == 3) ? - active->hpc3_hdd_ctl: - active->hpc1_hdd_ctl); - printf(" hdd_descptr: 0x%08x\n", - active->hdd_descptr); - - if (seg == lasttx) - break; - } - } - - /* Store a pointer to the packet so we can free it later */ - sc->sc_txmbuf[sc->sc_nexttx] = m0; - - /* Advance the tx pointer. */ - sc->sc_nfreetx -= dmamap->dm_nsegs; - sc->sc_nexttx = nexttx; - } - - /* All transmit descriptors used up, let upper layers know */ - if (sc->sc_nfreetx == 0) - ifq_set_oactive(&ifp->if_snd); - - if (sc->sc_nfreetx != ofree) { - SQ_DPRINTF(("%s: %d packets enqueued, first %d, INTR on %d\n", - sc->sc_dev.dv_xname, lasttx - firsttx + 1, - firsttx, lasttx)); - - /* - * Cause a transmit interrupt to happen on the - * last packet we enqueued, mark it as the last - * descriptor. - * - * HPC1_HDD_CTL_INTR will generate an interrupt on - * HPC1. HPC3 requires HPC3_HDD_CTL_EOCHAIN in - * addition to HPC3_HDD_CTL_INTR to interrupt. - */ - KASSERT(lasttx != -1); - txd = sc->sc_txdesc + lasttx; - active = hpc_sync_dma_desc(txd, &store); - if (sc->hpc_regs->revision == 3) { - active->hpc3_hdd_ctl |= - HPC3_HDD_CTL_INTR | HPC3_HDD_CTL_EOCHAIN; - } else { - active->hpc1_hdd_ctl |= HPC1_HDD_CTL_INTR; - active->hpc1_hdd_bufptr |= HPC1_HDD_CTL_EOCHAIN; - } - hpc_update_dma_desc(txd, active); - - /* - * There is a potential race condition here if the HPC - * DMA channel is active and we try and either update - * the 'next descriptor' pointer in the HPC PIO space - * or the 'next descriptor' pointer in a previous desc- - * riptor. - * - * To avoid this, if the channel is active, we rely on - * the transmit interrupt routine noticing that there - * are more packets to send and restarting the HPC DMA - * engine, rather than mucking with the DMA state here. - */ - status = sq_hpc_read(sc, sc->hpc_regs->enetx_ctl); - - if ((status & sc->hpc_regs->enetx_ctl_active) != 0) { - SQ_TRACE(SQ_ADD_TO_DMA, sc, firsttx, status); - - txd = sc->sc_txdesc + SQ_PREVTX(firsttx); - active = hpc_sync_dma_desc(txd, &store); - /* - * NB: hpc3_hdd_ctl == hpc1_hdd_bufptr, and - * HPC1_HDD_CTL_EOCHAIN == HPC3_HDD_CTL_EOCHAIN - */ - active->hpc3_hdd_ctl &= ~HPC3_HDD_CTL_EOCHAIN; - if (sc->hpc_regs->revision != 3) - active->hpc1_hdd_ctl &= ~HPC1_HDD_CTL_INTR; - - hpc_update_dma_desc(txd, active); - } else if (sc->hpc_regs->revision == 3) { - SQ_TRACE(SQ_START_DMA, sc, firsttx, status); - - sq_hpc_write(sc, HPC3_ENETX_NDBP, SQ_CDTXADDR(sc, - firsttx)); - - /* Kick DMA channel into life */ - sq_hpc_write(sc, HPC3_ENETX_CTL, HPC3_ENETX_CTL_ACTIVE); - } else { - /* - * In the HPC1 case where transmit DMA is - * inactive, we can either kick off if - * the ring was previously empty, or call - * our transmit interrupt handler to - * figure out if the ring stopped short - * and restart at the right place. - */ - if (ofree == SQ_NTXDESC) { - SQ_TRACE(SQ_START_DMA, sc, firsttx, status); - - sq_hpc_write(sc, HPC1_ENETX_NDBP, - SQ_CDTXADDR(sc, firsttx)); - sq_hpc_write(sc, HPC1_ENETX_CFXBP, - SQ_CDTXADDR(sc, firsttx)); - sq_hpc_write(sc, HPC1_ENETX_CBP, - SQ_CDTXADDR(sc, firsttx)); - - /* Kick DMA channel into life */ - sq_hpc_write(sc, HPC1_ENETX_CTL, - HPC1_ENETX_CTL_ACTIVE); - } else - sq_txring_hpc1(sc); - } - - /* Set a watchdog timer in case the chip flakes out. */ - ifp->if_timer = 5; - } -} - -void -sq_stop(struct ifnet *ifp) -{ - struct sq_softc *sc = ifp->if_softc; - int i; - - ifp->if_timer = 0; - ifp->if_flags &= ~IFF_RUNNING; - ifq_clr_oactive(&ifp->if_snd); - - for (i = 0; i < SQ_NTXDESC; i++) { - if (sc->sc_txmbuf[i] != NULL) { - bus_dmamap_unload(sc->sc_dmat, sc->sc_txmap[i]); - m_freem(sc->sc_txmbuf[i]); - sc->sc_txmbuf[i] = NULL; - } - } - - /* Clear Seeq transmit/receive command registers */ - sc->sc_txcmd = 0; - sq_seeq_write(sc, SEEQ_TXCMD, 0); - sq_seeq_write(sc, SEEQ_RXCMD, 0); - - sq_reset(sc); -} - -/* Device timeout/watchdog routine. */ -void -sq_watchdog(struct ifnet *ifp) -{ - struct sq_softc *sc = ifp->if_softc; - uint32_t status; - - status = sq_hpc_read(sc, sc->hpc_regs->enetx_ctl); - log(LOG_ERR, "%s: device timeout (prev %d, next %d, free %d, " - "status %08x)\n", sc->sc_dev.dv_xname, sc->sc_prevtx, - sc->sc_nexttx, sc->sc_nfreetx, status); - -#ifdef SQ_DEBUG - sq_trace_dump(sc); -#endif - - ++ifp->if_oerrors; - - sq_init(ifp); -} - -#ifdef SQ_DEBUG -void -sq_trace_dump(struct sq_softc *sc) -{ - int i; - const char *act; - - for (i = 0; i < sc->sq_trace_idx; i++) { - switch (sc->sq_trace[i].action) { - case SQ_RESET: act = "SQ_RESET"; break; - case SQ_ADD_TO_DMA: act = "SQ_ADD_TO_DMA"; break; - case SQ_START_DMA: act = "SQ_START_DMA"; break; - case SQ_DONE_DMA: act = "SQ_DONE_DMA"; break; - case SQ_RESTART_DMA: act = "SQ_RESTART_DMA"; break; - case SQ_TXINTR_ENTER: act = "SQ_TXINTR_ENTER"; break; - case SQ_TXINTR_EXIT: act = "SQ_TXINTR_EXIT"; break; - case SQ_TXINTR_BUSY: act = "SQ_TXINTR_BUSY"; break; - case SQ_IOCTL: act = "SQ_IOCTL"; break; - case SQ_ENQUEUE: act = "SQ_ENQUEUE"; break; - default: act = "UNKNOWN"; - } - - printf("%s: [%03d] action %-16s buf %03d free %03d " - "status %08x line %d\n", sc->sc_dev.dv_xname, i, act, - sc->sq_trace[i].bufno, sc->sq_trace[i].freebuf, - sc->sq_trace[i].status, sc->sq_trace[i].line); - } - - memset(&sc->sq_trace, 0, sizeof(sc->sq_trace)); - sc->sq_trace_idx = 0; -} -#endif - -int -sq_intr(void *arg) -{ - struct sq_softc *sc = arg; - struct ifnet *ifp = &sc->sc_ac.ac_if; - int oldlink = sc->sc_flags & SQF_LINKUP; - uint32_t stat; - uint8_t sqe; - - stat = sq_hpc_read(sc, sc->hpc_regs->enetr_reset); - - if ((stat & 2) == 0) { - SQ_DPRINTF(("%s: Unexpected interrupt!\n", - sc->sc_dev.dv_xname)); - } else - sq_hpc_write(sc, sc->hpc_regs->enetr_reset, (stat | 2)); - - /* - * If the interface isn't running, the interrupt couldn't - * possibly have come from us. - */ - if ((ifp->if_flags & IFF_RUNNING) == 0) - return 0; - - /* - * Check for loss of carrier detected during transmission if we - * can detect it. - * Unfortunately, this does not work on IP20 and E++ designs. - */ - if (sc->sc_type == SQ_TYPE_80C03 && - !ISSET(sc->sc_flags, SQF_NOLINKDOWN)) { - sqe = sq_seeq_read(sc, SEEQ_SQE) & (SQE_FLAG | SQE_NOCARR); - if (sqe != 0) { - sq_seeq_write(sc, SEEQ_TXCMD, - TXCMD_BANK2 | sc->sc_txcmd); - /* reset counters */ - sq_seeq_write(sc, SEEQ_TXCTRL, 0); - sq_seeq_write(sc, SEEQ_TXCTRL, - TXCTRL_SQE | TXCTRL_NOCARR); - sq_seeq_write(sc, SEEQ_TXCMD, - TXCMD_BANK0 | sc->sc_txcmd); - if (sqe == (SQE_FLAG | SQE_NOCARR)) - sc->sc_flags &= ~SQF_LINKUP; - } - } - - /* Always check for received packets */ - sq_rxintr(sc); - - /* Only handle transmit interrupts if we actually sent something */ - if (sc->sc_nfreetx < SQ_NTXDESC) - sq_txintr(sc); - - /* Notify link status change */ - if (oldlink != (sc->sc_flags & SQF_LINKUP)) { - if (oldlink != 0) { - ifp->if_link_state = LINK_STATE_DOWN; - ifp->if_baudrate = 0; - } else { - ifp->if_link_state = LINK_STATE_UP; - ifp->if_baudrate = IF_Mbps(10); - } - if_link_state_change(ifp); - } - - /* - * XXX Always claim the interrupt, even if we did nothing. - * XXX There seem to be extra interrupts when the receiver becomes - * XXX idle. - */ - return 1; -} - -void -sq_rxintr(struct sq_softc *sc) -{ - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct mbuf_list ml = MBUF_LIST_INITIALIZER(); - struct mbuf* m; - struct hpc_dma_desc *rxd, *active, store; - int i, framelen; - uint8_t pktstat; - uint32_t status; - uint32_t ctl_reg; - int new_end, orig_end; - - for (i = sc->sc_nextrx; ; i = SQ_NEXTRX(i)) { - rxd = sc->sc_rxdesc + i; - active = hpc_sync_dma_desc(rxd, &store); - /* - * If this is a CPU-owned buffer, we're at the end of the list. - */ - if (sc->hpc_regs->revision == 3) - ctl_reg = active->hpc3_hdd_ctl & HPC3_HDD_CTL_OWN; - else - ctl_reg = active->hpc1_hdd_ctl & HPC1_HDD_CTL_OWN; - - if (ctl_reg) { -#if defined(SQ_DEBUG) - uint32_t reg; - - reg = sq_hpc_read(sc, sc->hpc_regs->enetr_ctl); - SQ_DPRINTF(("%s: rxintr: done at %d (ctl %08x)\n", - sc->sc_dev.dv_xname, i, reg)); -#endif - break; - } - - m = sc->sc_rxmbuf[i]; - framelen = m->m_ext.ext_size - 3; - if (sc->hpc_regs->revision == 3) - framelen -= - HPC3_HDD_CTL_BYTECNT(active->hpc3_hdd_ctl); - else - framelen -= - HPC1_HDD_CTL_BYTECNT(active->hpc1_hdd_ctl); - - /* Now sync the actual packet data */ - bus_dmamap_sync(sc->sc_dmat, sc->sc_rxmap[i], 0, - sc->sc_rxmap[i]->dm_mapsize, BUS_DMASYNC_POSTREAD); - - pktstat = *((uint8_t *)m->m_data + framelen + 2); - - if ((pktstat & RXSTAT_GOOD) == 0) { - ifp->if_ierrors++; - - if (pktstat & RXSTAT_OFLOW) - printf("%s: receive FIFO overflow\n", - sc->sc_dev.dv_xname); - - bus_dmamap_sync(sc->sc_dmat, sc->sc_rxmap[i], 0, - sc->sc_rxmap[i]->dm_mapsize, BUS_DMASYNC_PREREAD); - SQ_INIT_RXDESC(sc, i); - SQ_DPRINTF(("%s: sq_rxintr: buf %d no RXSTAT_GOOD\n", - sc->sc_dev.dv_xname, i)); - continue; - } - - /* Link must be good if we have received data. */ - sc->sc_flags |= SQF_LINKUP; - - if (sq_add_rxbuf(sc, i) != 0) { - ifp->if_ierrors++; - bus_dmamap_sync(sc->sc_dmat, sc->sc_rxmap[i], 0, - sc->sc_rxmap[i]->dm_mapsize, BUS_DMASYNC_PREREAD); - SQ_INIT_RXDESC(sc, i); - SQ_DPRINTF(("%s: sq_rxintr: buf %d sq_add_rxbuf() " - "failed\n", sc->sc_dev.dv_xname, i)); - continue; - } - - - m->m_data += 2; - m->m_pkthdr.len = m->m_len = framelen; - - SQ_DPRINTF(("%s: sq_rxintr: buf %d len %d\n", - sc->sc_dev.dv_xname, i, framelen)); - - ml_enqueue(&ml, m); - } - - if_input(ifp, &ml); - - /* If anything happened, move ring start/end pointers to new spot */ - if (i != sc->sc_nextrx) { - new_end = SQ_PREVRX(i); - rxd = sc->sc_rxdesc + new_end; - active = hpc_sync_dma_desc(rxd, &store); - /* - * NB: hpc3_hdd_ctl == hpc1_hdd_bufptr, and - * HPC1_HDD_CTL_EOCHAIN == HPC3_HDD_CTL_EOCHAIN - */ - active->hpc3_hdd_ctl |= HPC3_HDD_CTL_EOCHAIN; - hpc_update_dma_desc(rxd, active); - - orig_end = SQ_PREVRX(sc->sc_nextrx); - rxd = sc->sc_rxdesc + orig_end; - active = hpc_sync_dma_desc(rxd, &store); - active->hpc3_hdd_ctl &= ~HPC3_HDD_CTL_EOCHAIN; - hpc_update_dma_desc(rxd, active); - - sc->sc_nextrx = i; - } - - status = sq_hpc_read(sc, sc->hpc_regs->enetr_ctl); - - /* If receive channel is stopped, restart it... */ - if ((status & sc->hpc_regs->enetr_ctl_active) == 0) { - /* Pass the start of the receive ring to the HPC */ - sq_hpc_write(sc, sc->hpc_regs->enetr_ndbp, - SQ_CDRXADDR(sc, sc->sc_nextrx)); - - /* And turn on the HPC Ethernet receive channel */ - sq_hpc_write(sc, sc->hpc_regs->enetr_ctl, - sc->hpc_regs->enetr_ctl_active); - } -} - -void -sq_txintr(struct sq_softc *sc) -{ - struct ifnet *ifp = &sc->sc_ac.ac_if; - uint shift = 0; - uint32_t status, tmp; - - if (sc->hpc_regs->revision != 3) - shift = 16; - - status = sq_hpc_read(sc, sc->hpc_regs->enetx_ctl) >> shift; - - SQ_TRACE(SQ_TXINTR_ENTER, sc, sc->sc_prevtx, status); - - tmp = (sc->hpc_regs->enetx_ctl_active >> shift) | TXSTAT_GOOD; - if ((status & tmp) == 0) { - if (status & TXSTAT_COLL) - ifp->if_collisions++; - - if (status & TXSTAT_UFLOW) { - printf("%s: transmit underflow\n", - sc->sc_dev.dv_xname); - ifp->if_oerrors++; -#ifdef SQ_DEBUG - sq_trace_dump(sc); -#endif - sq_init(ifp); - return; - } - - if (status & TXSTAT_16COLL) { - if (ifp->if_flags & IFF_DEBUG) - printf("%s: max collisions reached\n", - sc->sc_dev.dv_xname); - ifp->if_oerrors++; - ifp->if_collisions += 16; - } - } - - /* prevtx now points to next xmit packet not yet finished */ - if (sc->hpc_regs->revision == 3) - sq_txring_hpc3(sc); - else - sq_txring_hpc1(sc); - - /* If we have buffers free, let upper layers know */ - if (sc->sc_nfreetx > 0) - ifq_clr_oactive(&ifp->if_snd); - - /* If all packets have left the coop, cancel watchdog */ - if (sc->sc_nfreetx == SQ_NTXDESC) - ifp->if_timer = 0; - - SQ_TRACE(SQ_TXINTR_EXIT, sc, sc->sc_prevtx, status); - sq_start(ifp); -} - -/* - * Reclaim used transmit descriptors and restart the transmit DMA - * engine if necessary. - */ -void -sq_txring_hpc1(struct sq_softc *sc) -{ - /* - * HPC1 doesn't tag transmitted descriptors, however, - * the NDBP register points to the next descriptor that - * has not yet been processed. If DMA is not in progress, - * we can safely reclaim all descriptors up to NDBP, and, - * if necessary, restart DMA at NDBP. Otherwise, if DMA - * is active, we can only safely reclaim up to CBP. - * - * For now, we'll only reclaim on inactive DMA and assume - * that a sufficiently large ring keeps us out of trouble. - */ - struct ifnet *ifp = &sc->sc_ac.ac_if; - uint32_t reclaimto, status; - int reclaimall, i = sc->sc_prevtx; - - status = sq_hpc_read(sc, HPC1_ENETX_CTL); - if (status & HPC1_ENETX_CTL_ACTIVE) { - SQ_TRACE(SQ_TXINTR_BUSY, sc, i, status); - return; - } else - reclaimto = sq_hpc_read(sc, HPC1_ENETX_NDBP); - - if (sc->sc_nfreetx == 0 && SQ_CDTXADDR(sc, i) == reclaimto) - reclaimall = 1; - else - reclaimall = 0; - - while (sc->sc_nfreetx < SQ_NTXDESC) { - if (SQ_CDTXADDR(sc, i) == reclaimto && !reclaimall) - break; - - /* Sync the packet data, unload DMA map, free mbuf */ - bus_dmamap_sync(sc->sc_dmat, sc->sc_txmap[i], - 0, sc->sc_txmap[i]->dm_mapsize, BUS_DMASYNC_POSTWRITE); - bus_dmamap_unload(sc->sc_dmat, sc->sc_txmap[i]); - m_freem(sc->sc_txmbuf[i]); - sc->sc_txmbuf[i] = NULL; - - sc->sc_nfreetx++; - - SQ_TRACE(SQ_DONE_DMA, sc, i, status); - - i = SQ_NEXTTX(i); - } - - if (sc->sc_nfreetx < SQ_NTXDESC) { - SQ_TRACE(SQ_RESTART_DMA, sc, i, status); - - KASSERT(reclaimto == SQ_CDTXADDR(sc, i)); - - sq_hpc_write(sc, HPC1_ENETX_CFXBP, reclaimto); - sq_hpc_write(sc, HPC1_ENETX_CBP, reclaimto); - - /* Kick DMA channel into life */ - sq_hpc_write(sc, HPC1_ENETX_CTL, HPC1_ENETX_CTL_ACTIVE); - - /* - * Set a watchdog timer in case the chip - * flakes out. - */ - ifp->if_timer = 5; - } - - sc->sc_prevtx = i; -} - -/* - * Reclaim used transmit descriptors and restart the transmit DMA - * engine if necessary. - */ -void -sq_txring_hpc3(struct sq_softc *sc) -{ - /* - * HPC3 tags descriptors with a bit once they've been - * transmitted. We need only free each XMITDONE'd - * descriptor, and restart the DMA engine if any - * descriptors are left over. - */ - struct ifnet *ifp = &sc->sc_ac.ac_if; - struct hpc_dma_desc *txd, *active, store; - int i; - uint32_t status = 0; - - i = sc->sc_prevtx; - while (sc->sc_nfreetx < SQ_NTXDESC) { - /* - * Check status first so we don't end up with a case of - * the buffer not being finished while the DMA channel - * has gone idle. - */ - status = sq_hpc_read(sc, HPC3_ENETX_CTL); - - txd = sc->sc_txdesc + i; - active = hpc_sync_dma_desc(txd, &store); - - /* Check for used descriptor and restart DMA chain if needed */ - if ((active->hpc3_hdd_ctl & HPC3_HDD_CTL_XMITDONE) == 0) { - if ((status & HPC3_ENETX_CTL_ACTIVE) == 0) { - SQ_TRACE(SQ_RESTART_DMA, sc, i, status); - - sq_hpc_write(sc, HPC3_ENETX_NDBP, - SQ_CDTXADDR(sc, i)); - - /* Kick DMA channel into life */ - sq_hpc_write(sc, HPC3_ENETX_CTL, - HPC3_ENETX_CTL_ACTIVE); - - /* - * Set a watchdog timer in case the chip - * flakes out. - */ - ifp->if_timer = 5; - } else - SQ_TRACE(SQ_TXINTR_BUSY, sc, i, status); - break; - } - - /* Sync the packet data, unload DMA map, free mbuf */ - bus_dmamap_sync(sc->sc_dmat, sc->sc_txmap[i], - 0, sc->sc_txmap[i]->dm_mapsize, BUS_DMASYNC_POSTWRITE); - bus_dmamap_unload(sc->sc_dmat, sc->sc_txmap[i]); - m_freem(sc->sc_txmbuf[i]); - sc->sc_txmbuf[i] = NULL; - - sc->sc_nfreetx++; - - SQ_TRACE(SQ_DONE_DMA, sc, i, status); - i = SQ_NEXTTX(i); - } - - sc->sc_prevtx = i; -} - -void -sq_reset(struct sq_softc *sc) -{ - /* Stop HPC dma channels */ - sq_hpc_write(sc, sc->hpc_regs->enetr_ctl, 0); - sq_hpc_write(sc, sc->hpc_regs->enetx_ctl, 0); - - sq_hpc_write(sc, sc->hpc_regs->enetr_reset, 3); - delay(20); - sq_hpc_write(sc, sc->hpc_regs->enetr_reset, 0); -} - -/* sq_add_rxbuf: Add a receive buffer to the indicated descriptor. */ -int -sq_add_rxbuf(struct sq_softc *sc, int idx) -{ - int err; - struct mbuf *m; - - MGETHDR(m, M_DONTWAIT, MT_DATA); - if (m == NULL) - return ENOBUFS; - - MCLGET(m, M_DONTWAIT); - if ((m->m_flags & M_EXT) == 0) { - m_freem(m); - return ENOBUFS; - } - - if (sc->sc_rxmbuf[idx] != NULL) - bus_dmamap_unload(sc->sc_dmat, sc->sc_rxmap[idx]); - - sc->sc_rxmbuf[idx] = m; - - if ((err = bus_dmamap_load(sc->sc_dmat, sc->sc_rxmap[idx], - m->m_ext.ext_buf, m->m_ext.ext_size, NULL, BUS_DMA_NOWAIT)) != 0) { - printf("%s: can't load rx DMA map %d, error = %d\n", - sc->sc_dev.dv_xname, idx, err); - panic("sq_add_rxbuf"); /* XXX */ - } - - bus_dmamap_sync(sc->sc_dmat, sc->sc_rxmap[idx], - 0, sc->sc_rxmap[idx]->dm_mapsize, BUS_DMASYNC_PREREAD); - - SQ_INIT_RXDESC(sc, idx); - - return 0; -} - -/* - * Media handling - */ - -int -sq_ifmedia_change_ip22(struct ifnet *ifp) -{ - struct sq_softc *sc = ifp->if_softc; - struct ifmedia *ifm = &sc->sc_ifmedia; - uint32_t iocw; - - iocw = - bus_space_read_4(sc->sc_hpct, sc->sc_hpcbh, IOC_BASE + IOC_WRITE); - - switch (IFM_SUBTYPE(ifm->ifm_media)) { - case IFM_10_5: - iocw &= ~IOC_WRITE_ENET_AUTO; - iocw |= IOC_WRITE_ENET_AUI; - break; - case IFM_10_T: - iocw &= ~(IOC_WRITE_ENET_AUTO | IOC_WRITE_ENET_AUI); - iocw |= IOC_WRITE_ENET_UTP; /* in case it cleared */ - break; - default: - case IFM_AUTO: - iocw |= IOC_WRITE_ENET_AUTO; - break; - } - - bus_space_write_4(sc->sc_hpct, sc->sc_hpcbh, IOC_BASE + IOC_WRITE, - iocw); - bus_space_barrier(sc->sc_hpct, sc->sc_hpcbh, IOC_BASE + IOC_WRITE, 4, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - return 0; -} - -int -sq_ifmedia_change_singlemedia(struct ifnet *ifp) -{ - return 0; -} - -void -sq_ifmedia_status_ip22(struct ifnet *ifp, struct ifmediareq *req) -{ - struct sq_softc *sc = ifp->if_softc; - uint32_t iocr, iocw; - - iocw = - bus_space_read_4(sc->sc_hpct, sc->sc_hpcbh, IOC_BASE + IOC_WRITE); - - req->ifm_status = IFM_AVALID; - if (sc->sc_flags & SQF_LINKUP) - req->ifm_status |= IFM_ACTIVE; - if ((iocw & IOC_WRITE_ENET_AUTO) != 0) { - iocr = bus_space_read_4(sc->sc_hpct, sc->sc_hpcbh, - IOC_BASE + IOC_READ); - if ((iocr & IOC_READ_ENET_LINK) != 0) - req->ifm_active = IFM_10_5 | IFM_ETHER; - else - req->ifm_active = IFM_10_T | IFM_ETHER; - } else { - if ((iocw & IOC_WRITE_ENET_AUI) != 0) - req->ifm_active = IFM_10_5 | IFM_ETHER; - else - req->ifm_active = IFM_10_T | IFM_ETHER; - } -} - -void -sq_ifmedia_status_singlemedia(struct ifnet *ifp, struct ifmediareq *req) -{ - struct sq_softc *sc = ifp->if_softc; - struct ifmedia *ifm = &sc->sc_ifmedia; - - req->ifm_status = IFM_AVALID; - if (sc->sc_flags & SQF_LINKUP) - req->ifm_status |= IFM_ACTIVE; - req->ifm_active = ifm->ifm_media; -} diff --git a/sys/arch/sgi/hpc/if_sqvar.h b/sys/arch/sgi/hpc/if_sqvar.h deleted file mode 100644 index ab83035e577..00000000000 --- a/sys/arch/sgi/hpc/if_sqvar.h +++ /dev/null @@ -1,189 +0,0 @@ -/* $OpenBSD: if_sqvar.h,v 1.6 2015/09/18 20:50:02 miod Exp $ */ -/* $NetBSD: sqvar.h,v 1.12 2011/01/25 13:12:39 tsutsui Exp $ */ - -/* - * Copyright (c) 2001 Rafal K. Boni - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* Note, these must be powers of two for the magic NEXT/PREV macros to work */ -#define SQ_NRXDESC 64 -#define SQ_NTXDESC 64 - -#define SQ_NRXDESC_MASK (SQ_NRXDESC - 1) -#define SQ_NEXTRX(x) ((x + 1) & SQ_NRXDESC_MASK) -#define SQ_PREVRX(x) ((x - 1) & SQ_NRXDESC_MASK) - -#define SQ_NTXDESC_MASK (SQ_NTXDESC - 1) -#define SQ_NEXTTX(x) ((x + 1) & SQ_NTXDESC_MASK) -#define SQ_PREVTX(x) ((x - 1) & SQ_NTXDESC_MASK) - -/* - * We pack all DMA control structures into one container so we can alloc just - * one chunk of DMA-safe memory and pack them into it. Otherwise, we'd have to - * allocate a page for each descriptor, since the bus_dmamem_alloc() interface - * does not allow us to allocate smaller chunks. - */ -struct sq_control { - /* Receive descriptors */ - struct hpc_dma_desc rx_desc[SQ_NRXDESC]; - - /* Transmit descriptors */ - struct hpc_dma_desc tx_desc[SQ_NTXDESC]; -}; - -#define SQ_CDOFF(x) offsetof(struct sq_control, x) -#define SQ_CDTXOFF(x) SQ_CDOFF(tx_desc[(x)]) -#define SQ_CDRXOFF(x) SQ_CDOFF(rx_desc[(x)]) - -#define SQ_TYPE_8003 0 -#define SQ_TYPE_80C03 1 - -/* Trace Actions */ -#define SQ_RESET 1 -#define SQ_ADD_TO_DMA 2 -#define SQ_START_DMA 3 -#define SQ_DONE_DMA 4 -#define SQ_RESTART_DMA 5 -#define SQ_TXINTR_ENTER 6 -#define SQ_TXINTR_EXIT 7 -#define SQ_TXINTR_BUSY 8 -#define SQ_IOCTL 9 -#define SQ_ENQUEUE 10 - -struct sq_action_trace { - int action; - int line; - int bufno; - int status; - int freebuf; -}; - -#ifdef SQ_DEBUG -#define SQ_TRACEBUF_SIZE 100 - -#define SQ_TRACE(act, sc, buf, stat) do { \ - (sc)->sq_trace[(sc)->sq_trace_idx].action = (act); \ - (sc)->sq_trace[(sc)->sq_trace_idx].line = __LINE__; \ - (sc)->sq_trace[(sc)->sq_trace_idx].bufno = (buf); \ - (sc)->sq_trace[(sc)->sq_trace_idx].status = (stat); \ - (sc)->sq_trace[(sc)->sq_trace_idx].freebuf = (sc)->sc_nfreetx; \ - if (++(sc)->sq_trace_idx == SQ_TRACEBUF_SIZE) \ - (sc)->sq_trace_idx = 0; \ -} while (/* CONSTCOND */0) -#else -#define SQ_TRACE(act, sc, buf, stat) do { } while (/* CONSTCOND */0) -#endif - -struct sq_softc { - struct device sc_dev; - - /* HPC registers */ - bus_space_tag_t sc_hpct; - bus_space_handle_t sc_hpcbh; /* HPC base, for IOC access */ - bus_space_handle_t sc_hpch; - - /* HPC external Ethernet registers: aka Seeq 8003 registers */ - bus_space_tag_t sc_regt; - bus_space_handle_t sc_regh; - - bus_dma_tag_t sc_dmat; - - struct arpcom sc_ac; - uint8_t sc_enaddr[ETHER_ADDR_LEN]; - struct ifmedia sc_ifmedia; - - int sc_type; - int sc_flags; -#define SQF_LINKUP 0x00000001 -#define SQF_NOLINKDOWN 0x00000002 - - struct sq_control* sc_control; -#define sc_rxdesc sc_control->rx_desc -#define sc_txdesc sc_control->tx_desc - - /* DMA structures for control data (DMA RX/TX descriptors) */ - int sc_ncdseg; - bus_dma_segment_t sc_cdseg; - bus_dmamap_t sc_cdmap; -#define sc_cddma sc_cdmap->dm_segs[0].ds_addr - - int sc_nextrx; - - /* DMA structures for RX packet data */ - bus_dma_segment_t sc_rxseg[SQ_NRXDESC]; - bus_dmamap_t sc_rxmap[SQ_NRXDESC]; - struct mbuf* sc_rxmbuf[SQ_NRXDESC]; - - int sc_nexttx; - int sc_prevtx; - int sc_nfreetx; - - /* DMA structures for TX packet data */ - bus_dma_segment_t sc_txseg[SQ_NTXDESC]; - bus_dmamap_t sc_txmap[SQ_NTXDESC]; - struct mbuf* sc_txmbuf[SQ_NTXDESC]; - - uint8_t sc_txcmd; /* current value of TXCMD */ - uint8_t sc_rxcmd; /* prototype rxcmd */ - - struct hpc_values *hpc_regs; /* HPC register definitions */ - -#ifdef SQ_DEBUG - int sq_trace_idx; - struct sq_action_trace sq_trace[SQ_TRACEBUF_SIZE]; -#endif -}; - -#define SQ_CDTXADDR(sc, x) ((sc)->sc_cddma + SQ_CDTXOFF((x))) -#define SQ_CDRXADDR(sc, x) ((sc)->sc_cddma + SQ_CDRXOFF((x))) - -static inline void -SQ_INIT_RXDESC(struct sq_softc *sc, unsigned int x) -{ - struct hpc_dma_desc *__rxd, *__active, __store; - struct mbuf *__m = (sc)->sc_rxmbuf[(x)]; - - __rxd = &(sc)->sc_rxdesc[(x)]; - __active = hpc_sync_dma_desc(__rxd, &__store); - __m->m_data = __m->m_ext.ext_buf; - if (sc->hpc_regs->revision == 3) { - __active->hpc3_hdd_bufptr = - (sc)->sc_rxmap[(x)]->dm_segs[0].ds_addr; - __active->hpc3_hdd_ctl = __m->m_ext.ext_size | - HPC3_HDD_CTL_OWN | HPC3_HDD_CTL_INTR | - HPC3_HDD_CTL_EOPACKET | - ((x) == (SQ_NRXDESC - 1) ? HPC3_HDD_CTL_EOCHAIN : 0); - } else { - __active->hpc1_hdd_bufptr = - (sc)->sc_rxmap[(x)]->dm_segs[0].ds_addr | - ((x) == (SQ_NRXDESC - 1) ? HPC1_HDD_CTL_EOCHAIN : 0); - __active->hpc1_hdd_ctl = __m->m_ext.ext_size | - HPC1_HDD_CTL_OWN | HPC1_HDD_CTL_INTR | - HPC1_HDD_CTL_EOPACKET; - } - __active->hdd_descptr = SQ_CDRXADDR((sc), SQ_NEXTRX((x))); - hpc_update_dma_desc(__rxd, __active); -} diff --git a/sys/arch/sgi/hpc/iocreg.h b/sys/arch/sgi/hpc/iocreg.h deleted file mode 100644 index ca5eace2939..00000000000 --- a/sys/arch/sgi/hpc/iocreg.h +++ /dev/null @@ -1,125 +0,0 @@ -/* $OpenBSD: iocreg.h,v 1.2 2012/04/08 22:08:25 miod Exp $ */ -/* $NetBSD: iocreg.h,v 1.2 2005/12/11 12:18:53 christos Exp $ */ - -/* - * Copyright (c) 2003 Christopher Sekiya - * Copyright (c) 2001 Rafal K. Boni - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * IOC1/2 memory map. - * - * The IOC1/2 is connected to the HPC#0, PBus channel 6, so these registers - * are based from the external register window for PBus channel 6 on HPC#0. - * - */ - -#define IOC_BASE HPC3_PBUS_CH6_DEVREGS - -#define IOC_PLP_REGS 0x00 /* Parallel port registers */ -#define IOC_PLP_REGS_SIZE 0x2c - -#define IOC_PLP_DATA 0x00 /* Data register */ -#define IOC_PLP_CTL 0x04 /* Control register */ -#define IOC_PLP_STAT 0x08 /* Status register */ -#define IOC_PLP_DMACTL 0x0c /* DMA control register */ -#define IOC_PLP_INTSTAT 0x10 /* Interrupt status register */ -#define IOC_PLP_INTMASK 0x14 /* Interrupt mask register */ -#define IOC_PLP_TIMER1 0x18 /* Timer 1 register */ -#define IOC_PLP_TIMER2 0x1c /* Timer 2 register */ -#define IOC_PLP_TIMER3 0x20 /* Timer 3 register */ -#define IOC_PLP_TIMER4 0x24 /* Timer 4 register */ - -#define IOC_SERIAL_REGS 0x30 /* Serial port registers */ -#define IOC_SERIAL_REGS_SIZE 0x0c - -#define IOC_SERIAL_PORT1_CMD 0x00 /* Port 1 command transfer */ -#define IOC_SERIAL_PORT1_DATA 0x04 /* Port 1 data transfer */ -#define IOC_SERIAL_PORT2_CMD 0x08 /* Port 2 command transfer */ -#define IOC_SERIAL_PORT2_DATA 0x0c /* Port 2 data transfer */ - -#define IOC_KB_REGS 0x40 /* Keyboard/mouse registers */ -#define IOC_KB_REGS_SIZE 0x08 - -/* Miscellaneous registers */ - -#define IOC_MISC_REGS 0x48 /* Misc. IOC regs */ -#define IOC_MISC_REGS_SIZE 0x34 - -#define IOC_GCSEL 0x48 /* General select register */ - -#define IOC_GCREG 0x4c /* General control register */ -#define IOC_GCREG_GIO_33MHZ 0x08 - -#define IOC_PANEL 0x50 /* Front Panel register */ -#define IOC_PANEL_POWER_STATE 0x01 -#define IOC_PANEL_POWER_IRQ 0x02 -#define IOC_PANEL_VDOWN_IRQ 0x10 -#define IOC_PANEL_VDOWN_HOLD 0x20 -#define IOC_PANEL_VUP_IRQ 0x40 -#define IOC_PANEL_VUP_HOLD 0x80 - -#define IOC_SYSID 0x58 /* System ID register */ -#define IOC_SYSID_SYSTYPE 0x01 /* 0: Sapphire, 1: Full House */ -#define IOC_SYSID_BOARDREV 0x1e -#define IOC_SYSID_BOARDREV_SHIFT 1 -#define IOC_SYSID_CHIPREV 0xe0 -#define IOC_SYSID_CHIPREV_SHIFT 5 - -#define IOC_READ 0x60 /* Read register */ -#define IOC_READ_SCSI0_POWER 0x10 -#define IOC_READ_SCSI1_POWER 0x20 -#define IOC_READ_ENET_POWER 0x40 -#define IOC_READ_ENET_LINK 0x80 - -#define IOC_DMASEL 0x68 /* DMA select register */ -#define IOC_DMASEL_ISDN_B 0x01 -#define IOC_DMASEL_ISDN_A 0x02 -#define IOC_DMASEL_PARALLEL 0x04 -#define IOC_DMASEL_SERIAL_10MHZ 0x00 -#define IOC_DMASEL_SERIAL_6MHZ 0x10 -#define IOC_DMASEL_SERIAL_EXTERNAL 0x20 - -#define IOC_RESET 0x70 /* Reset (IP24) / Write 1 (IP22) - register */ -#define IOC_RESET_PARALLEL 0x01 -#define IOC_RESET_PCKBC 0x02 -#define IOC_RESET_EISA 0x04 -#define IOC_RESET_ISDN 0x08 -#define IOC_RESET_LED_GREEN 0x10 -#define IOC_RESET_LED_RED 0x20 -#define IOC_RESET_LED_ORANGE 0x40 - -#define IOC_WRITE 0x78 /* Write (IP24) / Write 2 (IP22) - register */ -#define IOC_WRITE_ENET_NTH 0x01 -#define IOC_WRITE_ENET_UTP 0x02 -#define IOC_WRITE_ENET_AUI 0x04 -#define IOC_WRITE_ENET_AUTO 0x08 -#define IOC_WRITE_PC_UART2 0x10 -#define IOC_WRITE_PC_UART1 0x20 -#define IOC_WRITE_MARGIN_LOW 0x40 -#define IOC_WRITE_MARGIN_HIGH 0x80 diff --git a/sys/arch/sgi/hpc/makemap.awk b/sys/arch/sgi/hpc/makemap.awk deleted file mode 100644 index 3c5a7ebb2bf..00000000000 --- a/sys/arch/sgi/hpc/makemap.awk +++ /dev/null @@ -1,335 +0,0 @@ -#! /usr/bin/awk -f -# $OpenBSD: makemap.awk,v 1.1 2014/05/22 19:39:37 miod Exp $ -# -# Copyright (c) 2005, 2014, Miodrag Vallat -# -# 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 ``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 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. -# -# -# This script attempts to convert, with minimal hacks and losses, the -# regular PS/2 keyboard (pckbd) layout tables into SGI serial keyboard (zskbd) -# layout tables. -# - -BEGIN { - rcsid = "$OpenBSD: makemap.awk,v 1.1 2014/05/22 19:39:37 miod Exp $" - ifdepth = 0 - ignore = 0 - haskeys = 0 - summary = 0 - - # PS/2 -> SGI conversion table - for (i = 0; i < 256; i++) - conv[i] = -1 - - conv[1] = 6 - conv[2] = 7 - conv[3] = 13 - conv[4] = 14 - conv[5] = 21 - conv[6] = 22 - conv[7] = 29 - conv[8] = 30 - conv[9] = 37 - conv[10] = 38 - conv[11] = 45 - conv[12] = 46 - conv[13] = 53 - conv[14] = 60 - conv[15] = 8 - conv[16] = 9 - conv[17] = 15 - conv[18] = 16 - conv[19] = 23 - conv[20] = 24 - conv[21] = 31 - conv[22] = 32 - conv[23] = 39 - conv[24] = 40 - conv[25] = 47 - conv[26] = 48 - conv[27] = 55 - conv[28] = 50 - conv[29] = 2 - conv[30] = 10 - conv[31] = 11 - conv[32] = 17 - conv[33] = 18 - conv[34] = 25 - conv[35] = 26 - conv[36] = 33 - conv[37] = 34 - conv[38] = 41 - conv[39] = 42 - conv[40] = 49 - conv[41] = 54 - conv[42] = 5 - conv[43] = 56 - conv[44] = 19 - conv[45] = 20 - conv[46] = 27 - conv[47] = 28 - conv[48] = 35 - conv[49] = 36 - conv[50] = 43 - conv[51] = 44 - conv[52] = 51 - conv[53] = 52 - conv[54] = 4 - conv[55] = 108 - conv[56] = 83 - conv[57] = 82 - conv[58] = 3 - conv[59] = 86 - conv[60] = 87 - conv[61] = 88 - conv[62] = 89 - conv[63] = 90 - conv[64] = 91 - conv[65] = 92 - conv[66] = 93 - conv[67] = 94 - conv[68] = 95 - conv[69] = 106 - conv[70] = 99 - conv[71] = 66 - conv[72] = 67 - conv[73] = 74 - conv[74] = 75 - conv[75] = 62 - conv[76] = 68 - conv[77] = 69 - conv[78] = 109 - conv[79] = 57 - conv[80] = 63 - conv[81] = 64 - conv[82] = 58 - conv[83] = 65 - conv[86] = 111 - conv[87] = 96 - conv[88] = 97 - conv[127] = 100 - conv[156] = 81 - conv[157] = 85 - conv[170] = 98 - conv[181] = 107 - conv[183] = 98 - conv[184] = 84 - conv[199] = 102 - conv[200] = 80 - conv[201] = 103 - conv[203] = 72 - conv[205] = 79 - conv[207] = 104 - conv[208] = 73 - conv[209] = 105 - conv[210] = 101 - conv[211] = 61 -} -NR == 1 { - VERSION = $0 - gsub("\\$", "", VERSION) - gsub("\\$", "", rcsid) - - printf("/*\t\$OpenBSD\$\t*/\n\n") - printf("/*\n") - printf(" * THIS FILE IS AUTOMAGICALLY GENERATED. DO NOT EDIT.\n") - printf(" *\n") - printf(" * generated by:\n") - printf(" *\t%s\n", rcsid) - printf(" * generated from:\n") - printf(" */\n") - print VERSION - - next -} - -# -# A very limited #if ... #endif parser. We only want to correctly detect -# ``#if 0'' constructs, so as not to process their contents. This is necessary -# since our output is out-of-order from our input. -# -# Note that this does NOT handle ``#ifdef notyet'' correctly - please only use -# ``#if 0'' constructs in the input. -# - -/^#if/ { - ignores[ifdepth] = ignore - if ($2 == "0") - ignore = 1 - #else - # ignore = 0 - ifdepth++ - if (ignore) - next -} -/^#endif/ { - oldignore = ignore - ifdepth-- - ignore = ignores[ifdepth] - ignores[ifdepth] = 0 - if (oldignore) - next -} - -$1 == "#include" { - if (ignore) - next - if ($2 == "<dev/pckbc/wskbdmap_mfii.h>") - next - printf("#include %s\n", $2) - next -} -$1 == "#define" || $1 == "#undef" { - if (ignore) - next - print $0 - next -} - -/pckbd/ { - gsub("pckbd", "zskbd", $0) -} -/zskbd_keydesctab/ { - gsub("zskbd", "wssgi", $0) -} - -/zskbd_keydesc_/ { - mapname = substr($0, index($0, "zskbd_keydesc_") + length("zskbd_keydesc_")) - sub("\\[\\].*", "", mapname) - sub("\\).*", "", mapname) - shortname = mapname - sub("_nodead", "", shortname) # _nodead ok if main layout ok - if (shortname != "be" && - shortname != "de" && - shortname != "dk" && - shortname != "es" && - shortname != "fi" && # missing from PS/2 source... - shortname != "fr" && - shortname != "gr" && # missing from PS/2 source... - shortname != "it" && - shortname != "nl" && - shortname != "no" && - shortname != "pt" && - shortname != "sf" && - shortname != "sg" && - shortname != "sv" && - shortname != "uk" && - shortname != "us") { - nolayout = 1 - } -} - -/zskbd_keydesc_.*\[\]/ { - if (nolayout) - printf("/* %s not applicable */\n", mapname) -} - -/KC/ { - if (ignore) - next - - if (nolayout) - next - - haskeys = 1 - - sidx = substr($1, 4, length($1) - 5) - orig = int(sidx) - id = conv[orig] - - if (id == -1) { - # printf("/* initially KC(%d),", orig) - # for (f = 2; f <= NF; f++) { - # if ($f != "/*" && $f != "*/") - # printf("\t%s", $f) - # } - # printf("\t*/\n") - } else { - lines[id] = sprintf(" KC(%d),\t", id) - # - # This makes sure that the non-comment part of the output - # ends up with a trailing comma. This is necessary since - # the last line of an input block might not have a trailing - # comma, but might not be the last line of an output block - # due to sorting. - # - comma = 0 - for (f = 2; f <= NF; f++) { - l = length($f) - if ($f == "/*") - comma++ - if (comma == 0 && substr($f, l) != ",") { - lines[id] = sprintf("%s%s,", lines[id], $f) - l++ - } else { - lines[id] = sprintf("%s%s", lines[id], $f) - } - if (comma == 0 && f != NF) { - if (l < 2 * 8) - lines[id] = lines[id] "\t" - if (l < 8) - lines[id] = lines[id] "\t" - } - if ($f == "*/") - comma-- - } - } - - next -} -/};/ { - if (ignore) - next - - if (nolayout) { - nolayout = 0 - next - } - - if (haskeys) { - for (i = 0; i < 256; i++) - if (lines[i]) { - print lines[i] - lines[i] = "" - } - - haskeys = 0 - } -} -/KBD_MAP/ { - summary = 1 -} -# hack to eat two line KBD_MAP() - we want to ignore all of them, and -# the second line will get rejected because ``nolayout'' will be set. -/KBD_MAP[^)]*,$/ { next } - -{ - if (ignore) - next - if (nolayout) { - if (summary) - nolayout = 0 - next - } - print $0 -} diff --git a/sys/arch/sgi/hpc/panel.c b/sys/arch/sgi/hpc/panel.c deleted file mode 100644 index b4fdc9dca61..00000000000 --- a/sys/arch/sgi/hpc/panel.c +++ /dev/null @@ -1,226 +0,0 @@ -/* $OpenBSD: panel.c,v 1.3 2014/07/11 08:18:31 guenther Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/proc.h> -#include <sys/signalvar.h> -#include <sys/timeout.h> - -#include <machine/autoconf.h> -#include <mips64/archtype.h> -#include <machine/bus.h> - -#include <sgi/hpc/iocreg.h> -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/hpcvar.h> - -#include <sgi/sgi/ip22.h> - -#include "audio.h" -#include "wskbd.h" -extern int wskbd_set_mixervolume(long, long); - -struct panel_softc { - struct device sc_dev; - bus_space_tag_t sc_iot; - bus_space_handle_t sc_ioh; - int sc_irq; /* irq number */ - void *sc_ih; /* irq handler cookie */ - struct timeout sc_repeat_tmo; /* polling timeout */ -}; - -/* Repeat delays for volume buttons. */ -#define PANEL_REPEAT_FIRST 400 -#define PANEL_REPEAT_NEXT 100 - -int panel_match(struct device *, void *, void *); -void panel_attach(struct device *, struct device *, void *); - -struct cfdriver panel_cd = { - NULL, "panel", DV_DULL -}; - -const struct cfattach panel_ca = { - sizeof(struct panel_softc), panel_match, panel_attach -}; - -int panel_intr(void *); -void panel_repeat(void *); -#if NAUDIO > 0 && NWSKBD > 0 -void panel_volume_adjust(struct panel_softc *, uint8_t); -#endif - -int -panel_match(struct device *parent, void *vcf, void *aux) -{ - struct cfdata *cf = vcf; - struct hpc_attach_args *ha = aux; - - if (strcmp(ha->ha_name, cf->cf_driver->cd_name) != 0) - return 0; - - if (sys_config.system_type == SGI_IP20) - return 0; - - return 1; -} - -void -panel_attach(struct device *parent, struct device *self, void *aux) -{ - struct panel_softc *sc = (struct panel_softc *)self; - struct hpc_attach_args *haa = aux; - - sc->sc_iot = haa->ha_st; - if (bus_space_subregion(haa->ha_st, haa->ha_sh, haa->ha_devoff + 3, 1, - &sc->sc_ioh)) { - printf(": can't map registers\n"); - return; - } - - sc->sc_irq = haa->ha_irq; - sc->sc_ih = hpc_intr_establish(sc->sc_irq, IPL_BIO, panel_intr, sc, - sc->sc_dev.dv_xname); - if (sc->sc_ih == NULL) { - printf(": can't establish interrupt\n"); - return; - } - - if (sys_config.system_subtype == IP22_INDY) - printf(": power and volume buttons\n"); - else - printf(": power button\n"); - - timeout_set(&sc->sc_repeat_tmo, panel_repeat, sc); -} - -int -panel_intr(void *v) -{ - struct panel_softc *sc = (struct panel_softc *)v; - uint8_t reg, ack; - extern int allowpowerdown; - - reg = bus_space_read_1(sc->sc_iot, sc->sc_ioh, 0); - - ack = IOC_PANEL_POWER_STATE; - if (sys_config.system_subtype == IP22_INDIGO2 || - (reg & IOC_PANEL_POWER_IRQ) == 0) - ack |= IOC_PANEL_POWER_IRQ; - if (sys_config.system_subtype == IP22_INDY) { - if ((reg & IOC_PANEL_VDOWN_IRQ) == 0) - ack |= IOC_PANEL_VDOWN_IRQ; - if ((reg & IOC_PANEL_VUP_IRQ) == 0) - ack |= IOC_PANEL_VUP_IRQ; - } - bus_space_write_1(sc->sc_iot, sc->sc_ioh, 0, ack); - bus_space_barrier(sc->sc_iot, sc->sc_ioh, 0, 1, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - - /* - * Panel interrupts are latched for about 300 msec after being - * acked, and not until all buttons are depressed. - * We need to temporary disable the interrupt and switch to polling, - * until the interrupt can be enabled again. - */ - hpc_intr_disable(sc->sc_ih); - - /* - * If the power button is down, try and issue a shutdown immediately - * (if allowed). - */ - if (sys_config.system_subtype == IP22_INDIGO2 || - (reg & IOC_PANEL_POWER_IRQ) == 0) { - if (allowpowerdown == 1) { - allowpowerdown = 0; - prsignal(initprocess, SIGUSR2); - } - } - -#if NAUDIO > 0 && NWSKBD > 0 - /* - * If any of the volume buttons is down, update volume. - */ - if (sys_config.system_subtype == IP22_INDY) - panel_volume_adjust(sc, reg); -#endif - - timeout_add_msec(&sc->sc_repeat_tmo, PANEL_REPEAT_FIRST); - - return 1; -} - -void -panel_repeat(void *v) -{ - struct panel_softc *sc = (struct panel_softc *)v; - uint8_t reg; - - reg = bus_space_read_1(sc->sc_iot, sc->sc_ioh, 0); - -#if NAUDIO > 0 && NWSKBD > 0 - /* - * Volume button autorepeat. - */ - if (sys_config.system_subtype == IP22_INDY) - panel_volume_adjust(sc, reg); -#endif - - if (hpc_is_intr_pending(sc->sc_irq)) { - /* - * Keep acking everything to get the interrupt finally - * unlatched. - */ - bus_space_write_1(sc->sc_iot, sc->sc_ioh, 0, - IOC_PANEL_POWER_STATE | IOC_PANEL_POWER_IRQ | - IOC_PANEL_VDOWN_IRQ | IOC_PANEL_VDOWN_HOLD | - IOC_PANEL_VUP_IRQ | IOC_PANEL_VUP_HOLD); - bus_space_barrier(sc->sc_iot, sc->sc_ioh, 0, 1, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - - timeout_add_msec(&sc->sc_repeat_tmo, PANEL_REPEAT_NEXT); - } else { - hpc_intr_enable(sc->sc_ih); - } -} - -#if NAUDIO > 0 && NWSKBD > 0 -void -panel_volume_adjust(struct panel_softc *sc, uint8_t reg) -{ - long adjust; - - switch (reg & (IOC_PANEL_VDOWN_IRQ | IOC_PANEL_VUP_IRQ)) { - case 0: /* both buttons pressed: mute */ - adjust = 0; - break; - case IOC_PANEL_VDOWN_IRQ: /* up button pressed */ - adjust = 1; - break; - case IOC_PANEL_VDUP_IRQ: /* down button pressed */ - adjust = -1; - break; - case IOC_PANEL_VDOWN_IRQ | IOC_PANEL_VDUP_IRQ: - return; - } - - wskbd_set_mixervolume(adjust, 1); -} -#endif diff --git a/sys/arch/sgi/hpc/pckbc_hpc.c b/sys/arch/sgi/hpc/pckbc_hpc.c deleted file mode 100644 index 4140ee3d08a..00000000000 --- a/sys/arch/sgi/hpc/pckbc_hpc.c +++ /dev/null @@ -1,117 +0,0 @@ -/* $OpenBSD: pckbc_hpc.c,v 1.4 2015/05/24 10:57:47 miod Exp $ */ -/* $NetBSD: pckbc_hpc.c,v 1.9 2008/03/15 13:23:24 cube Exp $ */ - -/* - * Copyright (c) 2003 Christopher SEKIYA - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for the - * NetBSD Project. See http://www.NetBSD.org/ for - * information about NetBSD. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/malloc.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/hpcvar.h> -#include <sgi/sgi/ip22.h> - -#include <dev/ic/i8042reg.h> -#include <dev/ic/pckbcvar.h> - -int pckbc_hpc_match(struct device *, void *, void *); -void pckbc_hpc_attach(struct device *, struct device *, void *); - -const struct cfattach pckbc_hpc_ca = { - sizeof(struct pckbc_softc), pckbc_hpc_match, pckbc_hpc_attach -}; - -int -pckbc_hpc_match(struct device *parent, void *vcf, void *aux) -{ - struct cfdata *cf = vcf; - struct hpc_attach_args *ha = aux; - - /* keyboard controller is not wired on Challenge S */ - if (sys_config.system_subtype == IP22_CHALLS) - return 0; - - if (strcmp(ha->ha_name, cf->cf_driver->cd_name) == 0) - return 1; - - return 0; -} - -void -pckbc_hpc_attach(struct device *parent, struct device * self, void *aux) -{ - struct pckbc_softc *sc = (struct pckbc_softc *)self; - struct hpc_attach_args *haa = aux; - struct pckbc_internal *t = NULL; - bus_space_handle_t ioh_d, ioh_c; - int console; - - if (hpc_intr_establish(haa->ha_irq, IPL_TTY, pckbcintr, sc, - sc->sc_dv.dv_xname) == NULL) { - printf(": unable to establish interrupt\n"); - return; - } - - console = pckbc_is_console(haa->ha_st, - XKPHYS_TO_PHYS(haa->ha_sh + haa->ha_devoff + 3)); - - if (console) { - /* pckbc_cnattach() has already been called */ - t = &pckbc_consdata; - pckbc_console_attached = 1; - } else { - if (bus_space_subregion(haa->ha_st, haa->ha_sh, - haa->ha_devoff + 3 + KBDATAP, 1, &ioh_d) || - bus_space_subregion(haa->ha_st, haa->ha_sh, - haa->ha_devoff + 3 + KBCMDP, 1, &ioh_c)) { - printf(": couldn't map registers\n"); - return; - } - - t = malloc(sizeof(*t), M_DEVBUF, M_NOWAIT | M_ZERO); - t->t_iot = haa->ha_st; - t->t_ioh_c = ioh_c; - t->t_ioh_d = ioh_d; - } - - t->t_cmdbyte = KC8_CPU; - t->t_sc = sc; - sc->id = t; - - printf("\n"); - pckbc_attach(sc, 0); -} diff --git a/sys/arch/sgi/hpc/wdsc.c b/sys/arch/sgi/hpc/wdsc.c deleted file mode 100644 index 385f7073a7f..00000000000 --- a/sys/arch/sgi/hpc/wdsc.c +++ /dev/null @@ -1,285 +0,0 @@ -/* $OpenBSD: wdsc.c,v 1.7 2020/02/05 16:29:29 krw Exp $ */ -/* $NetBSD: wdsc.c,v 1.32 2011/07/01 18:53:47 dyoung Exp $ */ - -/* - * Copyright (c) 2001 Wayne Knowles - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Wayne Knowles - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the NetBSD - * Foundation, Inc. and its contributors. - * 4. Neither the name of The NetBSD Foundation nor the names of its - * contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * - * 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/buf.h> -#include <sys/timeout.h> - -#include <scsi/scsi_all.h> -#include <scsi/scsiconf.h> - -#include <machine/bus.h> -#include <machine/cpu.h> - -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/hpcvar.h> -#include <sgi/hpc/hpcdma.h> - -#include <dev/ic/wd33c93reg.h> -#include <dev/ic/wd33c93var.h> - -struct wdsc_softc { - struct wd33c93_softc sc_wd33c93; /* Must be first */ - bus_dma_tag_t sc_dmat; - bus_dmamap_t sc_dmamap; - int sc_flags; -#define WDSC_DMA_ACTIVE 0x1 -#define WDSC_DMA_MAPLOADED 0x2 - struct hpc_dma_softc sc_hpcdma; -}; - -int wdsc_match(struct device *, void *, void *); -void wdsc_attach(struct device *, struct device *, void *); - -const struct cfattach wdsc_ca = { - sizeof(struct wdsc_softc), wdsc_match, wdsc_attach -}; - -struct cfdriver wdsc_cd = { - NULL, "wdsc", DV_DULL -}; - -int wdsc_dmasetup(struct wd33c93_softc *, void **, ssize_t *, int, - ssize_t *); -int wdsc_dmago(struct wd33c93_softc *); -void wdsc_dmastop(struct wd33c93_softc *); -void wdsc_reset(struct wd33c93_softc *); - -struct scsi_adapter wdsc_switch = { - wd33c93_scsi_cmd, NULL, NULL, NULL, NULL -}; - -/* - * Match for SCSI devices on the onboard and GIO32 adapter WD33C93 chips - */ -int -wdsc_match(struct device *parent, void *vcf, void *aux) -{ - struct hpc_attach_args *haa = aux; - struct cfdata *cf = vcf; - vaddr_t reset, asr; - uint32_t dummy; - uint8_t reg; - - if (strcmp(haa->ha_name, cf->cf_driver->cd_name) != 0) - return 0; - - reset = PHYS_TO_XKPHYS(haa->ha_sh + haa->ha_dmaoff + - haa->hpc_regs->scsi0_ctl, CCA_NC); - if (guarded_read_4(reset, &dummy) != 0) - return 0; - *(volatile uint32_t *)reset = haa->hpc_regs->scsi_dmactl_reset; - delay(1000); - *(volatile uint32_t *)reset = 0x0; - delay(1000); - - asr = PHYS_TO_XKPHYS(haa->ha_sh + haa->ha_devoff + 3, CCA_NC); - if (guarded_read_1(asr, ®) != 0) - return 0; - if ((reg & 0xff) != SBIC_ASR_INT) - return 0; - - return 1; -} - -/* - * Attach the wdsc driver - */ -void -wdsc_attach(struct device *parent, struct device *self, void *aux) -{ - struct wdsc_softc *wsc = (struct wdsc_softc *)self; - struct wd33c93_softc *sc = &wsc->sc_wd33c93; - struct hpc_attach_args *haa = aux; - int err; - - sc->sc_regt = haa->ha_st; - wsc->sc_dmat = haa->ha_dmat; - - wsc->sc_hpcdma.hpc = haa->hpc_regs; - - if ((err = bus_space_subregion(haa->ha_st, haa->ha_sh, - haa->ha_devoff + 3, 1, &sc->sc_asr_regh)) != 0) { - printf(": unable to map asr reg, err=%d\n", err); - return; - } - - if ((err = bus_space_subregion(haa->ha_st, haa->ha_sh, - haa->ha_devoff + 3 + 4, 1, &sc->sc_data_regh)) != 0) { - printf(": unable to map data reg, err=%d\n", err); - return; - } - - if (bus_dmamap_create(wsc->sc_dmat, MAXPHYS, - wsc->sc_hpcdma.hpc->scsi_dma_segs, - wsc->sc_hpcdma.hpc->scsi_dma_segs_size, - wsc->sc_hpcdma.hpc->scsi_dma_segs_size, - BUS_DMA_WAITOK, &wsc->sc_dmamap) != 0) { - printf(": failed to create dmamap\n"); - return; - } - - sc->sc_dmasetup = wdsc_dmasetup; - sc->sc_dmago = wdsc_dmago; - sc->sc_dmastop = wdsc_dmastop; - sc->sc_reset = wdsc_reset; - - sc->sc_id = 0; /* Host ID = 0 */ - sc->sc_clkfreq = 200; /* 20MHz */ - sc->sc_dmamode = SBIC_CTL_BURST_DMA; - - if (hpc_intr_establish(haa->ha_irq, IPL_BIO, - wd33c93_intr, wsc, self->dv_xname) == NULL) { - printf(": unable to establish interrupt!\n"); - return; - } - - hpcdma_init(haa, &wsc->sc_hpcdma, wsc->sc_hpcdma.hpc->scsi_dma_segs); - wd33c93_attach(sc, &wdsc_switch); -} - -/* - * Prime the hardware for a DMA transfer - * - * Requires splbio() interrupts to be disabled by the caller - */ -int -wdsc_dmasetup(struct wd33c93_softc *sc, void **addr, ssize_t *len, int datain, - ssize_t *dmasize) -{ - struct wdsc_softc *wsc = (struct wdsc_softc *)sc; - struct hpc_dma_softc *dsc = &wsc->sc_hpcdma; - ssize_t count; - int err; - void *vaddr; - - KASSERT((wsc->sc_flags & WDSC_DMA_ACTIVE) == 0); - - vaddr = *addr; - dsc->sc_dlen = count = *len; - if (count) { - KASSERT((wsc->sc_flags & WDSC_DMA_MAPLOADED) == 0); - - /* Build list of physical addresses for this transfer */ - if ((err = bus_dmamap_load(wsc->sc_dmat, wsc->sc_dmamap, - vaddr, count, NULL /* kernel address */, - BUS_DMA_NOWAIT)) != 0) - panic("%s: bus_dmamap_load err=%d", - sc->sc_dev.dv_xname, err); - - hpcdma_sglist_create(dsc, wsc->sc_dmamap); - wsc->sc_flags |= WDSC_DMA_MAPLOADED; - - if (datain) { - dsc->sc_dmacmd = - wsc->sc_hpcdma.hpc->scsi_dma_datain_cmd; - dsc->sc_flags |= HPCDMA_READ; - } else { - dsc->sc_dmacmd = - wsc->sc_hpcdma.hpc->scsi_dma_dataout_cmd; - dsc->sc_flags &= ~HPCDMA_READ; - } - } - return count; -} - -/* - * Prime the hardware for the next DMA transfer - */ -int -wdsc_dmago(struct wd33c93_softc *sc) -{ - struct wdsc_softc *wsc = (struct wdsc_softc *)sc; - struct hpc_dma_softc *dsc = &wsc->sc_hpcdma; - - if (dsc->sc_dlen == 0) - return 0; - - KASSERT((wsc->sc_flags & WDSC_DMA_ACTIVE) == 0); - KASSERT((wsc->sc_flags & WDSC_DMA_MAPLOADED)); - - wsc->sc_flags |= WDSC_DMA_ACTIVE; - - bus_dmamap_sync(wsc->sc_dmat, wsc->sc_dmamap, - 0, wsc->sc_dmamap->dm_mapsize, - (dsc->sc_flags & HPCDMA_READ) ? - BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE); - - hpcdma_cntl(dsc, dsc->sc_dmacmd); /* Thunderbirds are go! */ - - return wsc->sc_dmamap->dm_mapsize; -} - -/* - * Stop DMA and unload active DMA maps - */ -void -wdsc_dmastop(struct wd33c93_softc *sc) -{ - struct wdsc_softc *wsc = (struct wdsc_softc *)sc; - struct hpc_dma_softc *dsc = &wsc->sc_hpcdma; - - if (wsc->sc_flags & WDSC_DMA_ACTIVE) { - if (dsc->sc_flags & HPCDMA_READ) - hpcdma_flush(dsc); - hpcdma_cntl(dsc, 0); /* Stop DMA */ - bus_dmamap_sync(wsc->sc_dmat, wsc->sc_dmamap, - 0, wsc->sc_dmamap->dm_mapsize, - (dsc->sc_flags & HPCDMA_READ) ? - BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE); - } - if (wsc->sc_flags & WDSC_DMA_MAPLOADED) - bus_dmamap_unload(wsc->sc_dmat, wsc->sc_dmamap); - wsc->sc_flags &= ~(WDSC_DMA_ACTIVE | WDSC_DMA_MAPLOADED); -} - -/* - * Reset the controller. - */ -void -wdsc_reset(struct wd33c93_softc *sc) -{ - struct wdsc_softc *wsc = (struct wdsc_softc *)sc; - struct hpc_dma_softc *dsc = &wsc->sc_hpcdma; - - hpcdma_reset(dsc); -} diff --git a/sys/arch/sgi/hpc/wskbdmap_sgi.c b/sys/arch/sgi/hpc/wskbdmap_sgi.c deleted file mode 100644 index 04c72c3a955..00000000000 --- a/sys/arch/sgi/hpc/wskbdmap_sgi.c +++ /dev/null @@ -1,588 +0,0 @@ -/* $OpenBSD: wskbdmap_sgi.c,v 1.4 2019/05/13 12:31:56 abieber Exp $ */ - -/* - * THIS FILE IS AUTOMAGICALLY GENERATED. DO NOT EDIT. - * - * generated by: - * OpenBSD: makemap.awk,v 1.1 2014/05/22 19:39:37 miod Exp - * generated from: - */ -/* OpenBSD: wskbdmap_mfii.c,v 1.46 2019/05/11 14:19:16 abieber Exp */ -/* $NetBSD: wskbdmap_mfii.c,v 1.15 2000/05/19 16:40:04 drochner Exp $ */ - -/* - * PLEASE DO NOT FORGET TO REGEN - * sys/dev/usb/ukbdmap.c - * sys/arch/sgi/hpc/wskbdmap_sgi.c - * AFTER ANY CHANGES TO THIS FILE! - */ - -/*- - * Copyright (c) 1997 The NetBSD Foundation, Inc. - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Juergen Hannken-Illjes. - * - * 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. - */ - -#include <sys/types.h> -#include <dev/wscons/wsksymdef.h> -#include <dev/wscons/wsksymvar.h> - -#define KC(n) KS_KEYCODE(n) - -static const keysym_t zskbd_keydesc_us[] = { -/* pos command normal shifted */ - KC(2), KS_Cmd1, KS_Control_L, - KC(3), KS_Caps_Lock, - KC(4), KS_Shift_R, - KC(5), KS_Shift_L, - KC(6), KS_Cmd_Debugger,KS_Escape, - KC(7), KS_1, KS_exclam, - KC(8), KS_Tab, - KC(9), KS_q, - KC(10), KS_a, - KC(11), KS_s, - KC(13), KS_2, KS_at, - KC(14), KS_3, KS_numbersign, - KC(15), KS_w, - KC(16), KS_e, - KC(17), KS_d, - KC(18), KS_f, - KC(19), KS_z, - KC(20), KS_x, - KC(21), KS_4, KS_dollar, - KC(22), KS_5, KS_percent, - KC(23), KS_r, - KC(24), KS_t, - KC(25), KS_g, - KC(26), KS_h, - KC(27), KS_c, - KC(28), KS_v, - KC(29), KS_6, KS_asciicircum, - KC(30), KS_7, KS_ampersand, - KC(31), KS_y, - KC(32), KS_u, - KC(33), KS_j, - KC(34), KS_k, - KC(35), KS_b, - KC(36), KS_n, - KC(37), KS_8, KS_asterisk, - KC(38), KS_9, KS_parenleft, - KC(39), KS_i, - KC(40), KS_o, - KC(41), KS_l, - KC(42), KS_semicolon, KS_colon, - KC(43), KS_m, - KC(44), KS_comma, KS_less, - KC(45), KS_0, KS_parenright, - KC(46), KS_minus, KS_underscore, - KC(47), KS_p, - KC(48), KS_bracketleft, KS_braceleft, - KC(49), KS_apostrophe, KS_quotedbl, - KC(50), KS_Return, - KC(51), KS_period, KS_greater, - KC(52), KS_slash, KS_question, - KC(53), KS_equal, KS_plus, - KC(54), KS_grave, KS_asciitilde, - KC(55), KS_bracketright,KS_braceright, - KC(56), KS_backslash, KS_bar, - KC(57), KS_KP_End, KS_KP_1, - KC(58), KS_KP_Insert, KS_KP_0, - KC(60), KS_Cmd_ResetEmul,KS_Delete, - KC(61), KS_Cmd_KbdReset,KS_KP_Delete, - KC(62), KS_KP_Left, KS_KP_4, - KC(63), KS_KP_Down, KS_KP_2, - KC(64), KS_KP_Next, KS_KP_3, - KC(65), KS_KP_Delete, KS_KP_Decimal, - KC(66), KS_KP_Home, KS_KP_7, - KC(67), KS_KP_Up, KS_KP_8, - KC(68), KS_KP_Begin, KS_KP_5, - KC(69), KS_KP_Right, KS_KP_6, - KC(72), KS_Left, - KC(73), KS_Down, - KC(74), KS_KP_Prior, KS_KP_9, - KC(75), KS_KP_Subtract, - KC(79), KS_Right, - KC(80), KS_Up, - KC(81), KS_KP_Enter, - KC(82), KS_space, - KC(83), KS_Cmd2, KS_Alt_L, - KC(84), KS_Cmd2, KS_Alt_R, KS_Multi_key, - KC(85), KS_Cmd1, KS_Control_R, - KC(86), KS_Cmd_Screen0, KS_f1, - KC(87), KS_Cmd_Screen1, KS_f2, - KC(88), KS_Cmd_Screen2, KS_f3, - KC(89), KS_Cmd_Screen3, KS_f4, - KC(90), KS_Cmd_Screen4, KS_f5, - KC(91), KS_Cmd_Screen5, KS_f6, - KC(92), KS_Cmd_Screen6, KS_f7, - KC(93), KS_Cmd_Screen7, KS_f8, - KC(94), KS_Cmd_Screen8, KS_f9, - KC(95), KS_Cmd_Screen9, KS_f10, - KC(96), KS_Cmd_Screen10,KS_f11, - KC(97), KS_Cmd_Screen11,KS_f12, - KC(98), KS_Print_Screen, - KC(99), KS_Hold_Screen, - KC(100), KS_Pause, /*Break*/ - KC(101), KS_Insert, - KC(102), KS_Home, - KC(103), KS_Cmd_ScrollBack,KS_Prior, - KC(104), KS_End, - KC(105), KS_Cmd_ScrollFwd,KS_Next, - KC(106), KS_Num_Lock, - KC(107), KS_KP_Divide, - KC(108), KS_KP_Multiply, - KC(109), KS_KP_Add, -}; - -#if !defined(WSKBD_NO_INTL_LAYOUTS) - -static const keysym_t zskbd_keydesc_de[] = { -/* pos normal shifted altgr shift-altgr */ - KC(9), KS_q, KS_Q, KS_at, - KC(13), KS_2, KS_quotedbl, KS_twosuperior, - KC(14), KS_3, KS_section, KS_threesuperior, - KC(19), KS_y, - KC(29), KS_6, KS_ampersand, - KC(30), KS_7, KS_slash, KS_braceleft, - KC(31), KS_z, - KC(37), KS_8, KS_parenleft, KS_bracketleft, - KC(38), KS_9, KS_parenright, KS_bracketright, - KC(42), KS_odiaeresis, - KC(43), KS_m, KS_M, KS_mu, - KC(44), KS_comma, KS_semicolon, - KC(45), KS_0, KS_equal, KS_braceright, - KC(46), KS_ssharp, KS_question, KS_backslash, - KC(48), KS_udiaeresis, - KC(49), KS_adiaeresis, - KC(51), KS_period, KS_colon, - KC(52), KS_minus, KS_underscore, - KC(53), KS_dead_acute, KS_dead_grave, - KC(54), KS_dead_circumflex,KS_dead_abovering, - KC(55), KS_plus, KS_asterisk, KS_dead_tilde, - KC(56), KS_numbersign, KS_apostrophe, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, KS_bar, KS_brokenbar, -}; - -static const keysym_t zskbd_keydesc_de_nodead[] = { -/* pos normal shifted altgr shift-altgr */ - KC(53), KS_apostrophe, KS_grave, - KC(54), KS_asciicircum, KS_degree, - KC(55), KS_plus, KS_asterisk, KS_asciitilde, -}; - -static const keysym_t zskbd_keydesc_dk[] = { -/* pos normal shifted altgr shift-altgr */ - KC(13), KS_2, KS_quotedbl, KS_at, - KC(14), KS_3, KS_numbersign, KS_sterling, - KC(21), KS_4, KS_currency, KS_dollar, - KC(29), KS_6, KS_ampersand, - KC(30), KS_7, KS_slash, KS_braceleft, - KC(37), KS_8, KS_parenleft, KS_bracketleft, - KC(38), KS_9, KS_parenright, KS_bracketright, - KC(42), KS_ae, - KC(44), KS_comma, KS_semicolon, - KC(45), KS_0, KS_equal, KS_braceright, - KC(46), KS_plus, KS_question, - KC(48), KS_aring, - KC(49), KS_oslash, - KC(51), KS_period, KS_colon, - KC(52), KS_minus, KS_underscore, - KC(53), KS_dead_acute, KS_dead_grave, KS_bar, - KC(54), KS_onehalf, KS_paragraph, - KC(55), KS_dead_diaeresis,KS_dead_circumflex,KS_dead_tilde, - KC(56), KS_apostrophe, KS_asterisk, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, KS_backslash, -}; - -static const keysym_t zskbd_keydesc_dk_nodead[] = { -/* pos normal shifted altgr shift-altgr */ - KC(53), KS_apostrophe, KS_grave, KS_bar, - KC(55), KS_diaeresis, KS_asciicircum, KS_asciitilde, -}; - -static const keysym_t zskbd_keydesc_sv[] = { -/* pos normal shifted altgr shift-altgr */ - KC(42), KS_odiaeresis, - KC(46), KS_plus, KS_question, KS_backslash, - KC(49), KS_adiaeresis, - KC(54), KS_section, KS_onehalf, - KC(55), KS_dead_diaeresis,KS_dead_circumflex,KS_dead_tilde, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, KS_bar, -}; - -static const keysym_t zskbd_keydesc_sv_nodead[] = { -/* pos normal shifted altgr shift-altgr */ - KC(53), KS_apostrophe, KS_grave, KS_bar, - KC(55), KS_diaeresis, KS_asciicircum, KS_asciitilde, -}; - -static const keysym_t zskbd_keydesc_no[] = { -/* pos normal shifted altgr shift-altgr */ - KC(42), KS_oslash, - KC(49), KS_ae, - KC(53), KS_backslash, KS_dead_grave, KS_dead_acute, - KC(54), KS_bar, KS_paragraph, - KC(55), KS_dead_diaeresis,KS_dead_circumflex,KS_dead_tilde, - KC(111), KS_less, KS_greater, -}; - -static const keysym_t zskbd_keydesc_no_nodead[] = { -/* pos normal shifted altgr shift-altgr */ - KC(53), KS_backslash, KS_grave, KS_acute, - KC(55), KS_diaeresis, KS_asciicircum, KS_asciitilde, -}; - -static const keysym_t zskbd_keydesc_fr[] = { -/* pos normal shifted altgr shift-altgr */ - KC(7), KS_ampersand, KS_1, - KC(9), KS_a, - KC(10), KS_q, - KC(13), KS_eacute, KS_2, KS_asciitilde, - KC(14), KS_quotedbl, KS_3, KS_numbersign, - KC(15), KS_z, - KC(19), KS_w, - KC(21), KS_apostrophe, KS_4, KS_braceleft, - KC(22), KS_parenleft, KS_5, KS_bracketleft, - KC(29), KS_minus, KS_6, KS_bar, - KC(30), KS_egrave, KS_7, KS_grave, - KC(37), KS_underscore, KS_8, KS_backslash, - KC(38), KS_ccedilla, KS_9, KS_asciicircum, - KC(42), KS_m, - KC(43), KS_comma, KS_question, - KC(44), KS_semicolon, KS_period, - KC(45), KS_agrave, KS_0, KS_at, - KC(46), KS_parenright, KS_degree, KS_bracketright, - KC(48), KS_dead_circumflex,KS_dead_diaeresis, - KC(49), KS_ugrave, KS_percent, - KC(51), KS_colon, KS_slash, - KC(52), KS_exclam, KS_section, - KC(53), KS_equal, KS_plus, KS_braceright, - KC(54), KS_twosuperior, - KC(55), KS_dollar, KS_sterling, KS_currency, - KC(56), KS_asterisk, KS_mu, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, -}; - -/* - * fr-dvorak-be'po layout, simplified map, per http://www.clavier-dvorak.org/ - * (the complete map is still a moving target) - */ -/* fr_dvorak_bepo not applicable */ - -static const keysym_t zskbd_keydesc_it[] = { -/* pos normal shifted altgr shift-altgr */ - KC(13), KS_2, KS_quotedbl, KS_twosuperior, - KC(14), KS_3, KS_sterling, KS_threesuperior, - KC(22), KS_5, KS_percent, - KC(29), KS_6, KS_ampersand, - KC(30), KS_7, KS_slash, - KC(37), KS_8, KS_parenleft, - KC(38), KS_9, KS_parenright, - KC(42), KS_ograve, KS_Ccedilla, KS_at, - KC(44), KS_comma, KS_semicolon, - KC(45), KS_0, KS_equal, - KC(46), KS_apostrophe, KS_question, - KC(48), KS_egrave, KS_eacute, KS_braceleft, KS_bracketleft, - KC(49), KS_agrave, KS_degree, KS_numbersign, - KC(51), KS_period, KS_colon, - KC(52), KS_minus, KS_underscore, - KC(53), KS_igrave, KS_asciicircum, - KC(54), KS_backslash, KS_bar, - KC(55), KS_plus, KS_asterisk, KS_braceright, KS_bracketright, - KC(56), KS_ugrave, KS_section, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, -}; - -static const keysym_t zskbd_keydesc_uk[] = { -/* pos normal shifted altgr shift-altgr */ - KC(7), KS_1, KS_exclam, KS_plusminus, KS_exclamdown, - KC(13), KS_2, KS_quotedbl, KS_twosuperior, KS_cent, - KC(14), KS_3, KS_sterling, KS_threesuperior, - KC(21), KS_4, KS_dollar, KS_acute, KS_currency, - KC(22), KS_5, KS_percent, KS_mu, KS_yen, - KC(29), KS_6, KS_asciicircum, KS_paragraph, - KC(30), KS_7, KS_ampersand, KS_periodcentered,KS_brokenbar, - KC(37), KS_8, KS_asterisk, KS_cedilla, KS_ordfeminine, - KC(38), KS_9, KS_parenleft, KS_onesuperior, KS_diaeresis, - KC(45), KS_0, KS_parenright, KS_masculine, KS_copyright, - KC(46), KS_minus, KS_underscore, KS_hyphen, KS_ssharp, - KC(49), KS_apostrophe, KS_at, KS_section, KS_Agrave, - KC(53), KS_equal, KS_plus, KS_onehalf, KS_guillemotleft, - KC(54), KS_grave, KS_grave, KS_agrave, KS_agrave, - KC(56), KS_numbersign, KS_asciitilde, KS_sterling, KS_thorn, - KC(111), KS_backslash, KS_bar, KS_Udiaeresis, -}; - -/* jp not applicable */ - -static const keysym_t zskbd_keydesc_es[] = { -/* pos normal shifted altgr shift-altgr */ - KC(7), KS_1, KS_exclam, KS_bar, - KC(13), KS_2, KS_quotedbl, KS_at, - KC(14), KS_3, KS_periodcentered,KS_numbersign, - KC(21), KS_4, KS_dollar, KS_asciitilde, - KC(29), KS_6, KS_ampersand, - KC(30), KS_7, KS_slash, - KC(37), KS_8, KS_parenleft, - KC(38), KS_9, KS_parenright, - KC(42), KS_ntilde, - KC(44), KS_comma, KS_semicolon, - KC(45), KS_0, KS_equal, - KC(46), KS_apostrophe, KS_question, - KC(48), KS_dead_grave, KS_dead_circumflex,KS_bracketleft, - KC(49), KS_dead_acute, KS_dead_diaeresis,KS_braceleft, - KC(51), KS_period, KS_colon, - KC(52), KS_minus, KS_underscore, - KC(53), KS_exclamdown, KS_questiondown, - KC(54), KS_degree, KS_ordfeminine, KS_backslash, - KC(55), KS_plus, KS_asterisk, KS_bracketright, - KC(56), KS_ccedilla, KS_Ccedilla, KS_braceright, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, -}; - -/* lt not applicable */ - -static const keysym_t zskbd_keydesc_be[] = { -/* pos normal shifted altgr shift-altgr */ - KC(7), KS_ampersand, KS_1, KS_bar, - KC(9), KS_a, - KC(10), KS_q, - KC(13), KS_eacute, KS_2, KS_at, - KC(14), KS_quotedbl, KS_3, KS_numbersign, - KC(15), KS_z, - KC(19), KS_w, - KC(21), KS_apostrophe, KS_4, - KC(22), KS_parenleft, KS_5, - KC(29), KS_section, KS_6, KS_asciicircum, - KC(30), KS_egrave, KS_7, - KC(37), KS_exclam, KS_8, - KC(38), KS_ccedilla, KS_9, KS_braceleft, - KC(42), KS_m, - KC(43), KS_comma, KS_question, - KC(44), KS_semicolon, KS_period, - KC(45), KS_agrave, KS_0, KS_braceright, - KC(46), KS_parenright, KS_degree, - KC(48), KS_dead_circumflex,KS_dead_diaeresis,KS_bracketleft, - KC(49), KS_ugrave, KS_percent, KS_acute, - KC(51), KS_colon, KS_slash, - KC(52), KS_equal, KS_plus, KS_asciitilde, - KC(53), KS_minus, KS_underscore, - KC(54), KS_twosuperior, KS_threesuperior, - KC(55), KS_dollar, KS_asterisk, KS_bracketright, - KC(56), KS_mu, KS_sterling, KS_grave, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, KS_backslash, -}; - -/* us_declk not applicable */ - -/* us_dvorak not applicable */ - -/* us_colemak not applicable */ - -/* swapctrlcaps not applicable */ - -/* iopener not applicable */ - -/* ru not applicable */ - -/* ua not applicable */ - -static const keysym_t zskbd_keydesc_sg[] = { -/* pos normal shifted altgr shift-altgr */ - KC(7), KS_1, KS_plus, KS_bar, - KC(13), KS_2, KS_quotedbl, KS_at, - KC(14), KS_3, KS_asterisk, KS_numbersign, - KC(16), KS_e, KS_E, KS_currency, - KC(19), KS_y, - KC(21), KS_4, KS_ccedilla, - KC(29), KS_6, KS_ampersand, KS_notsign, - KC(30), KS_7, KS_slash, KS_brokenbar, - KC(31), KS_z, - KC(37), KS_8, KS_parenleft, KS_cent, - KC(38), KS_9, KS_parenright, - KC(42), KS_odiaeresis, KS_eacute, - KC(44), KS_comma, KS_semicolon, - KC(45), KS_0, KS_equal, - KC(46), KS_apostrophe, KS_question, KS_dead_acute, - KC(48), KS_udiaeresis, KS_egrave, KS_bracketleft, - KC(49), KS_adiaeresis, KS_agrave, KS_braceleft, - KC(51), KS_period, KS_colon, - KC(52), KS_minus, KS_underscore, - KC(53), KS_dead_circumflex,KS_dead_grave,KS_dead_tilde, - KC(54), KS_section, KS_degree, KS_dead_abovering, - KC(55), KS_dead_diaeresis,KS_exclam, KS_bracketright, - KC(56), KS_dollar, KS_sterling, KS_braceright, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, KS_backslash, -}; - -static const keysym_t zskbd_keydesc_sg_nodead[] = { -/* pos normal shifted altgr shift-altgr */ - KC(46), KS_apostrophe, KS_question, KS_acute, - KC(53), KS_asciicircum, KS_grave, KS_asciitilde, - KC(55), KS_diaeresis, KS_exclam, KS_bracketright, -}; - -static const keysym_t zskbd_keydesc_sf[] = { -/* pos normal shifted altgr shift-altgr */ - KC(42), KS_eacute, KS_odiaeresis, - KC(48), KS_egrave, KS_udiaeresis, KS_bracketleft, - KC(49), KS_agrave, KS_adiaeresis, KS_braceleft, -}; - -static const keysym_t zskbd_keydesc_pt[] = { -/* pos normal shifted altgr shift-altgr */ - KC(13), KS_2, KS_quotedbl, KS_at, - KC(14), KS_3, KS_numbersign, KS_sterling, - KC(29), KS_6, KS_ampersand, - KC(30), KS_7, KS_slash, KS_braceleft, - KC(37), KS_8, KS_parenleft, KS_bracketleft, - KC(38), KS_9, KS_parenright, KS_bracketright, - KC(42), KS_ccedilla, KS_Ccedilla, - KC(44), KS_comma, KS_semicolon, - KC(45), KS_0, KS_equal, KS_braceright, - KC(46), KS_apostrophe, KS_question, - KC(48), KS_plus, KS_asterisk, - KC(49), KS_masculine, KS_ordfeminine, - KC(51), KS_period, KS_colon, - KC(52), KS_minus, KS_underscore, - KC(53), KS_less, KS_greater, - KC(54), KS_backslash, KS_bar, - KC(55), KS_dead_acute, KS_dead_grave, - KC(56), KS_dead_tilde, KS_dead_circumflex, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_less, KS_greater, -}; - -/* la not applicable */ - -/* br not applicable */ - -/* tr not applicable */ - -/* tr_nodead not applicable */ - -/* pl not applicable */ - -/* hu not applicable */ - -/* si not applicable */ - -/* cf not applicable */ - -/* cf_nodead not applicable */ - -/* lv not applicable */ - -static const keysym_t zskbd_keydesc_nl[] = { -/* pos normal shifted altgr shift-altgr */ - KC(7), KS_1, KS_exclam, KS_onesuperior, - KC(11), KS_s, KS_S, KS_ssharp, - KC(13), KS_2, KS_quotedbl, KS_twosuperior, - KC(14), KS_3, KS_numbersign, KS_threesuperior, - KC(19), KS_z, KS_Z, KS_guillemotleft, - KC(20), KS_x, KS_X, KS_guillemotright, - KC(21), KS_4, KS_dollar, KS_onequarter, - KC(22), KS_5, KS_percent, KS_onehalf, - KC(23), KS_r, KS_R, KS_paragraph, - KC(27), KS_c, KS_C, KS_cent, - KC(29), KS_6, KS_ampersand, KS_threequarters, - KC(30), KS_7, KS_underscore, KS_sterling, - KC(37), KS_8, KS_parenleft, KS_braceleft, - KC(38), KS_9, KS_parenright, KS_braceright, - KC(42), KS_plus, KS_plusminus, - KC(43), KS_m, KS_M, KS_mu, - KC(44), KS_comma, KS_semicolon, - KC(45), KS_0, KS_apostrophe, - KC(46), KS_slash, KS_question, KS_backslash, - KC(48), KS_dead_diaeresis,KS_dead_circumflex, - KC(49), KS_dead_acute, KS_dead_grave, - KC(51), KS_period, KS_colon, KS_periodcentered, - KC(52), KS_minus, KS_equal, - KC(53), KS_degree, KS_dead_tilde, KS_dead_cedilla, - KC(54), KS_at, KS_section, KS_notsign, - KC(55), KS_asterisk, KS_bar, - KC(56), KS_less, KS_greater, - KC(84), KS_Mode_switch, KS_Multi_key, - KC(111), KS_bracketright,KS_bracketleft, KS_brokenbar, -}; - -static const keysym_t zskbd_keydesc_nl_nodead[] = { -/* pos normal shifted altgr shift-altgr */ - KC(48), KS_quotedbl, KS_asciicircum, - KC(49), KS_apostrophe, KS_grave, - KC(53), KS_degree, KS_asciitilde, KS_cedilla, -}; - -/* is not applicable */ - -/* is_nodead not applicable */ - -/* ee not applicable */ - -/* ee_nodead not applicable */ - -#endif /* WSKBD_NO_INTL_LAYOUTS */ - -#define KBD_MAP(name, base, map) \ - { name, base, sizeof(map)/sizeof(keysym_t), map } - -const struct wscons_keydesc wssgi_keydesctab[] = { - KBD_MAP(KB_US, 0, zskbd_keydesc_us), -#if !defined(WSKBD_NO_INTL_LAYOUTS) - KBD_MAP(KB_DE, KB_US, zskbd_keydesc_de), - KBD_MAP(KB_DE | KB_NODEAD, KB_DE, zskbd_keydesc_de_nodead), - KBD_MAP(KB_FR, KB_US, zskbd_keydesc_fr), - KBD_MAP(KB_DK, KB_US, zskbd_keydesc_dk), - KBD_MAP(KB_DK | KB_NODEAD, KB_DK, zskbd_keydesc_dk_nodead), - KBD_MAP(KB_IT, KB_US, zskbd_keydesc_it), - KBD_MAP(KB_UK, KB_US, zskbd_keydesc_uk), - KBD_MAP(KB_SV, KB_DK, zskbd_keydesc_sv), - KBD_MAP(KB_SV | KB_NODEAD, KB_SV, zskbd_keydesc_sv_nodead), - KBD_MAP(KB_NO, KB_DK, zskbd_keydesc_no), - KBD_MAP(KB_NO | KB_NODEAD, KB_NO, zskbd_keydesc_no_nodead), - KBD_MAP(KB_ES, KB_US, zskbd_keydesc_es), - KBD_MAP(KB_BE, KB_US, zskbd_keydesc_be), - KBD_MAP(KB_SG, KB_US, zskbd_keydesc_sg), - KBD_MAP(KB_SG | KB_NODEAD, KB_SG, zskbd_keydesc_sg_nodead), - KBD_MAP(KB_SF, KB_SG, zskbd_keydesc_sf), - KBD_MAP(KB_SF | KB_NODEAD, KB_SF, zskbd_keydesc_sg_nodead), - KBD_MAP(KB_PT, KB_US, zskbd_keydesc_pt), - KBD_MAP(KB_NL, KB_US, zskbd_keydesc_nl), - KBD_MAP(KB_NL | KB_NODEAD, KB_NL, zskbd_keydesc_nl_nodead), -#endif /* WSKBD_NO_INTL_LAYOUTS */ - {0, 0, 0, 0} -}; - -#undef KBD_MAP -#undef KC diff --git a/sys/arch/sgi/hpc/z8530kbd.c b/sys/arch/sgi/hpc/z8530kbd.c deleted file mode 100644 index ffa93445ca1..00000000000 --- a/sys/arch/sgi/hpc/z8530kbd.c +++ /dev/null @@ -1,753 +0,0 @@ -/* $OpenBSD: z8530kbd.c,v 1.7 2014/12/07 13:10:45 miod Exp $ */ -/* $NetBSD: zs_kbd.c,v 1.8 2008/03/29 19:15:35 tsutsui Exp $ */ - -/* - * Copyright (c) 2004 Steve Rumble - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * IP20 serial keyboard driver attached to zs channel 0 at 600bps. - * This layer is the parent of wskbd. - */ - -#include <sys/param.h> -#include <sys/malloc.h> -#include <sys/systm.h> -#include <sys/conf.h> -#include <sys/device.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wskbdvar.h> -#include <dev/wscons/wsksymdef.h> -#include <dev/wscons/wsksymvar.h> - -#include <machine/autoconf.h> -#include <mips64/archtype.h> - -#include <dev/ic/z8530reg.h> -#include <machine/z8530var.h> - -#define ZSKBD_BAUD 600 -#define ZSKBD_TXQ_LEN 16 /* power of 2 */ -#define ZSKBD_RXQ_LEN 64 /* power of 2 */ - -#define ZSKBD_DIP_SYNC 0x6e /* 110 */ -#define ZSKBD_INTL_KEY 0x6f /* 111 */ -#define ZSKBD_KEY_UP 0x80 -#define ZSKBD_KEY_ALL_UP 0xf0 - -#ifdef ZSKBD_DEBUG -int zskbd_debug = 0; - -#define DPRINTF(_x) if (zskbd_debug) printf _x -#else -#define DPRINTF(_x) -#endif - -struct zskbd_softc { - struct device sc_dev; - - struct zskbd_devconfig *sc_dc; - -#ifdef WSDISPLAY_COMPAT_RAWKBD - int sc_rawkbd; -#endif -}; - -struct zskbd_devconfig { - /* transmit tail-chasing fifo */ - uint8_t txq[ZSKBD_TXQ_LEN]; - u_int txq_head; - u_int txq_tail; - - /* receive tail-chasing fifo */ - uint8_t rxq[ZSKBD_RXQ_LEN]; - u_int rxq_head; - u_int rxq_tail; - - /* number of non-keystroke bytes expected */ - int expected; - - /* keyboard configuration */ -#define ZSKBD_CTRL_A 0x0 -#define ZSKBD_CTRL_A_SBEEP 0x2 /* 200 ms */ -#define ZSKBD_CTRL_A_LBEEP 0x4 /* 1000 ms */ -#define ZSKBD_CTRL_A_NOCLICK 0x8 /* turn off keyboard click */ -#define ZSKBD_CTRL_A_RCB 0x10 /* request config byte */ -#define ZSKBD_CTRL_A_NUMLK 0x20 /* num lock led */ -#define ZSKBD_CTRL_A_CAPSLK 0x40 /* caps lock led */ -#define ZSKBD_CTRL_A_AUTOREP 0x80 /* auto-repeat after 650 ms, 28x/sec */ - -#define ZSKBD_CTRL_B 0x1 -#define ZSKBD_CTRL_B_CMPL_DS1_2 0x2 /* complement of ds1+ds2 (num+capslk) */ -#define ZSKBD_CTRL_B_SCRLK 0x4 /* scroll lock light */ -#define ZSKBD_CTRL_B_L1 0x8 /* user-configurable lights */ -#define ZSKBD_CTRL_B_L2 0x10 -#define ZSKBD_CTRL_B_L3 0x20 -#define ZSKBD_CTRL_B_L4 0x40 - uint8_t kbd_conf[2]; - - /* dip switch settings */ - uint8_t dip; - - /* wscons glue */ - struct device *wskbddev; - int enabled; -}; - -struct zskbd_devconfig zskbd_consdc; - -int zskbd_match(struct device *, void *, void *); -void zskbd_attach(struct device *, struct device *, void *); - -struct cfdriver zskbd_cd = { - NULL, "zskbd", DV_DULL -}; - -const struct cfattach zskbd_ca = { - sizeof(struct zskbd_softc), zskbd_match, zskbd_attach -}; - -void zskbd_rxint(struct zs_chanstate *); -void zskbd_stint(struct zs_chanstate *, int); -void zskbd_txint(struct zs_chanstate *); -void zskbd_softint(struct zs_chanstate *); -int zskbd_send(struct zs_chanstate *, uint8_t *, u_int); -int zskbd_poll(struct zs_chanstate *, uint8_t *); -void zskbd_ctrl(struct zs_chanstate *, uint8_t, uint8_t, uint8_t, uint8_t); -int zskbd_process(struct zskbd_devconfig *, uint8_t); - -void zskbd_wskbd_input(struct zs_chanstate *, uint8_t); -int zskbd_wskbd_enable(void *, int); -void zskbd_wskbd_set_leds(void *, int); -int zskbd_wskbd_get_leds(void *); -void zskbd_wskbd_set_keyclick(void *, int); -int zskbd_wskbd_get_keyclick(void *); -int zskbd_wskbd_ioctl(void *, u_long, caddr_t, int, struct proc *); - -void zskbd_cnattach(int, int); -void zskbd_wskbd_getc(void *, u_int *, int *); -void zskbd_wskbd_pollc(void *, int); -void zskbd_wskbd_bell(void *, u_int, u_int, u_int); - -extern struct zschan *zs_get_chan_addr(int, int); -extern int zs_getc(void *); -extern void zs_putc(void *, int); - -static struct zsops zskbd_zsops = { - zskbd_rxint, - zskbd_stint, - zskbd_txint, - zskbd_softint -}; - -extern const struct wscons_keydesc wssgi_keydesctab[]; -struct wskbd_mapdata sgikbd_wskbd_keymapdata = { - wssgi_keydesctab, - KB_US | KB_DEFAULT -}; - -const int zskbd_layouts[] = { - KB_US, - KB_DE, - KB_FR, - KB_IT, - KB_DK, - KB_ES, - KB_NO, - KB_SV, - KB_SF, - KB_UK, - KB_BE, - KB_SG, - KB_NL, - -1, /* finnish */ - KB_PT, - -1 /* greek */ -}; - -const struct wskbd_accessops zskbd_wskbd_accessops = { - zskbd_wskbd_enable, - zskbd_wskbd_set_leds, - zskbd_wskbd_ioctl -}; - -const struct wskbd_consops zskbd_wskbd_consops = { - zskbd_wskbd_getc, - zskbd_wskbd_pollc, - zskbd_wskbd_bell -}; - -int zskbd_is_console = 0; - -int -zskbd_match(struct device *parent, void *vcf, void *aux) -{ - if (sys_config.system_type == SGI_IP20) { - struct zsc_attach_args *args = aux; - - if (args->channel == 0) - return 1; - } - - return 0; -} - -void -zskbd_attach(struct device *parent, struct device *self, void *aux) -{ - struct zskbd_softc *sc = (struct zskbd_softc *)self; - struct zsc_softc *zsc = (struct zsc_softc *)parent; - struct zsc_attach_args *args = aux; - struct zs_chanstate *cs; - struct zskbd_devconfig *dc; - struct wskbddev_attach_args wskaa; - int s, channel, rc; - uint8_t key; - - printf(": "); - - /* Establish ourself with the MD z8530 driver */ - channel = args->channel; - cs = zsc->zsc_cs[channel]; - cs->cs_ops = &zskbd_zsops; - cs->cs_private = sc; - - if (zskbd_is_console) - dc = &zskbd_consdc; - else - dc = malloc(sizeof(struct zskbd_devconfig), M_DEVBUF, - M_WAITOK | M_ZERO); - sc->sc_dc = dc; - - s = splzs(); - zs_write_reg(cs, 9, (channel == 0) ? ZSWR9_A_RESET : ZSWR9_B_RESET); - cs->cs_preg[1] = ZSWR1_RIE | ZSWR1_TIE; - cs->cs_preg[4] = (cs->cs_preg[4] & ZSWR4_CLK_MASK) | - (ZSWR4_ONESB | ZSWR4_PARENB); /* 1 stop, odd parity */ - cs->cs_preg[15] &= ~ZSWR15_ENABLE_ENHANCED; - zs_set_speed(cs, ZSKBD_BAUD); - zs_loadchannelregs(cs); - - /* - * Empty the keyboard input buffer (if the keyboard is the console - * input device and the user invoked UKC, the `enter key up' event - * will still be pending in the buffer). - */ - while ((zs_read_csr(cs) & ZSRR0_RX_READY) != 0) - (void)zs_read_data(cs); - - if (!zskbd_is_console) { - /* - * Ask the keyboard for its DIP switch settings. This will - * also let us know whether the keyboard is connected. - */ - dc->expected = 2; - zskbd_ctrl(cs, ZSKBD_CTRL_A_RCB, 0, 0, 0); - while (dc->expected != 0) { - rc = zskbd_poll(cs, &key); - if (rc != 0) { - if (rc == ENXIO && dc->expected == 2) { - printf("no keyboard"); - /* - * Attach wskbd nevertheless, in case - * the keyboard is plugged late. - */ - dc->expected = 0; - goto dip; - } else { - printf("i/o error\n"); - return; - } - } - - zskbd_process(dc, key); - } - } - - printf("dipsw %02x", dc->dip); - if (dc->dip < nitems(zskbd_layouts) && zskbd_layouts[dc->dip] != -1) - sgikbd_wskbd_keymapdata.layout = zskbd_layouts[dc->dip]; -dip: - - /* - * Disable key click by default. Note that if the keyboard is not - * currently connected, the bit will nevertheless stick and will - * disable the click as soon as a keyboard led needs to be lit. - */ - zskbd_ctrl(cs, ZSKBD_CTRL_A_NOCLICK, 0, 0, 0); - - splx(s); - - printf("\n"); - - if (zskbd_is_console) - dc->enabled = 1; - - /* attach wskbd */ - wskaa.console = zskbd_is_console; - wskaa.keymap = &sgikbd_wskbd_keymapdata; - wskaa.accessops = &zskbd_wskbd_accessops; - wskaa.accesscookie = cs; - dc->wskbddev = config_found(self, &wskaa, wskbddevprint); -} - -void -zskbd_rxint(struct zs_chanstate *cs) -{ - struct zskbd_softc *sc = cs->cs_private; - struct zskbd_devconfig *dc = sc->sc_dc; - uint8_t c, r; - - /* clear errors */ - r = zs_read_reg(cs, 1); - if (r & (ZSRR1_FE | ZSRR1_DO | ZSRR1_PE)) - zs_write_csr(cs, ZSWR0_RESET_ERRORS); - - /* read byte and append to our queue */ - c = zs_read_data(cs); - - dc->rxq[dc->rxq_tail] = c; - dc->rxq_tail = (dc->rxq_tail + 1) & ~ZSKBD_RXQ_LEN; - - cs->cs_softreq = 1; -} - -void -zskbd_stint(struct zs_chanstate *cs, int force) -{ - zs_write_csr(cs, ZSWR0_RESET_STATUS); - cs->cs_softreq = 1; -} - -void -zskbd_txint(struct zs_chanstate *cs) -{ - zs_write_reg(cs, 0, ZSWR0_RESET_TXINT); - cs->cs_softreq = 1; -} - -void -zskbd_softint(struct zs_chanstate *cs) -{ - struct zskbd_softc *sc = cs->cs_private; - struct zskbd_devconfig *dc = sc->sc_dc; - int rr0; - uint8_t key; - - /* handle pending transmissions */ - if (dc->txq_head != dc->txq_tail) { - int s; - - s = splzs(); - while (dc->txq_head != dc->txq_tail) { - rr0 = zs_read_csr(cs); - if ((rr0 & ZSRR0_TX_READY) == 0) - break; - zs_write_data(cs, dc->txq[dc->txq_head]); - dc->txq_head = (dc->txq_head + 1) & ~ZSKBD_TXQ_LEN; - } - splx(s); - } - - /* handle incoming keystrokes/config */ - while (dc->rxq_head != dc->rxq_tail) { - key = dc->rxq[dc->rxq_head]; - dc->rxq_head = (dc->rxq_head + 1) & ~ZSKBD_RXQ_LEN; - if (zskbd_process(dc, key) != 0) { - /* - * The `international' key (only found in non-us - * layouts) is supposed to be keycode 111, but is - * apparently 110 (same as the status byte prefix) - * on some (all?) models. - */ - if (key == ZSKBD_DIP_SYNC) - key = ZSKBD_INTL_KEY; - - /* toss wskbd a bone */ - if (dc->enabled) - zskbd_wskbd_input(cs, key); - } - } -} - -int -zskbd_process(struct zskbd_devconfig *dc, uint8_t key) -{ - switch (dc->expected) { - case 2: - if (key != ZSKBD_DIP_SYNC) { - /* only during attach, thus no device name prefix */ - printf("unexpected configuration byte header" - " (%02x), ", key); - /* transition state anyway */ - } - dc->expected--; - return 0; - case 1: - dc->dip = key; - dc->expected--; - return 0; - default: - case 0: - return 1; - } -} - -/* expects to be in splzs() */ -int -zskbd_send(struct zs_chanstate *cs, uint8_t *c, u_int len) -{ - struct zskbd_softc *sc = cs->cs_private; - struct zskbd_devconfig *dc = sc->sc_dc; - u_int i; - int rr0; - - while (len != 0) { - rr0 = zs_read_csr(cs); - if ((rr0 & ZSRR0_TX_READY) == 0) { - /* - * poll until whole transmission complete during - * autoconf - */ - if (cold) { - for (i = 1000; i != 0; i--) { - if ((rr0 & ZSRR0_TX_READY) != 0) - break; - delay(100); - } - if (i == 0) - return EIO; - } else - break; - } - zs_write_data(cs, *c++); - len--; - } - - /* - * Enqueue any remaining bytes. - */ - while (len != 0) { - dc->txq[dc->txq_tail] = *c++; - dc->txq_tail = (dc->txq_tail + 1) & ~ZSKBD_TXQ_LEN; - len--; - cs->cs_softreq = 1; - } - - return 0; -} - -/* expects to be in splzs() */ -int -zskbd_poll(struct zs_chanstate *cs, uint8_t *key) -{ - u_int i; - int rr0, rr1, c; - - for (i = 1000; i != 0; i--) { - rr0 = zs_read_csr(cs); - if ((rr0 & ZSRR0_RX_READY) != 0) - break; - delay(100); - } - if (i == 0) - return ENXIO; - - rr1 = zs_read_reg(cs, 1); - c = zs_read_data(cs); - - if (rr1 & (ZSRR1_FE | ZSRR1_DO | ZSRR1_PE)) - return EIO; - - *key = (uint8_t)c; - return 0; -} - -/* expects to be in splzs() */ -void -zskbd_ctrl(struct zs_chanstate *cs, uint8_t a_on, uint8_t a_off, uint8_t b_on, - uint8_t b_off) -{ - struct zskbd_softc *sc = cs->cs_private; - struct zskbd_devconfig *dc = sc->sc_dc; - - dc->kbd_conf[ZSKBD_CTRL_A] |= a_on; - dc->kbd_conf[ZSKBD_CTRL_A] &= ~(a_off | ZSKBD_CTRL_B); - dc->kbd_conf[ZSKBD_CTRL_B] &= ~b_off; - dc->kbd_conf[ZSKBD_CTRL_B] |= (b_on | ZSKBD_CTRL_B); - - zskbd_send(cs, dc->kbd_conf, 2); - - /* make sure we don't resend these each time */ - dc->kbd_conf[ZSKBD_CTRL_A] &= ~(ZSKBD_CTRL_A_RCB | ZSKBD_CTRL_A_SBEEP | - ZSKBD_CTRL_A_LBEEP); -} - -/****************************************************************************** - * wskbd glue - ******************************************************************************/ - -void -zskbd_wskbd_input(struct zs_chanstate *cs, uint8_t key) -{ - struct zskbd_softc *sc = cs->cs_private; - u_int type; -#ifdef WSDISPLAY_COMPAT_RAWKBD - int s; -#endif - - if (sc->sc_dc->wskbddev == NULL) - return; /* why bother */ - - if (key & ZSKBD_KEY_UP) { - if ((key & ZSKBD_KEY_ALL_UP) == ZSKBD_KEY_ALL_UP) - type = WSCONS_EVENT_ALL_KEYS_UP; - else - type = WSCONS_EVENT_KEY_UP; - } else - type = WSCONS_EVENT_KEY_DOWN; - - wskbd_input(sc->sc_dc->wskbddev, type, (key & ~ZSKBD_KEY_UP)); - - DPRINTF(("zskbd_wskbd_input: inputted key 0x%x\n", key)); - -#ifdef WSDISPLAY_COMPAT_RAWKBD - if (sc->sc_rawkbd && - type != WSCONS_EVENT_ALL_KEYS_UP) { - s = spltty(); - wskbd_rawinput(sc->sc_dc->wskbddev, &key, 1); - splx(s); - } -#endif -} - -int -zskbd_wskbd_enable(void *cookie, int on) -{ - struct zs_chanstate *cs = cookie; - struct zskbd_softc *sc = cs->cs_private; - - if (on) { - if (sc->sc_dc->enabled) - return (EBUSY); - else - sc->sc_dc->enabled = 1; - } else - sc->sc_dc->enabled = 0; - - DPRINTF(("zskbd_wskbd_enable: %s\n", on ? "enabled" : "disabled")); - - return (0); -} - -void -zskbd_wskbd_set_leds(void *cookie, int leds) -{ - struct zs_chanstate *cs = cookie; - int s; - uint8_t a_on, a_off, b_on, b_off; - - a_on = a_off = b_on = b_off = 0; - - if (leds & WSKBD_LED_CAPS) - a_on |= ZSKBD_CTRL_A_CAPSLK; - else - a_off |= ZSKBD_CTRL_A_CAPSLK; - - if (leds & WSKBD_LED_NUM) - a_on |= ZSKBD_CTRL_A_NUMLK; - else - a_off |= ZSKBD_CTRL_A_NUMLK; - - if (leds & WSKBD_LED_SCROLL) - b_on |= ZSKBD_CTRL_B_SCRLK; - else - b_off |= ZSKBD_CTRL_B_SCRLK; - - s = splzs(); - zskbd_ctrl(cs, a_on, a_off, b_on, b_off); - splx(s); -} - -int -zskbd_wskbd_get_leds(void *cookie) -{ - struct zs_chanstate *cs = cookie; - struct zskbd_softc *sc = cs->cs_private; - int leds; - - leds = 0; - - if (sc->sc_dc->kbd_conf[ZSKBD_CTRL_A] & ZSKBD_CTRL_A_NUMLK) - leds |= WSKBD_LED_NUM; - - if (sc->sc_dc->kbd_conf[ZSKBD_CTRL_A] & ZSKBD_CTRL_A_CAPSLK) - leds |= WSKBD_LED_CAPS; - - if (sc->sc_dc->kbd_conf[ZSKBD_CTRL_B] & ZSKBD_CTRL_B_SCRLK) - leds |= WSKBD_LED_SCROLL; - - return (leds); -} - -#if 0 -void -zskbd_wskbd_set_keyclick(void *cookie, int on) -{ - struct zs_chanstate *cs = cookie; - int s; - - if (on) { - if (!zskbd_wskbd_get_keyclick(cookie)) { - s = splzs(); - zskbd_ctrl(cs, 0, ZSKBD_CTRL_A_NOCLICK, 0, 0); - splx(s); - } - } else { - if (zskbd_wskbd_get_keyclick(cookie)) { - s = splzs(); - zskbd_ctrl(cs, ZSKBD_CTRL_A_NOCLICK, 0, 0, 0); - splx(s); - } - } -} - -int -zskbd_wskbd_get_keyclick(void *cookie) -{ - struct zs_chanstate *cs = cookie; - struct zskbd_softc *sc = cs->cs_private; - - if (sc->sc_dc->kbd_conf[ZSKBD_CTRL_A] & ZSKBD_CTRL_A_NOCLICK) - return (0); - else - return (1); -} -#endif - -int -zskbd_wskbd_ioctl(void *cookie, u_long cmd, caddr_t data, int flag, - struct proc *p) -{ - struct zs_chanstate *cs = cookie; -#ifdef WSDISPLAY_COMPAT_RAWKBD - struct zskbd_softc *sc = cs->cs_private; -#endif - - switch (cmd) { - case WSKBDIO_GTYPE: - *(int *)data = WSKBD_TYPE_SGI; - break; - case WSKBDIO_SETLEDS: - zskbd_wskbd_set_leds(cs, *(int *)data); - break; - case WSKBDIO_GETLEDS: - *(int *)data = zskbd_wskbd_get_leds(cs); - break; -#if 0 - case WSKBDIO_SETKEYCLICK: - zskbd_wskbd_set_keyclick(cs, *(int *)data); - break; - case WSKBDIO_GETKEYCLICK: - *(int *)data = zskbd_wskbd_get_keyclick(cs); - break; -#endif -#ifdef WSDISPLAY_COMPAT_RAWKBD - case WSKBDIO_SETMODE: - sc->sc_rawkbd = *(int *)data == WSKBD_RAW; - break; -#endif - default: - return -1; - } - - return 0; -} - -/* - * console routines - */ -void -zskbd_cnattach(int zsunit, int zschan) -{ - struct zschan *zs; - struct zskbd_devconfig *dc; - - zs = zs_get_chan_addr(zsunit, zschan); - dc = &zskbd_consdc; - - /* - * Try and figure out our dip switches early, in order to pick - * the right keyboard layout. - */ - dc->expected = 2; - zs_putc(zs, ZSKBD_CTRL_A_RCB); - zs_putc(zs, ZSKBD_CTRL_B); /* unnecessary? */ - - while (dc->expected != 0) { - zskbd_process(dc, zs_getc(zs)); - } - - if (dc->dip < nitems(zskbd_layouts) && zskbd_layouts[dc->dip] != -1) - sgikbd_wskbd_keymapdata.layout = zskbd_layouts[dc->dip]; - - wskbd_cnattach(&zskbd_wskbd_consops, zs, &sgikbd_wskbd_keymapdata); - zskbd_is_console = 1; -} - -void -zskbd_wskbd_getc(void *cookie, u_int *type, int *data) -{ - int key; - - key = zs_getc(cookie); - - if (key & ZSKBD_KEY_UP) - *type = WSCONS_EVENT_KEY_UP; - else - *type = WSCONS_EVENT_KEY_DOWN; - - *data = key & ~ZSKBD_KEY_UP; -} - -void -zskbd_wskbd_pollc(void *cookie, int on) -{ -} - -void -zskbd_wskbd_bell(void *cookie, u_int pitch, u_int period, u_int volume) -{ - /* - * Since we don't have any state, this'll nuke our lights, - * key click, and other bits in ZSKBD_CTRL_A. - */ - if (period >= 1000) - zs_putc(cookie, ZSKBD_CTRL_A_LBEEP); - else - zs_putc(cookie, ZSKBD_CTRL_A_SBEEP); -} diff --git a/sys/arch/sgi/hpc/z8530ms.c b/sys/arch/sgi/hpc/z8530ms.c deleted file mode 100644 index 991eba4a2c4..00000000000 --- a/sys/arch/sgi/hpc/z8530ms.c +++ /dev/null @@ -1,337 +0,0 @@ -/* $OpenBSD: z8530ms.c,v 1.2 2016/06/05 20:02:36 bru Exp $ */ -/* $NetBSD: zs_ms.c,v 1.7 2008/03/29 19:15:35 tsutsui Exp $ */ - -/* - * Copyright (c) 2004 Steve Rumble - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * IP20 serial mouse driver attached to zs channel 1 at 4800bps. - * This layer feeds wsmouse. - * - * 5 byte packets: sync, x1, y1, x2, y2 - * sync format: binary 10000LMR (left, middle, right) 0 is down - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/conf.h> -#include <sys/device.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsmousevar.h> - -#include <machine/autoconf.h> -#include <mips64/archtype.h> - -#include <dev/ic/z8530reg.h> -#include <machine/z8530var.h> - -#define ZSMS_BAUD 4800 -#define ZSMS_RXQ_LEN 64 /* power of 2 */ - -/* protocol */ -#define ZSMS_SYNC 0x80 -#define ZSMS_SYNC_MASK 0xf8 -#define ZSMS_SYNC_BTN_R 0x01 -#define ZSMS_SYNC_BTN_M 0x02 -#define ZSMS_SYNC_BTN_L 0x04 -#define ZSMS_SYNC_BTN_MASK 0x07 - -struct zsms_softc { - struct device sc_dev; - - /* tail-chasing fifo */ - uint8_t rxq[ZSMS_RXQ_LEN]; - uint8_t rxq_head; - uint8_t rxq_tail; - - /* 5-byte packet as described above */ -#define ZSMS_PACKET_SYNC 0 -#define ZSMS_PACKET_X1 1 -#define ZSMS_PACKET_Y1 2 -#define ZSMS_PACKET_X2 3 -#define ZSMS_PACKET_Y2 4 - int8_t packet[5]; - -#define ZSMS_STATE_SYNC 0x01 -#define ZSMS_STATE_X1 0x02 -#define ZSMS_STATE_Y1 0x04 -#define ZSMS_STATE_X2 0x08 -#define ZSMS_STATE_Y2 0x10 - uint8_t state; - - /* wsmouse bits */ - int enabled; - struct device *wsmousedev; -}; - -int zsms_match(struct device *, void *, void *); -void zsms_attach(struct device *, struct device *, void *); - -struct cfdriver zsms_cd = { - NULL, "zsms", DV_DULL -}; - -const struct cfattach zsms_ca = { - sizeof(struct zsms_softc), zsms_match, zsms_attach -}; - -void zsms_rxint(struct zs_chanstate *); -void zsms_txint(struct zs_chanstate *); -void zsms_stint(struct zs_chanstate *, int); -void zsms_softint(struct zs_chanstate *); - -void zsms_wsmouse_input(struct zsms_softc *); -int zsms_wsmouse_enable(void *); -void zsms_wsmouse_disable(void *); -int zsms_wsmouse_ioctl(void *, u_long, caddr_t, int, struct proc *); - -static struct zsops zsms_zsops = { - zsms_rxint, - zsms_stint, - zsms_txint, - zsms_softint -}; - -static const struct wsmouse_accessops zsms_wsmouse_accessops = { - zsms_wsmouse_enable, - zsms_wsmouse_ioctl, - zsms_wsmouse_disable -}; - -int -zsms_match(struct device *parent, void *vcf, void *aux) -{ - if (sys_config.system_type == SGI_IP20) { - struct zsc_attach_args *args = aux; - - if (args->channel == 1) - return (1); - } - - return (0); -} - -void -zsms_attach(struct device *parent, struct device *self, void *aux) -{ - struct zsc_softc *zsc = (struct zsc_softc *)parent; - struct zsms_softc *sc = (struct zsms_softc *)self; - struct zsc_attach_args *args = aux; - struct zs_chanstate *cs; - int s, channel; - struct wsmousedev_attach_args wsmaa; - - /* Establish ourself with the MD z8530 driver */ - channel = args->channel; - cs = zsc->zsc_cs[channel]; - cs->cs_ops = &zsms_zsops; - cs->cs_private = sc; - - sc->enabled = 0; - sc->rxq_head = 0; - sc->rxq_tail = 0; - sc->state = ZSMS_STATE_SYNC; - - printf("\n"); - - s = splzs(); - zs_write_reg(cs, 9, (channel == 0) ? ZSWR9_A_RESET : ZSWR9_B_RESET); - cs->cs_preg[1] = ZSWR1_RIE; - zs_set_speed(cs, ZSMS_BAUD); - zs_loadchannelregs(cs); - splx(s); - - /* attach wsmouse */ - wsmaa.accessops = &zsms_wsmouse_accessops; - wsmaa.accesscookie = sc; - sc->wsmousedev = config_found(self, &wsmaa, wsmousedevprint); -} - -void -zsms_rxint(struct zs_chanstate *cs) -{ - struct zsms_softc *sc = cs->cs_private; - uint8_t c, r; - - /* clear errors */ - r = zs_read_reg(cs, 1); - if (r & (ZSRR1_FE | ZSRR1_DO | ZSRR1_PE)) - zs_write_csr(cs, ZSWR0_RESET_ERRORS); - - /* read byte and append to our queue */ - c = zs_read_data(cs); - - sc->rxq[sc->rxq_tail] = c; - sc->rxq_tail = (sc->rxq_tail + 1) & ~ZSMS_RXQ_LEN; - - cs->cs_softreq = 1; -} - -/* We should never get here. */ -void -zsms_txint(struct zs_chanstate *cs) -{ - zs_write_reg(cs, 0, ZSWR0_RESET_TXINT); - - /* disable tx interrupts */ - CLR(cs->cs_preg[1], ZSWR1_TIE); - zs_loadchannelregs(cs); -} - -void -zsms_stint(struct zs_chanstate *cs, int force) -{ - zs_write_csr(cs, ZSWR0_RESET_STATUS); - cs->cs_softreq = 1; -} - -void -zsms_softint(struct zs_chanstate *cs) -{ - struct zsms_softc *sc = cs->cs_private; - - /* No need to keep score if nobody is listening */ - if (!sc->enabled) { - sc->rxq_head = sc->rxq_tail; - return; - } - - /* - * Here's the real action. Read a full packet and - * then let wsmouse know what has happened. - */ - while (sc->rxq_head != sc->rxq_tail) { - int8_t c = sc->rxq[sc->rxq_head]; - - switch (sc->state) { - case ZSMS_STATE_SYNC: - if ((c & ZSMS_SYNC_MASK) == ZSMS_SYNC) { - sc->packet[ZSMS_PACKET_SYNC] = c; - sc->state = ZSMS_STATE_X1; - } - break; - - case ZSMS_STATE_X1: - sc->packet[ZSMS_PACKET_X1] = c; - sc->state = ZSMS_STATE_Y1; - break; - - case ZSMS_STATE_Y1: - sc->packet[ZSMS_PACKET_Y1] = c; - sc->state = ZSMS_STATE_X2; - break; - - case ZSMS_STATE_X2: - sc->packet[ZSMS_PACKET_X2] = c; - sc->state = ZSMS_STATE_Y2; - break; - - case ZSMS_STATE_Y2: - sc->packet[ZSMS_PACKET_Y2] = c; - - /* tweak wsmouse */ - zsms_wsmouse_input(sc); - - sc->state = ZSMS_STATE_SYNC; - } - - sc->rxq_head = (sc->rxq_head + 1) & ~ZSMS_RXQ_LEN; - } -} - -/****************************************************************************** - * wsmouse glue - ******************************************************************************/ - -void -zsms_wsmouse_input(struct zsms_softc *sc) -{ - u_int btns; - int bl, bm, br; - int x, y; - - if (sc->wsmousedev == NULL) - return; - - btns = (uint8_t)sc->packet[ZSMS_PACKET_SYNC] & ZSMS_SYNC_BTN_MASK; - - bl = (btns & ZSMS_SYNC_BTN_L) == 0; - bm = (btns & ZSMS_SYNC_BTN_M) == 0; - br = (btns & ZSMS_SYNC_BTN_R) == 0; - - /* for wsmouse(4), 1 is down, 0 is up, the most left button is LSB */ - btns = 0; - if (bl) - btns |= 1 << 0; - if (bm) - btns |= 1 << 1; - if (br) - btns |= 1 << 2; - - x = (int)sc->packet[ZSMS_PACKET_X1] + (int)sc->packet[ZSMS_PACKET_X2]; - y = (int)sc->packet[ZSMS_PACKET_Y1] + (int)sc->packet[ZSMS_PACKET_Y2]; - - WSMOUSE_INPUT(sc->wsmousedev, btns, x, y, 0, 0); -} - -int -zsms_wsmouse_enable(void *cookie) -{ - struct zsms_softc *sc = cookie; - - if (sc->enabled) - return (EBUSY); - - sc->state = ZSMS_STATE_SYNC; - sc->enabled = 1; - - return (0); -} - -void -zsms_wsmouse_disable(void *cookie) -{ - struct zsms_softc *sc = cookie; - - sc->enabled = 0; -} - -int -zsms_wsmouse_ioctl(void *cookie, u_long cmd, caddr_t data, int flag, - struct proc *p) -{ - switch (cmd) { - case WSMOUSEIO_GTYPE: - *(u_int *)data = WSMOUSE_TYPE_SGI; - break; - default: - return -1; - } - - return 0; -} diff --git a/sys/arch/sgi/hpc/zs.c b/sys/arch/sgi/hpc/zs.c deleted file mode 100644 index 2dc8a354180..00000000000 --- a/sys/arch/sgi/hpc/zs.c +++ /dev/null @@ -1,771 +0,0 @@ -/* $OpenBSD: zs.c,v 1.17 2021/03/11 11:17:00 jsg Exp $ */ -/* $NetBSD: zs.c,v 1.37 2011/02/20 07:59:50 matt Exp $ */ - -/*- - * Copyright (c) 1996, 2000 The NetBSD Foundation, Inc. - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Gordon W. Ross and Wayne Knowles - * - * 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. - */ - -/* - * Zilog Z8530 Dual UART driver (machine-dependent part) - * - * Runs two serial lines per chip using slave drivers. - * Plain tty/async lines use the zstty slave. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/conf.h> -#include <sys/device.h> -#include <sys/ioctl.h> -#include <sys/kernel.h> -#include <sys/proc.h> -#include <sys/tty.h> -#include <sys/time.h> -#include <sys/syslog.h> - -#include <mips64/archtype.h> -#include <mips64/arcbios.h> - -#include <machine/autoconf.h> -#include <machine/cpu.h> -#include <machine/z8530var.h> - -#include <dev/cons.h> - -#include <dev/ic/z8530reg.h> - -#include <sgi/hpc/hpcvar.h> -#include <sgi/hpc/hpcreg.h> - -/* - * Some warts needed by z8530tty.c - - * The default parity REALLY needs to be the same as the PROM uses, - * or you can not see messages done with printf during boot-up... - */ -int zs_def_cflag = (CREAD | CS8 | HUPCL); -int zs_major = 19; - -#define PCLK 3672000 /* PCLK pin input clock rate */ - -#ifndef ZS_DEFSPEED -#define ZS_DEFSPEED 9600 -#endif - -/* - * Define interrupt levels. - */ -#define ZSHARD_PRI 64 - -/* SGI shouldn't need ZS_DELAY() as recovery time is done in hardware? */ -#define ZS_DELAY() delay(2) - -/* The layout of this is hardware-dependent (padding, order). */ -struct zschan { - uint8_t pad1[3]; - volatile uint8_t zc_csr; /* ctrl,status, and indirect access */ - uint8_t pad2[3]; - volatile uint8_t zc_data; /* data */ -}; - -struct zsdevice { - struct zschan zs_chan_b; - struct zschan zs_chan_a; -}; - -/* Return the byte offset of element within a structure */ -#define OFFSET(struct_def, el) ((size_t)&((struct_def *)0)->el) - -#define ZS_CHAN_A OFFSET(struct zsdevice, zs_chan_a) -#define ZS_CHAN_B OFFSET(struct zsdevice, zs_chan_b) -#define ZS_REG_CSR 3 -#define ZS_REG_DATA 7 -static int zs_chan_offset[] = {ZS_CHAN_A, ZS_CHAN_B}; - -cons_decl(zs); -struct consdev zs_cn = { - zscnprobe, - zscninit, - zscngetc, - zscnputc, - zscnpollc, - NULL -}; - - -/* Flags from cninit() */ -static int zs_consunit = -1; -static int zs_conschan = -1; - -/* Default speed for all channels */ -static int zs_defspeed = ZS_DEFSPEED; - -static uint8_t zs_init_reg[17] = { - 0, /* 0: CMD (reset, etc.) */ - 0, /* 1: No interrupts yet. */ - ZSHARD_PRI, /* 2: IVECT */ - ZSWR3_RX_8 | ZSWR3_RX_ENABLE, - ZSWR4_CLK_X16 | ZSWR4_ONESB, - ZSWR5_TX_8 | ZSWR5_TX_ENABLE, - 0, /* 6: TXSYNC/SYNCLO */ - 0, /* 7: RXSYNC/SYNCHI */ - 0, /* 8: alias for data port */ - ZSWR9_MASTER_IE, - 0, /*10: Misc. TX/RX control bits */ - ZSWR11_TXCLK_BAUD | ZSWR11_RXCLK_BAUD | ZSWR11_TRXC_OUT_ENA, - BPS_TO_TCONST(PCLK/16, ZS_DEFSPEED), /*12: BAUDLO (default=9600) */ - 0, /*13: BAUDHI (default=9600) */ - ZSWR14_BAUD_ENA, - ZSWR15_BREAK_IE, - ZSWR7P_TX_FIFO /* 7': TX FIFO interrupt level */ -}; - - -/**************************************************************** - * Autoconfig - ****************************************************************/ - -/* Definition of the driver for autoconfig. */ -int zs_hpc_match(struct device *, void *, void *); -void zs_hpc_attach(struct device *, struct device *, void *); -int zs_print(void *, const char *name); - -struct cfdriver zs_cd = { - NULL, "zs", DV_TTY -}; - -struct cfattach zs_hpc_ca = { - sizeof(struct zsc_softc), zs_hpc_match, zs_hpc_attach -}; - -int zshard(void *); -void zssoft(void *); -struct zschan *zs_get_chan_addr(int, int); -int zs_getc(void *); -void zs_putc(void *, int); - -/* - * Is the zs chip present? - */ -int -zs_hpc_match(struct device *parent, void *vcf, void *aux) -{ - struct cfdata *cf = vcf; - struct hpc_attach_args *ha = aux; - - if (strcmp(ha->ha_name, cf->cf_driver->cd_name) == 0) - return (1); - - return (0); -} - -/* - * Attach a found zs. - * - * Match slave number to zs unit number, so that misconfiguration will - * not set up the keyboard as ttya, etc. - */ -void -zs_hpc_attach(struct device *parent, struct device *self, void *aux) -{ - struct zsc_softc *zsc = (void *)self; - struct cfdata *cf = self->dv_cfdata; - struct hpc_attach_args *haa = aux; - struct zsc_attach_args zsc_args; - struct zs_chanstate *cs; - struct zs_channel *ch; - int zs_unit, channel, err, s; - int has_fifo; - - zsc->zsc_bustag = haa->ha_st; - if ((err = bus_space_subregion(haa->ha_st, haa->ha_sh, - haa->ha_devoff, 0x10, - &zsc->zsc_base)) != 0) { - printf(": unable to map 85c30 registers, error = %d\n", - err); - return; - } - - zs_unit = zsc->zsc_dev.dv_unit; - - /* - * Initialize software state for each channel. - * - * Done in reverse order of channels since the first serial port - * is actually attached to the *second* channel, and vice versa. - * Doing it this way should force a 'zstty*' to attach zstty0 to - * channel 1 and zstty1 to channel 0. They couldn't have wired - * it up in a more sensible fashion, could they? - */ - for (channel = 1; channel >= 0; channel--) { - zsc_args.channel = channel; - ch = &zsc->zsc_cs_store[channel]; - cs = zsc->zsc_cs[channel] = (struct zs_chanstate *)ch; - - /* - * According to IRIX <sys/z8530.h>, on Indigo, the CTR, DCD, - * DTR and RTS bits are inverted. - * - * That is, inverted when compared to the Indy and Indigo 2 - * designs. However, it turns out that the Indigo wiring is - * the `natural' one, with these pins being inverted from - * what one would naively expect, on the other designs. - * - * Choose wiring logic according to the hardware we run on, - * and the device flags. - */ - if (sys_config.system_type != SGI_IP20) - ch->cs_flags |= ZSCFL_INVERT_WIRING; - if (cf->cf_flags & ZSCFL_INVERT_WIRING) - ch->cs_flags ^= ZSCFL_INVERT_WIRING; - - cs->cs_reg_csr = NULL; - cs->cs_reg_data = NULL; - cs->cs_channel = channel; - cs->cs_private = NULL; - cs->cs_ops = &zsops_null; - cs->cs_brg_clk = PCLK / 16; - - if (bus_space_subregion(zsc->zsc_bustag, zsc->zsc_base, - zs_chan_offset[channel], - sizeof(struct zschan), - &ch->cs_regs) != 0) { - printf(": cannot map regs\n"); - return; - } - ch->cs_bustag = zsc->zsc_bustag; - - /* - * Figure out whether this chip is a 8530 or a 85230. - */ - if (channel == 1) { - zs_write_reg(cs, 15, ZSWR15_ENABLE_ENHANCED); - has_fifo = zs_read_reg(cs, 15) & ZSWR15_ENABLE_ENHANCED; - - if (has_fifo) { - zs_write_reg(cs, 15, 0); - printf(": 85230\n"); - } else - printf(": 8530\n"); - } - - if (has_fifo) - zs_init_reg[15] |= ZSWR15_ENABLE_ENHANCED; - else - zs_init_reg[15] &= ~ZSWR15_ENABLE_ENHANCED; - memcpy(cs->cs_creg, zs_init_reg, 17); - memcpy(cs->cs_preg, zs_init_reg, 17); - - /* If console, don't stomp speed, let zstty know */ - if (zs_unit == zs_consunit && channel == zs_conschan) { - zsc_args.consdev = &zs_cn; - zsc_args.hwflags = ZS_HWFLAG_CONSOLE; - cs->cs_defspeed = bios_consrate; - } else { - zsc_args.consdev = NULL; - zsc_args.hwflags = 0; - cs->cs_defspeed = zs_defspeed; - } - - cs->cs_defcflag = zs_def_cflag; - - /* Make these correspond to cs_defcflag (-crtscts) */ - cs->cs_rr0_dcd = ZSRR0_DCD; - cs->cs_rr0_cts = 0; - cs->cs_wr5_dtr = ZSWR5_DTR | ZSWR5_RTS; - cs->cs_wr5_rts = 0; - - /* - * Clear the master interrupt enable. - * The INTENA is common to both channels, - * so just do it on the A channel. - */ - if (channel == 0) { - zs_write_reg(cs, 9, 0); - } - /* - * Look for a child driver for this channel. - * The child attach will setup the hardware. - */ - if (!config_found(self, (void *)&zsc_args, zs_print)) { - /* No sub-driver. Just reset it. */ - uint8_t reset = (channel == 0) ? - ZSWR9_A_RESET : ZSWR9_B_RESET; - - s = splhigh(); - zs_write_reg(cs, 9, reset); - splx(s); - } - } - - - zsc->sc_si = softintr_establish(IPL_SOFTTTY, zssoft, zsc); - hpc_intr_establish(haa->ha_irq, IPL_TTY, zshard, zsc, self->dv_xname); - - /* - * Set the master interrupt enable and interrupt vector. - * (common to both channels, do it on A) - */ - cs = zsc->zsc_cs[0]; - s = splhigh(); - /* interrupt vector */ - zs_write_reg(cs, 2, zs_init_reg[2]); - /* master interrupt control (enable) */ - zs_write_reg(cs, 9, zs_init_reg[9]); - splx(s); -} - -int -zs_print(void *aux, const char *name) -{ - struct zsc_attach_args *args = aux; - - if (name != NULL) - printf("%s:", name); - - if (args->channel != -1) - printf(" channel %d", args->channel); - - return UNCONF; -} - -/* - * Our ZS chips all share a common, autovectored interrupt, - * so we have to look at all of them on each interrupt. - */ -int -zshard(void *arg) -{ - struct zsc_softc *zsc = arg; - int rval; - - rval = zsc_intr_hard(zsc); - if (rval != 0) { - if (zsc->zsc_cs[0]->cs_softreq || - zsc->zsc_cs[1]->cs_softreq) - softintr_schedule(zsc->sc_si); - } - - return rval; -} - -/* - * Similar scheme as for zshard (look at all of them) - */ -void -zssoft(void *arg) -{ - struct zsc_softc *zsc = arg; - int s; - - /* Make sure we call the tty layer at spltty. */ - s = spltty(); - (void)zsc_intr_soft(zsc); - splx(s); -} - - -/* - * MD functions for setting the baud rate and control modes. - */ -int -zs_set_speed(struct zs_chanstate *cs, int bps) -{ - int tconst, real_bps; - - if (bps == 0) - return (0); - -#ifdef DIAGNOSTIC - if (cs->cs_brg_clk == 0) - panic("zs_set_speed"); -#endif - - tconst = BPS_TO_TCONST(cs->cs_brg_clk, bps); - if (tconst < 0) - return (EINVAL); - - /* Convert back to make sure we can do it. */ - real_bps = TCONST_TO_BPS(cs->cs_brg_clk, tconst); - -#if 0 /* PCLK is too small, 9600bps really yields 9562 */ - /* XXX - Allow some tolerance here? */ - if (real_bps != bps) - return (EINVAL); -#endif - - cs->cs_preg[12] = tconst; - cs->cs_preg[13] = tconst >> 8; - - /* Caller will stuff the pending registers. */ - return (0); -} - -int -zs_set_modes(struct zs_chanstate *cs, int cflag) -{ - int s; - - /* - * Output hardware flow control on the chip is horrendous: - * if carrier detect drops, the receiver is disabled, and if - * CTS drops, the transmitter is stopped IN MID CHARACTER! - * Therefore, NEVER set the HFC bit, and instead use the - * status interrupt to detect CTS changes. - */ - s = splzs(); - cs->cs_rr0_pps = 0; - if ((cflag & (CLOCAL | MDMBUF)) != 0) { - cs->cs_rr0_dcd = 0; - if ((cflag & MDMBUF) == 0) - cs->cs_rr0_pps = ZSRR0_DCD; - } else - cs->cs_rr0_dcd = ZSRR0_DCD; - if ((cflag & CRTSCTS) != 0) { - cs->cs_wr5_dtr = ZSWR5_DTR; - cs->cs_wr5_rts = ZSWR5_RTS; - cs->cs_rr0_cts = ZSRR0_CTS; - } else if ((cflag & MDMBUF) != 0) { - cs->cs_wr5_dtr = 0; - cs->cs_wr5_rts = ZSWR5_DTR; - cs->cs_rr0_cts = ZSRR0_DCD; - } else { - cs->cs_wr5_dtr = ZSWR5_DTR | ZSWR5_RTS; - cs->cs_wr5_rts = 0; - cs->cs_rr0_cts = 0; - } - splx(s); - - /* Caller will stuff the pending registers. */ - return (0); -} - - -/* - * Read or write the chip with suitable delays. - */ - -uint8_t -zs_read_reg(struct zs_chanstate *cs, uint8_t reg) -{ - uint8_t val; - struct zs_channel *zsc = (struct zs_channel *)cs; - - bus_space_write_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, reg); - bus_space_barrier(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, 1, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - ZS_DELAY(); - val = bus_space_read_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR); - ZS_DELAY(); - - if ((zsc->cs_flags & ZSCFL_INVERT_WIRING) && reg == 0) - val ^= ZSRR0_CTS | ZSRR0_DCD; - - return val; -} - -void -zs_write_reg(struct zs_chanstate *cs, uint8_t reg, uint8_t val) -{ - struct zs_channel *zsc = (struct zs_channel *)cs; - - if ((zsc->cs_flags & ZSCFL_INVERT_WIRING) && reg == 5) - val ^= ZSWR5_DTR | ZSWR5_RTS; - - bus_space_write_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, reg); - bus_space_barrier(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, 1, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - ZS_DELAY(); - bus_space_write_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, val); - bus_space_barrier(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, 1, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - ZS_DELAY(); -} - -uint8_t -zs_read_csr(struct zs_chanstate *cs) -{ - struct zs_channel *zsc = (struct zs_channel *)cs; - uint8_t val; - - val = bus_space_read_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR); - ZS_DELAY(); - - if (zsc->cs_flags & ZSCFL_INVERT_WIRING) - val ^= ZSRR0_CTS | ZSRR0_DCD; - - return val; -} - -void -zs_write_csr(struct zs_chanstate *cs, uint8_t val) -{ - struct zs_channel *zsc = (struct zs_channel *)cs; - - bus_space_write_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, val); - bus_space_barrier(zsc->cs_bustag, zsc->cs_regs, ZS_REG_CSR, 1, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - ZS_DELAY(); -} - -uint8_t -zs_read_data(struct zs_chanstate *cs) -{ - struct zs_channel *zsc = (struct zs_channel *)cs; - uint8_t val; - - val = bus_space_read_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_DATA); - ZS_DELAY(); - return val; -} - -void -zs_write_data(struct zs_chanstate *cs, uint8_t val) -{ - struct zs_channel *zsc = (struct zs_channel *)cs; - - bus_space_write_1(zsc->cs_bustag, zsc->cs_regs, ZS_REG_DATA, val); - bus_space_barrier(zsc->cs_bustag, zsc->cs_regs, ZS_REG_DATA, 1, - BUS_SPACE_BARRIER_READ | BUS_SPACE_BARRIER_WRITE); - ZS_DELAY(); -} - -void -zs_abort(struct zs_chanstate *cs) -{ -#if defined(DDB) - db_enter(); -#endif -} - - -/*****************************************************/ -/* Polled character I/O functions for console KGDB */ -/*****************************************************/ - -struct zschan * -zs_get_chan_addr(int zs_unit, int channel) -{ -#if 0 - static int dumped_addr = 0; -#endif - struct zsdevice *addr = NULL; - struct zschan *zc; - - switch (sys_config.system_type) { - case SGI_IP20: - switch (zs_unit) { - case 0: - addr = (struct zsdevice *) - PHYS_TO_XKPHYS(0x1fb80d00, CCA_NC); - break; - case 1: - addr = (struct zsdevice *) - PHYS_TO_XKPHYS(0x1fb80d10, CCA_NC); - break; - } - break; - - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - if (zs_unit == 0) - addr = (struct zsdevice *) - PHYS_TO_XKPHYS(0x1fbd9830, CCA_NC); - break; - } - if (addr == NULL) - panic("zs_get_chan_addr: bad zs_unit %d\n", zs_unit); - - /* - * We need to swap serial ports to match reality on - * non-keyboard channels. - */ - if (sys_config.system_type != SGI_IP20) { - if (channel == 0) - zc = &addr->zs_chan_b; - else - zc = &addr->zs_chan_a; - } else { - if (zs_unit == 0) { - if (channel == 0) - zc = &addr->zs_chan_a; - else - zc = &addr->zs_chan_b; - } else { - if (channel == 0) - zc = &addr->zs_chan_b; - else - zc = &addr->zs_chan_a; - } - } - -#if 0 - if (dumped_addr == 0) { - dumped_addr++; - printf("zs unit %d, channel %d had address %p\n", - zs_unit, channel, zc); - } -#endif - - return (zc); -} - -int -zs_getc(void *arg) -{ - register volatile struct zschan *zc = arg; - register int s, c, rr0; - - s = splzs(); - /* Wait for a character to arrive. */ - do { - rr0 = zc->zc_csr; - ZS_DELAY(); - } while ((rr0 & ZSRR0_RX_READY) == 0); - - c = zc->zc_data; - ZS_DELAY(); - splx(s); - - return (c); -} - -/* - * Polled output char. - */ -void -zs_putc(void *arg, int c) -{ - register volatile struct zschan *zc = arg; - register int s, rr0; - - s = splzs(); - /* Wait for transmitter to become ready. */ - do { - rr0 = zc->zc_csr; - ZS_DELAY(); - } while ((rr0 & ZSRR0_TX_READY) == 0); - - zc->zc_data = c; - - /* inline bus_space_barrier() */ - mips_sync(); - if (sys_config.system_type != SGI_IP20) { - (void)*(volatile uint32_t *)PHYS_TO_XKPHYS(HPC_BASE_ADDRESS_0 + - HPC3_INTRSTAT_40, CCA_NC); - } - - ZS_DELAY(); - splx(s); -} - -/***************************************************************/ - -static int cons_port; - -void -zscnprobe(struct consdev *cp) -{ - cp->cn_dev = makedev(zs_major, 0); - cp->cn_pri = CN_DEAD; - - switch (sys_config.system_type) { - case SGI_IP20: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - if (strlen(bios_console) == 9 && - strncmp(bios_console, "serial", 6) == 0) - cp->cn_pri = CN_FORCED; - else - cp->cn_pri = CN_MIDPRI; - break; - } -} - -void -zscninit(struct consdev *cn) -{ - if (strlen(bios_console) == 9 && - strncmp(bios_console, "serial", 6) != 0) - cons_port = bios_console[7] - '0'; - - /* Mark this unit as the console */ - zs_consunit = 0; - - /* SGI hardware wires serial port 1 to channel B, port 2 to A */ - if (cons_port == 0) - zs_conschan = 1; - else - zs_conschan = 0; -} - -int -zscngetc(dev_t dev) -{ - struct zschan *zs; - - switch (sys_config.system_type) { - case SGI_IP20: - zs = zs_get_chan_addr(1, cons_port); - break; - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - default: - zs = zs_get_chan_addr(0, cons_port); - break; - } - - return zs_getc(zs); -} - -void -zscnputc(dev_t dev, int c) -{ - struct zschan *zs; - - switch (sys_config.system_type) { - case SGI_IP20: - zs = zs_get_chan_addr(1, cons_port); - break; - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - default: - zs = zs_get_chan_addr(0, cons_port); - break; - } - - zs_putc(zs, c); -} - -void -zscnpollc(dev_t dev, int on) -{ -} diff --git a/sys/arch/sgi/include/_float.h b/sys/arch/sgi/include/_float.h deleted file mode 100644 index e7b4a14c95b..00000000000 --- a/sys/arch/sgi/include/_float.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: _float.h,v 1.1 2012/06/26 16:12:44 deraadt Exp $ */ - -#include <mips64/_float.h> diff --git a/sys/arch/sgi/include/_types.h b/sys/arch/sgi/include/_types.h deleted file mode 100644 index 600456175e0..00000000000 --- a/sys/arch/sgi/include/_types.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: _types.h,v 1.3 2007/05/15 15:23:36 art Exp $ */ - -/* public domain */ -#include <mips64/_types.h> - diff --git a/sys/arch/sgi/include/asm.h b/sys/arch/sgi/include/asm.h deleted file mode 100644 index 7aee16c31f5..00000000000 --- a/sys/arch/sgi/include/asm.h +++ /dev/null @@ -1,39 +0,0 @@ -/* $OpenBSD: asm.h,v 1.6 2015/12/25 05:52:29 visa Exp $ */ -#ifndef _SGI_ASM_H_ -#define _SGI_ASM_H_ - -#include <mips64/asm.h> -#ifdef TGT_OCTANE -#include <sgi/sgi/ip30.h> -#endif - -#ifdef MULTIPROCESSOR - -#if defined(TGT_OCTANE) - -#include <sgi/xbow/xheartreg.h> - -/* Returns the physical cpu identifier */ -#define HW_GET_CPU_PRID(prid, tmp) \ - LOAD_XKPHYS(tmp, CCA_NC); \ - PTR_L prid, (HEART_PIU_BASE + HEART_PRID)(tmp) \ - -/* Return the cpu_info pointer - see locore.S for the logic behind this */ -#define HW_GET_CPU_INFO(ci, tmp) \ - HW_GET_CPU_PRID(ci, tmp); \ - LOAD_XKPHYS(tmp, CCA_COHERENT_EXCLWRITE); \ - PTR_SLL ci, MPCONF_SHIFT; \ - PTR_ADD ci, MPCONF_BASE; \ - or tmp, ci; \ - PTR_L ci, (MPCONF_LEN - REGSZ)(tmp) - -#elif defined(TGT_ORIGIN) - -#define HW_GET_CPU_INFO(ci, tmp) \ - DMFC0 ci, COP_0_ERROR_PC - -#endif /* TGT_ORIGIN */ - -#endif /* MULTIPROCESSOR */ - -#endif /* _SGI_ASM_H_ */ diff --git a/sys/arch/sgi/include/atomic.h b/sys/arch/sgi/include/atomic.h deleted file mode 100644 index bc1f3a4a1cf..00000000000 --- a/sys/arch/sgi/include/atomic.h +++ /dev/null @@ -1,10 +0,0 @@ -/* $OpenBSD: atomic.h,v 1.3 2011/03/23 16:54:36 pirofti Exp $ */ - -/* Public Domain */ - -#ifndef _MACHINE_ATOMIC_H_ -#define _MACHINE_ATOMIC_H_ - -#include <mips64/atomic.h> - -#endif /* _MACHINE_ATOMIC_H_ */ diff --git a/sys/arch/sgi/include/autoconf.h b/sys/arch/sgi/include/autoconf.h deleted file mode 100644 index a76335f6b6a..00000000000 --- a/sys/arch/sgi/include/autoconf.h +++ /dev/null @@ -1,110 +0,0 @@ -/* $OpenBSD: autoconf.h,v 1.39 2015/12/25 08:34:50 visa Exp $ */ - -/* - * Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -/* - * Definitions used by autoconfiguration. - */ - -#ifndef _MACHINE_AUTOCONF_H_ -#define _MACHINE_AUTOCONF_H_ - -#include <machine/bus.h> - -/* - * Structure holding all misc config information. - */ -struct cpu_info; - -struct sys_rec { - int system_type; - int system_subtype; /* IP35 only */ - - /* Serial console configuration. */ - struct mips_bus_space console_io; -}; - -extern struct sys_rec sys_config; - -/* - * Attachment information for mainbus child devices. - */ -struct mainbus_attach_args { - const char *maa_name; - int16_t maa_nasid; - int16_t maa_physid; -}; - -/* - * Device physical location information. Used to match console and boot - * devices on IP27 and IP30 kernels. - */ -struct sgi_device_location { - int16_t nasid; /* node identifier */ - uint widget; /* widget number */ - - int bus; /* bus number if connected to PIC */ - int device; /* device number if PCI */ - int fn; /* function number if PCI */ - - uint32_t specific; /* port on dual-scsibus controllers, - device id on serial controllers */ -}; - -#include <mips64/autoconf.h> - -void enaddr_aton(const char *, u_int8_t *); -u_long bios_getenvint(const char *); - -struct device; - -void arcs_device_register(struct device *, void *); -void dksc_device_register(struct device *, void *); -extern void (*_device_register)(struct device *, void *); - -void ip22_setup(void); -void ip22_post_autoconf(void); -void ip27_setup(void); -void ip27_autoconf(struct device *); -void ip30_setup(void); -void ip30_autoconf(struct device *); -void ip32_setup(void); - -extern char osloadpartition[256]; -extern char osloadoptions[129]; -extern int16_t masternasid; -extern int16_t currentnasid; - -extern struct sgi_device_location console_output, console_input; - -int location_match(struct sgi_device_location *, - struct sgi_device_location *); - -extern void (*md_halt)(int); -void arcbios_halt(int); - -#endif /* _MACHINE_AUTOCONF_H_ */ diff --git a/sys/arch/sgi/include/bus.h b/sys/arch/sgi/include/bus.h deleted file mode 100644 index 82eca8966c8..00000000000 --- a/sys/arch/sgi/include/bus.h +++ /dev/null @@ -1,481 +0,0 @@ -/* $OpenBSD: bus.h,v 1.29 2020/04/14 17:35:28 kettenis Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB Sweden. 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 ``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 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. - */ - -#ifndef _MACHINE_BUS_H_ -#define _MACHINE_BUS_H_ - -#ifdef __STDC__ -#define CAT(a,b) a##b -#define CAT3(a,b,c) a##b##c -#else -#define CAT(a,b) a/**/b -#define CAT3(a,b,c) a/**/b/**/c -#endif - -/* - * Bus access types. - */ -struct mips_bus_space; -typedef u_long bus_addr_t; -typedef u_long bus_size_t; -typedef u_long bus_space_handle_t; -typedef struct mips_bus_space *bus_space_tag_t; -typedef struct mips_bus_space bus_space_t; - -struct mips_bus_space { - bus_addr_t bus_base; - void *bus_private; - u_int8_t (*_space_read_1)(bus_space_tag_t , bus_space_handle_t, - bus_size_t); - void (*_space_write_1)(bus_space_tag_t , bus_space_handle_t, - bus_size_t, u_int8_t); - u_int16_t (*_space_read_2)(bus_space_tag_t , bus_space_handle_t, - bus_size_t); - void (*_space_write_2)(bus_space_tag_t , bus_space_handle_t, - bus_size_t, u_int16_t); - u_int32_t (*_space_read_4)(bus_space_tag_t , bus_space_handle_t, - bus_size_t); - void (*_space_write_4)(bus_space_tag_t , bus_space_handle_t, - bus_size_t, u_int32_t); - u_int64_t (*_space_read_8)(bus_space_tag_t , bus_space_handle_t, - bus_size_t); - void (*_space_write_8)(bus_space_tag_t , bus_space_handle_t, - bus_size_t, u_int64_t); - void (*_space_read_raw_2)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, u_int8_t *, bus_size_t); - void (*_space_write_raw_2)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, const u_int8_t *, bus_size_t); - void (*_space_read_raw_4)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, u_int8_t *, bus_size_t); - void (*_space_write_raw_4)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, const u_int8_t *, bus_size_t); - void (*_space_read_raw_8)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, u_int8_t *, bus_size_t); - void (*_space_write_raw_8)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, const u_int8_t *, bus_size_t); - int (*_space_map)(bus_space_tag_t , bus_addr_t, - bus_size_t, int, bus_space_handle_t *); - void (*_space_unmap)(bus_space_tag_t, bus_space_handle_t, - bus_size_t); - int (*_space_subregion)(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_size_t, bus_space_handle_t *); - void * (*_space_vaddr)(bus_space_tag_t, bus_space_handle_t); - void (*_space_barrier)(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_size_t, int); -}; - -#define bus_space_read_1(t, h, o) (*(t)->_space_read_1)((t), (h), (o)) -#define bus_space_read_2(t, h, o) (*(t)->_space_read_2)((t), (h), (o)) -#define bus_space_read_4(t, h, o) (*(t)->_space_read_4)((t), (h), (o)) -#define bus_space_read_8(t, h, o) (*(t)->_space_read_8)((t), (h), (o)) - -#define bus_space_write_1(t, h, o, v) (*(t)->_space_write_1)((t), (h), (o), (v)) -#define bus_space_write_2(t, h, o, v) (*(t)->_space_write_2)((t), (h), (o), (v)) -#define bus_space_write_4(t, h, o, v) (*(t)->_space_write_4)((t), (h), (o), (v)) -#define bus_space_write_8(t, h, o, v) (*(t)->_space_write_8)((t), (h), (o), (v)) - -#define bus_space_read_raw_multi_2(t, h, a, b, l) \ - (*(t)->_space_read_raw_2)((t), (h), (a), (b), (l)) -#define bus_space_read_raw_multi_4(t, h, a, b, l) \ - (*(t)->_space_read_raw_4)((t), (h), (a), (b), (l)) -#define bus_space_read_raw_multi_8(t, h, a, b, l) \ - (*(t)->_space_read_raw_8)((t), (h), (a), (b), (l)) - -#define bus_space_write_raw_multi_2(t, h, a, b, l) \ - (*(t)->_space_write_raw_2)((t), (h), (a), (b), (l)) -#define bus_space_write_raw_multi_4(t, h, a, b, l) \ - (*(t)->_space_write_raw_4)((t), (h), (a), (b), (l)) -#define bus_space_write_raw_multi_8(t, h, a, b, l) \ - (*(t)->_space_write_raw_8)((t), (h), (a), (b), (l)) - -#define bus_space_map(t, o, s, c, p) (*(t)->_space_map)((t), (o), (s), (c), (p)) -#define bus_space_unmap(t, h, s) (*(t)->_space_unmap)((t), (h), (s)) -#define bus_space_subregion(t, h, o, s, p) \ - (*(t)->_space_subregion)((t), (h), (o), (s), (p)) - -#define BUS_SPACE_MAP_CACHEABLE 0x01 -#define BUS_SPACE_MAP_LINEAR 0x02 -#define BUS_SPACE_MAP_PREFETCHABLE 0x04 - -#define bus_space_vaddr(t, h) (*(t)->_space_vaddr)((t), (h)) - -/*----------------------------------------------------------------------------*/ -#define bus_space_read_multi(n,m) \ -static __inline void \ -CAT(bus_space_read_multi_,n)(bus_space_tag_t bst, bus_space_handle_t bsh, \ - bus_size_t o, CAT3(u_int,m,_t) *x, size_t cnt) \ -{ \ - while (cnt--) \ - *x++ = CAT(bus_space_read_,n)(bst, bsh, o); \ -} - -bus_space_read_multi(1,8) -bus_space_read_multi(2,16) -bus_space_read_multi(4,32) -bus_space_read_multi(8,64) - -/*----------------------------------------------------------------------------*/ -#define bus_space_read_region(n,m) \ -static __inline void \ -CAT(bus_space_read_region_,n)(bus_space_tag_t bst, bus_space_handle_t bsh, \ - bus_addr_t ba, CAT3(u_int,m,_t) *x, size_t cnt) \ -{ \ - while (cnt--) { \ - *x++ = CAT(bus_space_read_,n)(bst, bsh, ba); \ - ba += (n); \ - } \ -} - -bus_space_read_region(1,8) -bus_space_read_region(2,16) -bus_space_read_region(4,32) -bus_space_read_region(8,64) - -/*----------------------------------------------------------------------------*/ -#define bus_space_read_raw_region(n,m) \ -static __inline void \ -CAT(bus_space_read_raw_region_,n)(bus_space_tag_t bst, \ - bus_space_handle_t bsh, \ - bus_addr_t ba, u_int8_t *x, size_t cnt) \ -{ \ - cnt >>= ((n) >> 1); \ - while (cnt--) { \ - CAT(bus_space_read_raw_multi_,n)(bst, bsh, ba, x, (n)); \ - ba += (n); \ - x += (n); \ - } \ -} - -bus_space_read_raw_region(2,16) -bus_space_read_raw_region(4,32) -bus_space_read_raw_region(8,64) - -/*----------------------------------------------------------------------------*/ -#define bus_space_write_multi(n,m) \ -static __inline void \ -CAT(bus_space_write_multi_,n)(bus_space_tag_t bst, bus_space_handle_t bsh, \ - bus_size_t o, const CAT3(u_int,m,_t) *x, size_t cnt) \ -{ \ - while (cnt--) \ - CAT(bus_space_write_,n)(bst, bsh, o, *x++); \ -} - -bus_space_write_multi(1,8) -bus_space_write_multi(2,16) -bus_space_write_multi(4,32) -bus_space_write_multi(8,64) - -/*----------------------------------------------------------------------------*/ -#define bus_space_write_region(n,m) \ -static __inline void \ -CAT(bus_space_write_region_,n)(bus_space_tag_t bst, bus_space_handle_t bsh, \ - bus_addr_t ba, const CAT3(u_int,m,_t) *x, size_t cnt) \ -{ \ - while (cnt--) { \ - CAT(bus_space_write_,n)(bst, bsh, ba, *x++); \ - ba += (n); \ - } \ -} - -bus_space_write_region(1,8) -bus_space_write_region(2,16) -bus_space_write_region(4,32) -bus_space_write_region(8,64) - -/*----------------------------------------------------------------------------*/ -#define bus_space_write_raw_region(n,m) \ -static __inline void \ -CAT(bus_space_write_raw_region_,n)(bus_space_tag_t bst, \ - bus_space_handle_t bsh, \ - bus_addr_t ba, const u_int8_t *x, size_t cnt) \ -{ \ - cnt >>= ((n) >> 1); \ - while (cnt--) { \ - CAT(bus_space_write_raw_multi_,n)(bst, bsh, ba, x, (n)); \ - ba += (n); \ - x += (n); \ - } \ -} - -bus_space_write_raw_region(2,16) -bus_space_write_raw_region(4,32) -bus_space_write_raw_region(8,64) - -/*----------------------------------------------------------------------------*/ -#define bus_space_set_region(n,m) \ -static __inline void \ -CAT(bus_space_set_region_,n)(bus_space_tag_t bst, bus_space_handle_t bsh, \ - bus_addr_t ba, CAT3(u_int,m,_t) x, size_t cnt) \ -{ \ - while (cnt--) { \ - CAT(bus_space_write_,n)(bst, bsh, ba, x); \ - ba += (n); \ - } \ -} - -bus_space_set_region(1,8) -bus_space_set_region(2,16) -bus_space_set_region(4,32) -bus_space_set_region(8,64) - -/*----------------------------------------------------------------------------*/ -static __inline void -bus_space_copy_1(void *v, bus_space_handle_t h1, bus_size_t o1, - bus_space_handle_t h2, bus_size_t o2, bus_size_t c) -{ - char *s = (char *)(h1 + o1); - char *d = (char *)(h2 + o2); - - while (c--) - *d++ = *s++; -} - - -static __inline void -bus_space_copy_2(void *v, bus_space_handle_t h1, bus_size_t o1, - bus_space_handle_t h2, bus_size_t o2, bus_size_t c) -{ - short *s = (short *)(h1 + o1); - short *d = (short *)(h2 + o2); - - while (c--) - *d++ = *s++; -} - -static __inline void -bus_space_copy_4(void *v, bus_space_handle_t h1, bus_size_t o1, - bus_space_handle_t h2, bus_size_t o2, bus_size_t c) -{ - int *s = (int *)(h1 + o1); - int *d = (int *)(h2 + o2); - - while (c--) - *d++ = *s++; -} - -static __inline void -bus_space_copy_8(void *v, bus_space_handle_t h1, bus_size_t o1, - bus_space_handle_t h2, bus_size_t o2, bus_size_t c) -{ - int64_t *s = (int64_t *)(h1 + o1); - int64_t *d = (int64_t *)(h2 + o2); - - while (c--) - *d++ = *s++; -} - -/*----------------------------------------------------------------------------*/ -/* - * Bus read/write barrier methods. - * - * void bus_space_barrier(bus_space_tag_t tag, - * bus_space_handle_t bsh, bus_size_t offset, - * bus_size_t len, int flags); - * - */ -static __inline void -bus_space_barrier(bus_space_tag_t t, bus_space_handle_t h, bus_size_t offs, - bus_size_t len, int flags) -{ - (*(t)->_space_barrier)(t, h, offs, len, flags); -} - -#define BUS_SPACE_BARRIER_READ 0x01 /* force read barrier */ -#define BUS_SPACE_BARRIER_WRITE 0x02 /* force write barrier */ - -#define BUS_DMA_WAITOK 0x0000 -#define BUS_DMA_NOWAIT 0x0001 -#define BUS_DMA_ALLOCNOW 0x0002 -#define BUS_DMA_COHERENT 0x0008 -#define BUS_DMA_BUS1 0x0010 /* placeholders for bus functions... */ -#define BUS_DMA_BUS2 0x0020 -#define BUS_DMA_BUS3 0x0040 -#define BUS_DMA_BUS4 0x0080 -#define BUS_DMA_READ 0x0100 /* mapping is device -> memory only */ -#define BUS_DMA_WRITE 0x0200 /* mapping is memory -> device only */ -#define BUS_DMA_STREAMING 0x0400 /* hint: sequential, unidirectional */ -#define BUS_DMA_ZERO 0x0800 /* zero memory in dmamem_alloc */ -#define BUS_DMA_NOCACHE 0x1000 -#define BUS_DMA_64BIT 0x2000 /* device handles 64bit dva */ - -/* Forwards needed by prototypes below. */ -struct mbuf; -struct proc; -struct uio; - -#define BUS_DMASYNC_POSTREAD 0x0001 -#define BUS_DMASYNC_POSTWRITE 0x0002 -#define BUS_DMASYNC_PREREAD 0x0004 -#define BUS_DMASYNC_PREWRITE 0x0008 - -typedef struct machine_bus_dma_tag *bus_dma_tag_t; -typedef struct machine_bus_dmamap *bus_dmamap_t; - -/* - * bus_dma_segment_t - * - * Describes a single contiguous DMA transaction. Values - * are suitable for programming into DMA registers. - */ -struct machine_bus_dma_segment { - bus_addr_t ds_addr; /* DMA address */ - bus_size_t ds_len; /* length of transfer */ - - paddr_t _ds_paddr; /* CPU address */ - vaddr_t _ds_vaddr; /* CPU address - only valid after - calling bus_dmamap_load*() */ -}; -typedef struct machine_bus_dma_segment bus_dma_segment_t; - -/* - * bus_dma_tag_t - * - * A machine-dependent opaque type describing the implementation of - * DMA for a given bus. - */ - -struct machine_bus_dma_tag { - void *_cookie; /* cookie used in the guts */ - - /* - * DMA mapping methods. - */ - int (*_dmamap_create)(bus_dma_tag_t , bus_size_t, int, - bus_size_t, bus_size_t, int, bus_dmamap_t *); - void (*_dmamap_destroy)(bus_dma_tag_t , bus_dmamap_t); - int (*_dmamap_load)(bus_dma_tag_t , bus_dmamap_t, void *, - bus_size_t, struct proc *, int); - int (*_dmamap_load_mbuf)(bus_dma_tag_t , bus_dmamap_t, - struct mbuf *, int); - int (*_dmamap_load_uio)(bus_dma_tag_t , bus_dmamap_t, - struct uio *, int); - int (*_dmamap_load_raw)(bus_dma_tag_t , bus_dmamap_t, - bus_dma_segment_t *, int, bus_size_t, int); - int (*_dmamap_load_buffer)(bus_dma_tag_t, bus_dmamap_t, void *, - bus_size_t, struct proc *, int, paddr_t *, int *, int); - void (*_dmamap_unload)(bus_dma_tag_t , bus_dmamap_t); - void (*_dmamap_sync)(bus_dma_tag_t , bus_dmamap_t, - bus_addr_t, bus_size_t, int); - - /* - * DMA memory utility functions. - */ - int (*_dmamem_alloc)(bus_dma_tag_t, bus_size_t, bus_size_t, - bus_size_t, bus_dma_segment_t *, int, int *, int); - void (*_dmamem_free)(bus_dma_tag_t, bus_dma_segment_t *, int); - int (*_dmamem_map)(bus_dma_tag_t, bus_dma_segment_t *, - int, size_t, caddr_t *, int); - void (*_dmamem_unmap)(bus_dma_tag_t, caddr_t, size_t); - paddr_t (*_dmamem_mmap)(bus_dma_tag_t, bus_dma_segment_t *, - int, off_t, int, int); - - /* - * internal memory address translation information. - */ - bus_addr_t (*_pa_to_device)(paddr_t, int); - bus_addr_t _dma_mask; -}; - -#define bus_dmamap_create(t, s, n, m, b, f, p) \ - (*(t)->_dmamap_create)((t), (s), (n), (m), (b), (f), (p)) -#define bus_dmamap_destroy(t, p) \ - (*(t)->_dmamap_destroy)((t), (p)) -#define bus_dmamap_load(t, m, b, s, p, f) \ - (*(t)->_dmamap_load)((t), (m), (b), (s), (p), (f)) -#define bus_dmamap_load_mbuf(t, m, b, f) \ - (*(t)->_dmamap_load_mbuf)((t), (m), (b), (f)) -#define bus_dmamap_load_uio(t, m, u, f) \ - (*(t)->_dmamap_load_uio)((t), (m), (u), (f)) -#define bus_dmamap_load_raw(t, m, sg, n, s, f) \ - (*(t)->_dmamap_load_raw)((t), (m), (sg), (n), (s), (f)) -#define bus_dmamap_unload(t, p) \ - (*(t)->_dmamap_unload)((t), (p)) -#define bus_dmamap_sync(t, p, a, l, o) \ - (void)((t)->_dmamap_sync ? \ - (*(t)->_dmamap_sync)((t), (p), (a), (l), (o)) : (void)0) - -#define bus_dmamem_alloc(t, s, a, b, sg, n, r, f) \ - (*(t)->_dmamem_alloc)((t), (s), (a), (b), (sg), (n), (r), (f)) -#define bus_dmamem_free(t, sg, n) \ - (*(t)->_dmamem_free)((t), (sg), (n)) -#define bus_dmamem_map(t, sg, n, s, k, f) \ - (*(t)->_dmamem_map)((t), (sg), (n), (s), (k), (f)) -#define bus_dmamem_unmap(t, k, s) \ - (*(t)->_dmamem_unmap)((t), (k), (s)) -#define bus_dmamem_mmap(t, sg, n, o, p, f) \ - (*(t)->_dmamem_mmap)((t), (sg), (n), (o), (p), (f)) - -int _dmamap_create(bus_dma_tag_t, bus_size_t, int, - bus_size_t, bus_size_t, int, bus_dmamap_t *); -void _dmamap_destroy(bus_dma_tag_t, bus_dmamap_t); -int _dmamap_load(bus_dma_tag_t, bus_dmamap_t, void *, - bus_size_t, struct proc *, int); -int _dmamap_load_mbuf(bus_dma_tag_t, bus_dmamap_t, struct mbuf *, int); -int _dmamap_load_uio(bus_dma_tag_t, bus_dmamap_t, struct uio *, int); -int _dmamap_load_raw(bus_dma_tag_t, bus_dmamap_t, - bus_dma_segment_t *, int, bus_size_t, int); -int _dmamap_load_buffer(bus_dma_tag_t, bus_dmamap_t, void *, - bus_size_t, struct proc *, int, paddr_t *, int *, int); -void _dmamap_unload(bus_dma_tag_t, bus_dmamap_t); -void _dmamap_sync(bus_dma_tag_t, bus_dmamap_t, bus_addr_t, - bus_size_t, int); - -int _dmamem_alloc(bus_dma_tag_t, bus_size_t, bus_size_t, - bus_size_t, bus_dma_segment_t *, int, int *, int); -void _dmamem_free(bus_dma_tag_t, bus_dma_segment_t *, int); -int _dmamem_map(bus_dma_tag_t, bus_dma_segment_t *, - int, size_t, caddr_t *, int); -void _dmamem_unmap(bus_dma_tag_t, caddr_t, size_t); -paddr_t _dmamem_mmap(bus_dma_tag_t, bus_dma_segment_t *, int, off_t, int, int); -int _dmamem_alloc_range(bus_dma_tag_t, bus_size_t, bus_size_t, bus_size_t, - bus_dma_segment_t *, int, int *, int, paddr_t, paddr_t); - -/* - * bus_dmamap_t - * - * Describes a DMA mapping. - */ -struct machine_bus_dmamap { - /* - * PRIVATE MEMBERS: not for use by machine-independent code. - */ - bus_size_t _dm_size; /* largest DMA transfer mappable */ - int _dm_segcnt; /* number of segs this map can map */ - bus_size_t _dm_maxsegsz; /* largest possible segment */ - bus_size_t _dm_boundary; /* don't cross this */ - int _dm_flags; /* misc. flags */ - - void *_dm_cookie; /* cookie for bus-specific functions */ - - /* - * PUBLIC MEMBERS: these are used by machine-independent code. - */ - bus_size_t dm_mapsize; /* size of the mapping */ - int dm_nsegs; /* # valid segments in mapping */ - bus_dma_segment_t dm_segs[1]; /* segments; variable length */ -}; - -#endif /* _MACHINE_BUS_H_ */ diff --git a/sys/arch/sgi/include/cdefs.h b/sys/arch/sgi/include/cdefs.h deleted file mode 100644 index 1b97c99ec72..00000000000 --- a/sys/arch/sgi/include/cdefs.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: cdefs.h,v 1.3 2013/03/28 17:30:45 martynas Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/cdefs.h> diff --git a/sys/arch/sgi/include/conf.h b/sys/arch/sgi/include/conf.h deleted file mode 100644 index caf921e81f0..00000000000 --- a/sys/arch/sgi/include/conf.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: conf.h,v 1.1 2009/08/09 21:07:22 miod Exp $ */ -/* public domain */ -#include <sys/conf.h> diff --git a/sys/arch/sgi/include/cpu.h b/sys/arch/sgi/include/cpu.h deleted file mode 100644 index e1dbb7cc13e..00000000000 --- a/sys/arch/sgi/include/cpu.h +++ /dev/null @@ -1,66 +0,0 @@ -/* $OpenBSD: cpu.h,v 1.16 2017/07/30 16:05:24 visa Exp $ */ -/*- - * Copyright (c) 1992, 1993 - * The Regents of the University of California. All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * Ralph Campbell and Rick Macklem. - * - * 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. - * 3. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - * - * Copyright (C) 1989 Digital Equipment Corporation. - * Permission to use, copy, modify, and distribute this software and - * its documentation for any purpose and without fee is hereby granted, - * provided that the above copyright notice appears in all copies. - * Digital Equipment Corporation makes no representations about the - * suitability of this software for any purpose. It is provided "as is" - * without express or implied warranty. - * - * from: @(#)cpu.h 8.4 (Berkeley) 1/4/94 - */ - -#ifndef _MACHINE_CPU_H_ -#define _MACHINE_CPU_H_ - -#ifdef _KERNEL -#if defined(MULTIPROCESSOR) && !defined(_LOCORE) -#define MAXCPUS 4 -struct cpu_info; -struct cpu_info *hw_getcurcpu(void); -void hw_setcurcpu(struct cpu_info *); -void hw_cpu_boot_secondary(struct cpu_info *); -void hw_cpu_hatch(struct cpu_info *); -void hw_cpu_spinup_trampoline(struct cpu_info *); -int hw_ipi_intr_establish(int (*)(void *), u_long); -void hw_ipi_intr_set(u_long); -void hw_ipi_intr_clear(u_long); -#endif /* MULTIPROCESSOR && !_LOCORE */ - - -#endif/* _KERNEL */ - -#include <mips64/cpu.h> - -#endif /* !_MACHINE_CPU_H_ */ diff --git a/sys/arch/sgi/include/cpustate.h b/sys/arch/sgi/include/cpustate.h deleted file mode 100644 index d915f5c2428..00000000000 --- a/sys/arch/sgi/include/cpustate.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: cpustate.h,v 1.1 2004/08/06 21:12:18 pefo Exp $ */ - -#include <mips64/cpustate.h> diff --git a/sys/arch/sgi/include/db_machdep.h b/sys/arch/sgi/include/db_machdep.h deleted file mode 100644 index 43621cb7c22..00000000000 --- a/sys/arch/sgi/include/db_machdep.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: db_machdep.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/db_machdep.h> diff --git a/sys/arch/sgi/include/disklabel.h b/sys/arch/sgi/include/disklabel.h deleted file mode 100644 index 2f44b1e1b5a..00000000000 --- a/sys/arch/sgi/include/disklabel.h +++ /dev/null @@ -1,108 +0,0 @@ -/* $OpenBSD: disklabel.h,v 1.7 2015/09/30 14:57:03 krw Exp $ */ - -/* - * Copyright (c) 1994 Christopher G. Demetriou - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Christopher G. Demetriou. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -#ifndef _MACHINE_DISKLABEL_H_ -#define _MACHINE_DISKLABEL_H_ - -#define LABELSECTOR 1 /* sector containing label */ -#define LABELOFFSET 0 /* offset of label in sector */ -#define MAXPARTITIONS 16 /* number of partitions */ - -/* - * SGI Volume Header. - */ - -#define SGILABEL_MAGIC 0xbe5a941 -#define SGI_SIZE_VOLDIR 15 - -/* Partition types. */ -#define SGI_PTYPE_VOLHDR 0 -#define SGI_PTYPE_RAW 3 -#define SGI_PTYPE_BSD 4 -#define SGI_PTYPE_VOLUME 6 -#define SGI_PTYPE_EFS 7 -#define SGI_PTYPE_LVOL 8 -#define SGI_PTYPE_RLVOL 9 -#define SGI_PTYPE_XFS 10 -#define SGI_PTYPE_XFSLOG 11 -#define SGI_PTYPE_XLV 12 -#define SGI_PTYPE_XVM 13 - -/* Device parameters. */ -struct devparms { - u_int8_t dp_skew; - u_int8_t dp_gap1; - u_int8_t dp_gap2; - u_int8_t dp_spares_cyl; - u_int16_t dp_cyls; - u_int16_t dp_shd0; - u_int16_t dp_trks0; - u_int8_t dp_ctq_depth; - u_int8_t dp_cylshi; - u_int16_t dp_unused; - u_int16_t dp_secs; - u_int16_t dp_secbytes; - u_int16_t dp_interleave; - u_int32_t dp_flags; - u_int32_t dp_datarate; - u_int32_t dp_nretries; - u_int32_t dp_mspw; - u_int16_t dp_xgap1; - u_int16_t dp_xsync; - u_int16_t dp_xrdly; - u_int16_t dp_xgap2; - u_int16_t dp_xrgate; - u_int16_t dp_xwcont; -} __packed; - -/* SGI volume header. */ -struct sgilabel { - u_int32_t magic; - int16_t root; - int16_t swap; - char bootfile[16]; - struct devparms dp; - struct { - char name[8]; - int32_t block; - int32_t bytes; - } voldir[SGI_SIZE_VOLDIR]; - struct { - int32_t blocks; - int32_t first; - int32_t type; - } partitions[MAXPARTITIONS]; - int32_t checksum; - int32_t _pad; -} __packed; - -#endif /* _MACHINE_DISKLABEL_H_ */ diff --git a/sys/arch/sgi/include/eisa_machdep.h b/sys/arch/sgi/include/eisa_machdep.h deleted file mode 100644 index 93ba8c4c4e8..00000000000 --- a/sys/arch/sgi/include/eisa_machdep.h +++ /dev/null @@ -1,68 +0,0 @@ -/* $OpenBSD: eisa_machdep.h,v 1.1 2012/03/28 20:44:23 miod Exp $ */ -/* $NetBSD: eisa_machdep.h,v 1.4 1997/06/06 23:12:52 thorpej Exp $ */ - -/* - * Copyright (c) 1996 Christopher G. Demetriou. 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Christopher G. Demetriou - * for the NetBSD Project. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * Machine-specific definitions for EISA autoconfiguration. - */ - -/* - * EISA spaces memory layout - */ - -#define EISA_IO_BASE 0x00080000 -#define EISA_IO_END 0x00090000 - -#define EISA_MEM0_BASE 0x00100000 -#define EISA_MEM0_END 0x08000000 - -#define EISA_MEM1_BASE 0x80000000 -#define EISA_MEM1_END 0x100000000UL - -/* - * Types provided to machine-independent EISA code. - */ -typedef void *eisa_chipset_tag_t; -typedef int eisa_intr_handle_t; - -/* - * Functions provided to machine-independent EISA code. - */ -void eisa_attach_hook(struct device *, struct device *, - struct eisabus_attach_args *); -int eisa_maxslots(eisa_chipset_tag_t); -int eisa_intr_map(eisa_chipset_tag_t, u_int, - eisa_intr_handle_t *); -const char *eisa_intr_string(eisa_chipset_tag_t, eisa_intr_handle_t); -void *eisa_intr_establish(eisa_chipset_tag_t, eisa_intr_handle_t, - int, int, int (*)(void *), void *, char *); -void eisa_intr_disestablish(eisa_chipset_tag_t, void *); diff --git a/sys/arch/sgi/include/endian.h b/sys/arch/sgi/include/endian.h deleted file mode 100644 index 82fa9b6a860..00000000000 --- a/sys/arch/sgi/include/endian.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: endian.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -#include <mips64/endian.h> diff --git a/sys/arch/sgi/include/exec.h b/sys/arch/sgi/include/exec.h deleted file mode 100644 index b325225d6a5..00000000000 --- a/sys/arch/sgi/include/exec.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: exec.h,v 1.8 2004/10/18 19:05:36 grange Exp $ */ - -#include <mips64/exec.h> diff --git a/sys/arch/sgi/include/fenv.h b/sys/arch/sgi/include/fenv.h deleted file mode 100644 index 53bc9796ec7..00000000000 --- a/sys/arch/sgi/include/fenv.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: fenv.h,v 1.2 2013/06/01 21:20:54 jasper Exp $ */ -/* public domain */ -#include <mips64/fenv.h> diff --git a/sys/arch/sgi/include/fpu.h b/sys/arch/sgi/include/fpu.h deleted file mode 100644 index 2376fd1b0bb..00000000000 --- a/sys/arch/sgi/include/fpu.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: fpu.h,v 1.1 2010/09/17 00:34:08 miod Exp $ */ -/* public domain */ -#include <mips64/fpu.h> diff --git a/sys/arch/sgi/include/frame.h b/sys/arch/sgi/include/frame.h deleted file mode 100644 index 86edb4c0a9b..00000000000 --- a/sys/arch/sgi/include/frame.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: frame.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/frame.h> diff --git a/sys/arch/sgi/include/ieee.h b/sys/arch/sgi/include/ieee.h deleted file mode 100644 index 53af586b1a9..00000000000 --- a/sys/arch/sgi/include/ieee.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: ieee.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/ieee.h> diff --git a/sys/arch/sgi/include/ieeefp.h b/sys/arch/sgi/include/ieeefp.h deleted file mode 100644 index 3bf6eca07a6..00000000000 --- a/sys/arch/sgi/include/ieeefp.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: ieeefp.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/ieeefp.h> diff --git a/sys/arch/sgi/include/intr.h b/sys/arch/sgi/include/intr.h deleted file mode 100644 index cbd905b8fcc..00000000000 --- a/sys/arch/sgi/include/intr.h +++ /dev/null @@ -1,206 +0,0 @@ -/* $OpenBSD: intr.h,v 1.53 2019/09/05 05:31:38 visa Exp $ */ - -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#ifndef _MACHINE_INTR_H_ -#define _MACHINE_INTR_H_ - -/* - * The interrupt level ipl is a logical level; per-platform interrupt - * code will turn it into the appropriate hardware interrupt masks - * values. - * - * Interrupt sources on the CPU are kept enabled regardless of the - * current ipl value; individual hardware sources interrupting while - * logically masked are masked on the fly, remembered as pending, and - * unmasked at the first splx() opportunity. - * - * An exception to this rule is the clock interrupt. Clock interrupts - * are always allowed to happen, but will (of course!) not be serviced - * if logically masked. The reason for this is that clocks usually sit on - * INT5 and cannot be easily masked if external hardware masking is used. - */ - -/* Interrupt priority `levels'; not mutually exclusive. */ -#define IPL_NONE 0 /* nothing */ -#define IPL_SOFTINT 1 /* soft interrupts */ -#define IPL_SOFTCLOCK 1 /* soft clock interrupts */ -#define IPL_SOFTNET 2 /* soft network interrupts */ -#define IPL_SOFTTTY 3 /* soft terminal interrupts */ -#define IPL_SOFTHIGH IPL_SOFTTTY /* highest level of soft interrupts */ -#define IPL_BIO 4 /* block I/O */ -#define IPL_AUDIO IPL_BIO -#define IPL_NET 5 /* network */ -#define IPL_TTY 6 /* terminal */ -#define IPL_VM 7 /* memory allocation */ -#define IPL_CLOCK 8 /* clock */ -#define IPL_SCHED IPL_CLOCK -#define IPL_HIGH 9 /* everything */ -#define IPL_IPI 10 /* interprocessor interrupt */ -#define NIPLS 11 /* number of levels */ - -#define IPL_MPFLOOR IPL_TTY - -/* Interrupt priority 'flags'. */ -#define IPL_MPSAFE 0x100 - -/* Interrupt sharing types. */ -#define IST_NONE 0 /* none */ -#define IST_PULSE 1 /* pulsed */ -#define IST_EDGE 2 /* edge-triggered */ -#define IST_LEVEL 3 /* level-triggered */ - -#define SINTBIT(q) (q) -#define SINTMASK(q) (1 << SINTBIT(q)) - -/* Soft interrupt masks. */ - -#define SI_SOFTCLOCK 0 /* for IPL_SOFTCLOCK */ -#define SI_SOFTNET 1 /* for IPL_SOFTNET */ -#define SI_SOFTTTY 2 /* for IPL_SOFTTTY */ - -#define SI_NQUEUES 3 - -#ifndef _LOCORE - -#include <sys/mutex.h> -#include <sys/queue.h> - -struct soft_intrhand { - TAILQ_ENTRY(soft_intrhand) sih_list; - void (*sih_func)(void *); - void *sih_arg; - struct soft_intrq *sih_siq; - int sih_pending; -}; - -struct soft_intrq { - TAILQ_HEAD(, soft_intrhand) siq_list; - int siq_si; - struct mutex siq_mtx; -}; - -void softintr_disestablish(void *); -void softintr_dispatch(int); -void *softintr_establish(int, void (*)(void *), void *); -void softintr_init(void); -void softintr_schedule(void *); - -#define splbio() splraise(IPL_BIO) -#define splnet() splraise(IPL_NET) -#define spltty() splraise(IPL_TTY) -#define splaudio() splraise(IPL_AUDIO) -#define splvm() splraise(IPL_VM) -#define splclock() splraise(IPL_CLOCK) -#define splsched() splraise(IPL_SCHED) -#define splhigh() splraise(IPL_HIGH) - -#define splsoftclock() splraise(IPL_SOFTCLOCK) -#define splsoftnet() splraise(IPL_SOFTNET) -#define splstatclock() splhigh() - -#define spl0() spllower(0) - -void splinit(void); - -#ifdef DIAGNOSTIC -/* - * Although this function is implemented in MI code, it must be in this MD - * header because we don't want this header to include MI includes. - */ -void splassert_fail(int, int, const char *); -extern int splassert_ctl; -void splassert_check(int, const char *); -#define splassert(__wantipl) do { \ - if (splassert_ctl > 0) { \ - splassert_check(__wantipl, __func__); \ - } \ -} while (0) -#define splsoftassert(wantipl) splassert(wantipl) -#else -#define splassert(X) -#define splsoftassert(X) -#endif - -void register_splx_handler(void (*)(int)); -int splraise(int); -void splx(int); -int spllower(int); - -/* - * Interrupt control struct used by interrupt dispatchers - * to hold interrupt handler info. - */ - -#include <sys/evcount.h> - -struct intrhand { - struct intrhand *ih_next; - int (*ih_fun)(void *); - void *ih_arg; - int ih_level; - int ih_irq; - struct evcount ih_count; - int ih_flags; -#define IH_ALLOCATED 0x01 -#define IH_MPSAFE 0x02 -}; - -void intr_barrier(void *); - -/* - * Low level interrupt dispatcher registration data. - */ - -/* Schedule priorities for base interrupts (CPU) */ -#define INTPRI_IPI 0 -#define INTPRI_CLOCK 1 -/* other values are system-specific */ - -#define NLOWINT 16 /* Number of low level registrations possible */ - -extern uint32_t idle_mask; - -struct trapframe; -void set_intr(int, uint32_t, uint32_t(*)(uint32_t, struct trapframe *)); - -uint32_t updateimask(uint32_t); -void dosoftint(void); - -#ifdef MULTIPROCESSOR -#if defined (TGT_OCTANE) -#define ENABLEIPI() updateimask(~CR_INT_2) /* enable IPI interrupt level */ -#elif defined (TGT_ORIGIN) -#define ENABLEIPI() updateimask(~CR_INT_0) /* enable IPI interrupt level */ -#else -#error MULTIPROCESSOR kernel not supported on this configuration -#endif -#endif - -#endif /* _LOCORE */ - -#endif /* _MACHINE_INTR_H_ */ diff --git a/sys/arch/sgi/include/kcore.h b/sys/arch/sgi/include/kcore.h deleted file mode 100644 index 35f8b8090e6..00000000000 --- a/sys/arch/sgi/include/kcore.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: kcore.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/kcore.h> diff --git a/sys/arch/sgi/include/limits.h b/sys/arch/sgi/include/limits.h deleted file mode 100644 index d9c3dc1468c..00000000000 --- a/sys/arch/sgi/include/limits.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: limits.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/limits.h> diff --git a/sys/arch/sgi/include/loadfile_machdep.h b/sys/arch/sgi/include/loadfile_machdep.h deleted file mode 100644 index 2b759cafe11..00000000000 --- a/sys/arch/sgi/include/loadfile_machdep.h +++ /dev/null @@ -1,52 +0,0 @@ -/* $OpenBSD: loadfile_machdep.h,v 1.5 2015/07/17 20:44:39 miod Exp $ */ -/* $NetBSD: loadfile_machdep.h,v 1.2 2001/10/31 17:20:49 thorpej Exp $ */ - -/*- - * Copyright (c) 1999 The NetBSD Foundation, Inc. - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Christos Zoulas. - * - * 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. - */ - -#define BOOT_ELF -#define ELFSIZE 64 - -#define LOAD_KERNEL LOAD_ALL -#define COUNT_KERNEL COUNT_ALL - -#define LOADADDR(a) (((u_long)(a)) + offset) -#define ALIGNENTRY(a) ((u_long)(a)) -#define READ(f, b, c) read((f), (void *)LOADADDR(b), (c)) -#define BCOPY(s, d, c) memcpy((void *)LOADADDR(d), (void *)(s), (c)) -#define BZERO(d, c) memset((void *)LOADADDR(d), 0, (c)) -#define WARN(a) (void)(printf a, \ - printf((errno ? ": %s\n" : "\n"), \ - strerror(errno))) -#define PROGRESS(a) (void) printf a -#define ALLOC(a) alloc(a) -#define FREE(a, b) free(a, b) - -extern int check_phdr(void *); -#define CHECK_PHDR(sz,phdr) check_phdr(phdr) diff --git a/sys/arch/sgi/include/lock.h b/sys/arch/sgi/include/lock.h deleted file mode 100644 index 9f00e2a6496..00000000000 --- a/sys/arch/sgi/include/lock.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: lock.h,v 1.1 2007/05/01 18:56:31 miod Exp $ */ -/* public domain */ -#include <mips64/lock.h> diff --git a/sys/arch/sgi/include/memconf.h b/sys/arch/sgi/include/memconf.h deleted file mode 100644 index 306f0ef4c4d..00000000000 --- a/sys/arch/sgi/include/memconf.h +++ /dev/null @@ -1,10 +0,0 @@ -/* $OpenBSD: memconf.h,v 1.3 2011/03/23 16:54:36 pirofti Exp $ */ - -#ifndef _MACHINE_MEMCONF_H_ -#define _MACHINE_MEMCONF_H_ - -#define MAXMEMSEGS 32 - -#include <mips64/memconf.h> - -#endif /* _MACHINE_MEMCONF_H_ */ diff --git a/sys/arch/sgi/include/mips_opcode.h b/sys/arch/sgi/include/mips_opcode.h deleted file mode 100644 index c9ed582317e..00000000000 --- a/sys/arch/sgi/include/mips_opcode.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: mips_opcode.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/mips_opcode.h> diff --git a/sys/arch/sgi/include/mnode.h b/sys/arch/sgi/include/mnode.h deleted file mode 100644 index dc7365b98f1..00000000000 --- a/sys/arch/sgi/include/mnode.h +++ /dev/null @@ -1,493 +0,0 @@ -/* $OpenBSD: mnode.h,v 1.18 2011/04/17 17:44:24 miod Exp $ */ - -/* - * Copyright (c) 2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#ifndef _MACHINE_MNODE_H_ -#define _MACHINE_MNODE_H_ - -/* - * Definitions for Nodes set up in M-Mode. Some stuff here - * inspired by information gathered from Linux source code. - */ - -/* - * IP27 uses XKSSEG to access the 1TB memory area. - */ -#define IP27_CAC_BASE PHYS_TO_XKPHYS(0, CCA_CACHED) - -/* - * IP27 uses XKPHYS space for accessing special objects. - * Note that IP27_UNCAC_BASE is a linear space without specials. - */ -#define IP27_HSPEC_BASE PHYS_TO_XKPHYS_UNCACHED(0, SP_HUB) -#define IP27_IO_BASE PHYS_TO_XKPHYS_UNCACHED(0, SP_IO) -#define IP27_MSPEC_BASE PHYS_TO_XKPHYS_UNCACHED(0, SP_SPECIAL) -#define IP27_UNCAC_BASE PHYS_TO_XKPHYS_UNCACHED(0, SP_NC) - -/* - * Macros used to find the base of each nodes address space. - * In M mode each node space is 4GB; in N mode each node space is 2GB only. - */ -#define IP27_NODE_BASE(base, node) ((base) + ((uint64_t)(node) << kl_n_shift)) -#define IP27_NODE_SIZE_MASK ((1UL << kl_n_shift) - 1) - -#define IP27_NODE_CAC_BASE(node) (IP27_NODE_BASE(IP27_CAC_BASE, node)) -#define IP27_NODE_HSPEC_BASE(node) (IP27_NODE_BASE(IP27_HSPEC_BASE, node)) -#define IP27_NODE_IO_BASE(node) (IP27_NODE_BASE(IP27_IO_BASE, node)) -#define IP27_NODE_MSPEC_BASE(node) (IP27_NODE_BASE(IP27_MSPEC_BASE, node)) -#define IP27_NODE_UNCAC_BASE(node) (IP27_NODE_BASE(IP27_UNCAC_BASE, node)) - -/* Get typed address to nodes uncached space */ -#define IP27_UNCAC_ADDR(type, node, offs) \ - ((type)(IP27_NODE_UNCAC_BASE(node) + ((offs) & IP27_NODE_SIZE_MASK))) - -/* - * Convert a physical (XIO) address to a node number. - */ -#define IP27_PHYS_TO_NODE(addr) ((addr) >> kl_n_shift) - -/* - * IP27 platforms uses something called kldir to describe each - * nodes configuration. Directory entries looks like: - */ -#define IP27_KLDIR_MAGIC 0x434d5f53505f5357 - -typedef struct kldir_entry { - uint64_t magic; - off_t offset; /* Offset from start of node space */ - void *pointer; - size_t size; /* Size in bytes */ - uint64_t count; /* # of entries if array, 1 if not */ - size_t stride; /* Stride if array, 0 if not */ - char rsvd[16]; /* Pad entry to 0x40 bytes */ -} kldir_entry_t; - -/* Get address to a specific directory entry */ -#define IP27_KLD_BASE(node) IP27_UNCAC_ADDR(kldir_entry_t *, node, 0x2000) -#define IP27_KLD_LAUNCH(node) (IP27_KLD_BASE(node) + 0) -#define IP27_KLD_KLCONFIG(node) (IP27_KLD_BASE(node) + 1) -#define IP27_KLD_NMI(node) (IP27_KLD_BASE(node) + 2) -#define IP27_KLD_GDA(node) (IP27_KLD_BASE(node) + 3) -#define IP27_KLD_FREEMEM(node) (IP27_KLD_BASE(node) + 4) -#define IP27_KLD_SYMMON_STK(node) (IP27_KLD_BASE(node) + 5) -#define IP27_KLD_PI_ERROR(node) (IP27_KLD_BASE(node) + 6) -#define IP27_KLD_KERN_VARS(node) (IP27_KLD_BASE(node) + 7) -#define IP27_KLD_KERN_XP(node) (IP27_KLD_BASE(node) + 8) -#define IP27_KLD_KERN_PARTID(node) (IP27_KLD_BASE(node) + 9) - -/* ========== */ - -/* - * KLCONFIG is a linked list of data structures describing the - * system configuration. - */ -typedef uint32_t klconf_off_t; -typedef char confidence_t; - -typedef struct console_s { - unsigned long uart_base; - unsigned long config_base; - unsigned long memory_base; - short baud; - short flag; - int type; - int16_t nasid; - char wid; - char npci; - uint64_t baseio_nic; -} console_t; - -typedef struct klc_malloc_hdr { - klconf_off_t km_base; - klconf_off_t km_limit; - klconf_off_t km_current; -} klc_malloc_hdr_t; - -/* KLCONFIG header addressed by IP27_KLCONFIG_HDR(node) */ -#define IP27_KLCONFIG_HDR(n) \ - IP27_UNCAC_ADDR(kl_config_hdr_t *, n, IP27_KLD_KLCONFIG(n)->offset) - -typedef struct kl_config_hdr { - uint64_t magic; /* set this to KLCFGINFO_MAGIC */ - uint32_t version; /* structure version number */ - klconf_off_t malloc_hdr_off; /* offset of ch_malloc_hdr */ - klconf_off_t cons_off; /* offset of ch_cons */ - klconf_off_t board_info; /* the link list of boards */ - console_t cons_info; /* address info of the console */ - klc_malloc_hdr_t malloc_hdr[3]; - confidence_t sw_belief; /* confidence that software is bad */ - confidence_t sn0net_belief; /* confidence that sn0net is bad */ -} kl_config_hdr_t; - -/* Board info. */ -#define IP27_KLFIRST_BOARD(n) \ - IP27_UNCAC_ADDR(lboard_t *, n, IP27_KLCONFIG_HDR(n)->board_info) -#define IP27_KLNEXT_BOARD(n, board) \ - IP27_UNCAC_ADDR(lboard_t *, n, board->brd_next) -#define MAX_COMPTS_PER_BRD 24 - -typedef struct lboard_s { - klconf_off_t brd_next; /* Next BOARD */ - uint8_t struct_type; /* type, local or remote */ - unsigned char brd_type; /* type+class */ - unsigned char brd_sversion; /* version of this structure */ - unsigned char brd_brevision; /* board revision */ - unsigned char brd_promver; /* board prom version, if any */ - unsigned char brd_flags; /* Enabled, Disabled etc */ - unsigned char brd_slot; /* slot number (widget on IP35) */ - unsigned short brd_bus_num: 2, /* PIC bus number (IP35) */ - brd_unused: 14; - short brd_module; /* module to which it belongs */ - char brd_partition; /* Partition number */ - unsigned short brd_diagval; /* diagnostic value */ - unsigned short brd_diagparm; /* diagnostic parameter */ - unsigned char brd_inventory; /* inventory history */ - unsigned char brd_numcompts; /* Number of components */ - uint64_t brd_nic; /* Number in CAN */ - int16_t brd_nasid; /* passed parameter */ - klconf_off_t brd_compts[MAX_COMPTS_PER_BRD]; /* COMPONENTS */ - klconf_off_t brd_errinfo; /* Board's error information */ - struct lboard_s *brd_parent; /* Logical parent for this brd */ - uint32_t brd_graph_link; /* vertex hdl to connect extrn compts */ - confidence_t brd_confidence; /* confidence that the board is bad */ - int16_t brd_owner; /* who owns this board */ - uint8_t brd_nic_flags; /* To handle 8 more NICs */ - char brd_name[32]; -} lboard_t; - -#define LBOARD 0x01 -#define RBOARD 0x02 - -/* Definitions of board type and class */ -#define IP27_BC_MASK 0xf0 -#define IP27_BT_MASK 0x0f - -#define IP27_BC_NODE 0x10 -#define IP27_BC_IO 0x20 -#define IP27_BC_ROUTER 0x30 -#define IP27_BC_MPLANE 0x40 -#define IP27_BC_GRAF 0x50 -#define IP27_BC_HDTV 0x60 -#define IP27_BC_BRICK 0x70 -#define IP27_BC_IO2 0x80 - -/* NODE types */ -#define IP27_BRD_CPU (IP27_BC_NODE | 0x01) -/* IO types */ -#define IP27_BRD_BASEIO (IP27_BC_IO | 0x01) /* IO6 */ -#define IP27_BRD_MSCSI (IP27_BC_IO | 0x02) -#define IP27_BRD_MENET (IP27_BC_IO | 0x03) -#define IP27_BRD_FDDI (IP27_BC_IO | 0x04) -#define IP27_BRD_PCI1 (IP27_BC_IO | 0x06) /* PCI shoebox */ -#define IP27_BRD_VME (IP27_BC_IO | 0x07) -#define IP27_BRD_MIO (IP27_BC_IO | 0x08) -#define IP27_BRD_FC (IP27_BC_IO | 0x09) -#define IP27_BRD_LINC (IP27_BC_IO | 0x0a) -/* MPLANE types */ -#define IP27_BRD_MPLANE8 (IP27_BC_MPLANE | 0x01) -#define IP27_BRD_IOBRICK_XBOW (IP27_BC_MPLANE | 0x02) -/* GRAF types */ -#define IP27_BRD_KONA (IP27_BC_GRAF | 0x01) -#define IP27_BRD_MGRAS (IP27_BC_GRAF | 0x03) -#define IP27_BRD_ODSY (IP27_BC_GRAF | 0x04) -/* BRICK types */ -#define IP27_BRD_IOBRICK (IP27_BC_BRICK | 0x00) -#define IP27_BRD_IBRICK (IP27_BC_BRICK | 0x01) -#define IP27_BRD_PBRICK (IP27_BC_BRICK | 0x02) -#define IP27_BRD_XBRICK (IP27_BC_BRICK | 0x03) -#define IP27_BRD_NBRICK (IP27_BC_BRICK | 0x04) -#define IP27_BRD_PEBRICK (IP27_BC_BRICK | 0x05) -#define IP27_BRD_PXBRICK (IP27_BC_BRICK | 0x06) -#define IP27_BRD_IXBRICK (IP27_BC_BRICK | 0x07) -#define IP27_BRD_CGBRICK (IP27_BC_BRICK | 0x08) -/* IO2 types */ -#define IP27_BRD_DIVO (IP27_BC_IO2 | 0x01) -#define IP27_BRD_TPU (IP27_BC_IO2 | 0x02) -#define IP27_BRD_GSN (IP27_BC_IO2 | 0x03) -#define IP27_BRD_GSN_AUX (IP27_BC_IO2 | 0x04) -#define IP27_BRD_PCI3 (IP27_BC_IO2 | 0x05) /* PCI shoehorn */ -#define IP27_BRD_HIPPI (IP27_BC_IO2 | 0x06) -#define IP27_BRD_ATM (IP27_BC_IO2 | 0x07) - -/* Component info. Common info about a component. */ -typedef struct klinfo_s { /* Generic info */ - unsigned char struct_type; /* type of this structure */ - unsigned char struct_version; /* version of this structure */ - unsigned char flags; /* Enabled, disabled etc */ - unsigned char revision; /* component revision */ - unsigned short diagval; /* result of diagnostics */ - unsigned short diagparm; /* diagnostic parameter */ - unsigned char inventory; /* previous inventory status */ - uint64_t nic; /* Must be aligned properly */ - unsigned char physid; /* physical id of component */ - unsigned int virtid; /* virtual id as seen by system */ - unsigned char widid; /* Widget id - if applicable */ - int16_t nasid; /* node number - from parent */ - unsigned short port: 2, /* (IP35) port on dual port controller */ - pci_bus_num: 2, /* (IP35) PCI bus number if on PIC */ - pci_multifunc: 1, - pci_func_num: 3,/* (IP35) PCI function number */ - pci_unused: 8; - char pad2; /* pad out structure. */ - void *arcs_compt; /* ptr to the arcs struct for ease*/ - klconf_off_t errinfo; /* component specific errors */ - unsigned short pad3; /* pci fields have moved over to */ - unsigned short pad4; /* klbri_t */ -} klinfo_t; - -#define KLINFO_PHYSID_PIC_BUS1 0x10 /* set if on PIC bus 1 */ -#define KLINFO_PHYSID_WIDGET_MASK 0x0f - -#define KLINFO_ENABLED 0x01 -#define KLINFO_FAILED 0x02 - -/* - * Component structure types. - */ -#define KLSTRUCT_UNKNOWN 0 -#define KLSTRUCT_CPU 1 -#define KLSTRUCT_HUB 2 -#define KLSTRUCT_MEMBNK 3 -#define KLSTRUCT_XBOW 4 -#define KLSTRUCT_BRI 5 -#define KLSTRUCT_IOC3 6 -#define KLSTRUCT_PCI 7 -#define KLSTRUCT_VME 8 -#define KLSTRUCT_ROU 9 -#define KLSTRUCT_GFX 10 -#define KLSTRUCT_SCSI 11 -#define KLSTRUCT_FDDI 12 -#define KLSTRUCT_MIO 13 -#define KLSTRUCT_DISK 14 -#define KLSTRUCT_TAPE 15 -#define KLSTRUCT_CDROM 16 -#define KLSTRUCT_HUB_UART 17 -#define KLSTRUCT_IOC3ENET 18 -#define KLSTRUCT_IOC3UART 19 -#define KLSTRUCT_IOC3PCKM 21 -#define KLSTRUCT_RAD 22 -#define KLSTRUCT_HUB_TTY 23 -#define KLSTRUCT_IOC3_TTY 24 -/* new IP35 values */ -#define KLSTRUCT_FIBERCHANNEL 25 -#define KLSTRUCT_MOD_SERIAL_NUM 26 -#define KLSTRUCT_IOC3MS 27 -#define KLSTRUCT_TPU 28 -#define KLSTRUCT_GSN 29 -#define KLSTRUCT_GSN_AUX 30 -#define KLSTRUCT_XTHD 31 -#define KLSTRUCT_QLFIBRE 32 -#define KLSTRUCT_FIREWIRE 33 -#define KLSTRUCT_USB 34 -#define KLSTRUCT_USBKBD 35 -#define KLSTRUCT_USBMS 36 -#define KLSTRUCT_SCSI2 37 -#define KLSTRUCT_PEBRICK 38 -#define KLSTRUCT_GIGENET 39 -#define KLSTRUCT_IDE 40 -/* new IP53 values */ -#define KLSTRUCT_IOC4 41 -#define KLSTRUCT_IOC4UART 42 -#define KLSTRUCT_IOC4_TTY 43 -#define KLSTRUCT_IOC4PCKM 44 -#define KLSTRUCT_IOC4MS 45 -#define KLSTRUCT_IOC4_ATA 46 -#define KLSTRUCT_VGAGFX 47 - -typedef struct klport_s { - int16_t port_nasid; - unsigned char port_flag; - klconf_off_t port_offset; -} klport_t; - -/* KLSTRUCT_CPU: CPU component info */ -typedef struct klcpu_s { - klinfo_t cpu_info; - uint16_t cpu_prid; /* Processor PRID value */ - uint16_t cpu_fpirr; /* IP27: FPU IRR value */ - /* IP35: mode information (?) */ - uint16_t cpu_speed; /* Speed in MHZ */ - uint16_t cpu_scachesz; /* secondary cache size in MB */ - uint16_t cpu_scachespeed;/* secondary cache speed in MHz */ -} klcpu_t; - -/* KLSTRUCT_HUB: Hub */ -typedef struct klhub_s { - klinfo_t hub_info; - uint32_t hub_flags; /* PCFG_HUB_xxx flags */ - klport_t hub_port; /* hub is connected to this */ - uint64_t hub_box_nic; /* nic of containing box */ - klconf_off_t hub_mfg_nic; /* MFG NIC string */ - uint64_t hub_speed; /* Speed of hub in HZ */ -} klhub_t; - -/* KLSTRUCT_MEMBNK: Memory bank */ -#define MD_MEM_BANKS_M 8 /* M-Mode */ -typedef struct klmembnk_m_s { - klinfo_t membnk_info; - int16_t membnk_memsz; /* Total memory in megabytes */ - int16_t membnk_dimm_select; /* bank to phys addr mapping*/ - int16_t membnk_bnksz[MD_MEM_BANKS_M]; /* Memory bank sizes */ - int16_t membnk_attr; /* directory memory, per bank */ -} klmembnk_m_t; - -#define MD_MEM_BANKS_N 4 /* N-Mode */ -typedef struct klmembnk_n_s { - klinfo_t membnk_info; - int16_t membnk_memsz; /* Total memory in megabytes */ - int16_t membnk_dimm_select; /* bank to phys addr mapping*/ - int16_t membnk_bnksz[MD_MEM_BANKS_N]; /* Memory bank sizes */ - int16_t membnk_attr; /* directory memory, per bank */ -} klmembnk_n_t; - -/* KLSTRUCT_XBOW: Xbow */ -#define MAX_XBOW_LINKS 16 -typedef struct klxbow_s { - klinfo_t xbow_info; - klport_t xbow_port_info[MAX_XBOW_LINKS]; /* Module number */ - int xbow_hub_master_link; -} klxbow_t; - -/* xbow_port_info.port_flag bits */ -#define XBOW_PORT_IO 0x01 -#define XBOW_PORT_HUB 0x02 -#define XBOW_PORT_ENABLE 0x04 - -/* KLSTRUCT_SCSI: SCSI Bus, or single-bus SCSI Controller */ -#define MAX_SCSI_DEVS 16 -typedef struct klscsi_s { - klinfo_t scsi_info; - uint64_t scsi_specific; - uint8_t scsi_numdevs; - klconf_off_t scsi_devinfo[MAX_SCSI_DEVS]; -} klscsi_t; - -/* KLSTRUCT_IOC3: Basic I/O Controller */ -typedef struct klioc3_s { - klinfo_t ioc3_info; - unsigned char ioc3_ssram; /* Info about ssram */ - unsigned char ioc3_nvram; /* Info about nvram */ - klconf_off_t ioc3_tty_off; - klconf_off_t ioc3_kbd_off; - klinfo_t ioc3_superio; /* Info about superio */ - klinfo_t ioc3_enet; - klconf_off_t ioc3_enet_off; -} klioc3_t; - -/* KLSTRUCT_IOC3_TTY: IOC3 attached TTY */ -typedef struct klttydev_s { - klinfo_t ttydev_info; - struct terminal_data *ttydev_cfg; /* driver fills up this */ -} klttydev_t; - -/* KLSTRUCT_SCSI2: SCSI Controller */ -typedef struct klscctl_s { - klinfo_t scsi_info; - uint type; - uint scsi_buscnt; - uint64_t scsi_bus[2]; -} klscctl_t; - -/* ========== */ - -#define IP27_NMI(n) \ - IP27_UNCAC_ADDR(nmi_t *, n, IP27_KLD_NMI(n)->offset) - -#define NMI_MAGIC 0x0048414d4d455201 /* \x00HAMMER\x01 */ - -typedef struct nmi { - uint64_t magic; /* NMI_MAGIC */ - uint64_t flags; - uint64_t cb; /* callback function */ - uint64_t cb_complement; /* two's complement of above */ - uint64_t cb_arg; /* callback arg */ - uint64_t master; /* nonzero if master node */ -} nmi_t; - -/* ========== */ - -#define IP27_GDA(n) (gda_t *)(IP27_KLD_GDA(n)->pointer) -#define IP27_GDA_SIZE(n) (IP27_KLD_GDA(n)->size) - -#define GDA_MAGIC 0x58464552 /* XFER */ - -#define GDA_MAXNODES 128 - -typedef struct gda { - uint32_t magic; /* GDA_MAGIC */ - uint16_t ver; - uint16_t masternasid; /* NASID of the master cpu */ - uint32_t promop; /* Request to pass to PROM */ - uint32_t switches; - void *tlb_handlers[3]; - uint partid; - uint symcnt; - void *symtab; - char *symnames; - void *replication_mask; - uint32_t pad[14]; - int16_t nasid[GDA_MAXNODES]; /* NASID of connected nodes */ -} gda_t; - -#define GDA_PROMOP_MAGIC 0x0ead0000 -/* commands */ -#define GDA_PROMOP_HALT 0x00000010 -#define GDA_PROMOP_POWERDOWN 0x00000020 -#define GDA_PROMOP_RESTART 0x00000030 -#define GDA_PROMOP_REBOOT 0x00000040 -#define GDA_PROMOP_EIM 0x00000050 -/* options */ -#define GDA_PROMOP_NO_DIAGS 0x00000100 /* don't run diagnostics */ -#define GDA_PROMOP_NO_MEMINIT 0x00000200 /* don't initialize memory */ -#define GDA_PROMOP_NO_DEVINIT 0x00000400 /* don't initialize devices */ - -/* ========== */ - -/* - * Functions. - */ - -console_t *kl_get_console(void); -void kl_init(int); -int kl_scan_all_nodes(uint, int (*)(lboard_t *, void *), void *); -int kl_scan_node(int, uint, int (*)(lboard_t *, void *), void *); -#define KLBRD_ANY 0 -int kl_scan_board(lboard_t *, uint, int (*)(klinfo_t *, void *), void *); -#define KLSTRUCT_ANY ((uint)~0) -void kl_get_location(klinfo_t *, struct sgi_device_location *); -void kl_get_console_location(console_t *, struct sgi_device_location *); - -/* widget number of the XBow `hub', for each node */ -extern int kl_hub_widget[GDA_MAXNODES]; - -extern int kl_n_mode; -extern u_int kl_n_shift; -extern klinfo_t *kl_glass_console; -extern gda_t *gda; -extern uint maxnodes; - -#endif /* _MACHINE_MNODE_H_ */ diff --git a/sys/arch/sgi/include/mplock.h b/sys/arch/sgi/include/mplock.h deleted file mode 100644 index c225ed39020..00000000000 --- a/sys/arch/sgi/include/mplock.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: mplock.h,v 1.2 2015/09/09 15:48:53 visa Exp $ */ - -#include <mips64/mplock.h> diff --git a/sys/arch/sgi/include/mutex.h b/sys/arch/sgi/include/mutex.h deleted file mode 100644 index b13515a4101..00000000000 --- a/sys/arch/sgi/include/mutex.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: mutex.h,v 1.9 2015/07/08 13:37:31 dlg Exp $ */ - -#include <mips64/mutex.h> diff --git a/sys/arch/sgi/include/param.h b/sys/arch/sgi/include/param.h deleted file mode 100644 index 900b9f8ed44..00000000000 --- a/sys/arch/sgi/include/param.h +++ /dev/null @@ -1,49 +0,0 @@ -/* $OpenBSD: param.h,v 1.7 2013/03/23 16:12:26 deraadt Exp $ */ - -/* - * Copyright (c) 2003 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - */ - -#ifndef _MACHINE_PARAM_H_ -#define _MACHINE_PARAM_H_ - -#define MACHINE "sgi" -#define _MACHINE sgi -#define MACHINE_ARCH "mips64" -#define _MACHINE_ARCH mips64 -#define MID_MACHINE MID_MIPS64 /* None but has to be defined */ - -#ifdef _KERNEL -#ifndef PAGE_SHIFT -#if defined(CPU_R5000) || defined(CPU_RM7000) -#define PAGE_SHIFT 12 -#else -#define PAGE_SHIFT 14 -#endif -#endif -#endif /* _KERNEL */ - -#include <mips64/param.h> - -#endif /* _MACHINE_PARAM_H_ */ diff --git a/sys/arch/sgi/include/pcb.h b/sys/arch/sgi/include/pcb.h deleted file mode 100644 index 5ef67f15474..00000000000 --- a/sys/arch/sgi/include/pcb.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: pcb.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/pcb.h> diff --git a/sys/arch/sgi/include/pmap.h b/sys/arch/sgi/include/pmap.h deleted file mode 100644 index a0c9a5da2a4..00000000000 --- a/sys/arch/sgi/include/pmap.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: pmap.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/pmap.h> diff --git a/sys/arch/sgi/include/proc.h b/sys/arch/sgi/include/proc.h deleted file mode 100644 index 7faa033afd6..00000000000 --- a/sys/arch/sgi/include/proc.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: proc.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/proc.h> diff --git a/sys/arch/sgi/include/profile.h b/sys/arch/sgi/include/profile.h deleted file mode 100644 index 751bcd1a4aa..00000000000 --- a/sys/arch/sgi/include/profile.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: profile.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/profile.h> diff --git a/sys/arch/sgi/include/pte.h b/sys/arch/sgi/include/pte.h deleted file mode 100644 index 80006a2b750..00000000000 --- a/sys/arch/sgi/include/pte.h +++ /dev/null @@ -1,2 +0,0 @@ -/* $OpenBSD: pte.h,v 1.4 2004/09/20 20:03:19 miod Exp $ */ -#include <mips64/pte.h> diff --git a/sys/arch/sgi/include/ptrace.h b/sys/arch/sgi/include/ptrace.h deleted file mode 100644 index 9f0a1a22e40..00000000000 --- a/sys/arch/sgi/include/ptrace.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: ptrace.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/ptrace.h> diff --git a/sys/arch/sgi/include/rbus_machdep.h b/sys/arch/sgi/include/rbus_machdep.h deleted file mode 100644 index 70f4ef2d8ea..00000000000 --- a/sys/arch/sgi/include/rbus_machdep.h +++ /dev/null @@ -1,60 +0,0 @@ -/* $OpenBSD: rbus_machdep.h,v 1.2 2011/03/23 16:54:36 pirofti Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#ifndef _MACHINE_RBUS_MACHDEP_H_ -#define _MACHINE_RBUS_MACHDEP_H_ - -/* - * RBUS mapping routines - */ - -struct rb_md_fnptr { - int (*rbus_md_space_map)(bus_space_tag_t, bus_addr_t, bus_size_t, - int, bus_space_handle_t *); - void (*rbus_md_space_unmap)(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_addr_t *); -}; - -static __inline__ int -md_space_map(rbus_tag_t rbt, u_long addr, bus_size_t size, int flags, - bus_space_handle_t *bshp) -{ - struct rb_md_fnptr *fn = (struct rb_md_fnptr *)rbt->rb_md; - - return (*fn->rbus_md_space_map)(rbt->rb_bt, (bus_addr_t)addr, size, - flags, bshp); -} - -static __inline__ void -md_space_unmap(rbus_tag_t rbt, bus_space_handle_t h, bus_size_t size, - bus_addr_t *addrp) -{ - struct rb_md_fnptr *fn = (struct rb_md_fnptr *)rbt->rb_md; - - (*fn->rbus_md_space_unmap)(rbt->rb_bt, h, size, addrp); -} - -/* - * PCCBB RBUS allocation routines (rbus_pccbb_parent_io, rbus_pccbb_parent_mem) - * are implemented in pci_machdep.h. - */ - -#define pccbb_attach_hook(parent, self, paa) \ - do { /* nothing */} while (/*CONSTCOND*/0) - -#endif /* _MACHINE_RBUS_MACHDEP_H_ */ diff --git a/sys/arch/sgi/include/reg.h b/sys/arch/sgi/include/reg.h deleted file mode 100644 index 1384ab67a31..00000000000 --- a/sys/arch/sgi/include/reg.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: reg.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/reg.h> diff --git a/sys/arch/sgi/include/regdef.h b/sys/arch/sgi/include/regdef.h deleted file mode 100644 index 5c6c04429b0..00000000000 --- a/sys/arch/sgi/include/regdef.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: regdef.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/regdef.h> diff --git a/sys/arch/sgi/include/regnum.h b/sys/arch/sgi/include/regnum.h deleted file mode 100644 index 02742e484c4..00000000000 --- a/sys/arch/sgi/include/regnum.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: regnum.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/regnum.h> diff --git a/sys/arch/sgi/include/reloc.h b/sys/arch/sgi/include/reloc.h deleted file mode 100644 index fcd6219ccdb..00000000000 --- a/sys/arch/sgi/include/reloc.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: reloc.h,v 1.3 2017/08/12 15:33:41 visa Exp $ */ - -/* public domain */ - -#include <mips64/reloc.h> diff --git a/sys/arch/sgi/include/setjmp.h b/sys/arch/sgi/include/setjmp.h deleted file mode 100644 index 42c95a623a8..00000000000 --- a/sys/arch/sgi/include/setjmp.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: setjmp.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/setjmp.h> diff --git a/sys/arch/sgi/include/signal.h b/sys/arch/sgi/include/signal.h deleted file mode 100644 index 76c9c9af96a..00000000000 --- a/sys/arch/sgi/include/signal.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: signal.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/signal.h> diff --git a/sys/arch/sgi/include/spinlock.h b/sys/arch/sgi/include/spinlock.h deleted file mode 100644 index 6a5d9013967..00000000000 --- a/sys/arch/sgi/include/spinlock.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: spinlock.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -#include <mips64/spinlock.h> diff --git a/sys/arch/sgi/include/sysarch.h b/sys/arch/sgi/include/sysarch.h deleted file mode 100644 index b7c783f2c72..00000000000 --- a/sys/arch/sgi/include/sysarch.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: sysarch.h,v 1.1 2009/09/27 18:20:13 miod Exp $ */ -/* public domain */ -#include <mips64/sysarch.h> diff --git a/sys/arch/sgi/include/tcb.h b/sys/arch/sgi/include/tcb.h deleted file mode 100644 index 4bed95616a4..00000000000 --- a/sys/arch/sgi/include/tcb.h +++ /dev/null @@ -1,3 +0,0 @@ -/* $OpenBSD: tcb.h,v 1.2 2013/06/01 21:20:54 jasper Exp $ */ -/* public domain */ -#include <mips64/tcb.h> diff --git a/sys/arch/sgi/include/timetc.h b/sys/arch/sgi/include/timetc.h deleted file mode 100644 index f538f141819..00000000000 --- a/sys/arch/sgi/include/timetc.h +++ /dev/null @@ -1,23 +0,0 @@ -/* $OpenBSD: timetc.h,v 1.2 2020/07/18 08:37:44 visa Exp $ */ -/* - * Copyright (c) 2020 Paul Irofti <paul@irofti.net> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#ifndef _MACHINE_TIMETC_H_ -#define _MACHINE_TIMETC_H_ - -#include <mips64/timetc.h> - -#endif /* _MACHINE_TIMETC_H_ */ diff --git a/sys/arch/sgi/include/trap.h b/sys/arch/sgi/include/trap.h deleted file mode 100644 index e85b26dc6f1..00000000000 --- a/sys/arch/sgi/include/trap.h +++ /dev/null @@ -1,5 +0,0 @@ -/* $OpenBSD: trap.h,v 1.1 2004/08/06 21:12:19 pefo Exp $ */ - -/* Use Mips generic include file */ - -#include <mips64/trap.h> diff --git a/sys/arch/sgi/include/vmparam.h b/sys/arch/sgi/include/vmparam.h deleted file mode 100644 index d67e16d4ede..00000000000 --- a/sys/arch/sgi/include/vmparam.h +++ /dev/null @@ -1,10 +0,0 @@ -/* $OpenBSD: vmparam.h,v 1.10 2014/07/13 15:48:32 miod Exp $ */ -/* public domain */ -#ifndef _MACHINE_VMPARAM_H_ -#define _MACHINE_VMPARAM_H_ - -#define VM_PHYSSEG_MAX 32 /* Max number of physical memory segments */ - -#include <mips64/vmparam.h> - -#endif /* _MACHINE_VMPARAM_H_ */ diff --git a/sys/arch/sgi/include/z8530var.h b/sys/arch/sgi/include/z8530var.h deleted file mode 100644 index ec176226ca2..00000000000 --- a/sys/arch/sgi/include/z8530var.h +++ /dev/null @@ -1,123 +0,0 @@ -/* $OpenBSD: z8530var.h,v 1.4 2013/04/21 14:44:16 sebastia Exp $ */ -/* $NetBSD: z8530var.h,v 1.10 2011/07/01 21:00:21 dyoung Exp $ */ - -/* - * Copyright (c) 1992, 1993 - * The Regents of the University of California. All rights reserved. - * - * This software was developed by the Computer Systems Engineering group - * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and - * contributed to Berkeley. - * - * All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Lawrence Berkeley Laboratory. - * - * 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. - * 3. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - * - * @(#)zsvar.h 8.1 (Berkeley) 6/11/93 - */ - -/* - * Copyright (c) 1994 Gordon W. Ross - * - * This software was developed by the Computer Systems Engineering group - * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and - * contributed to Berkeley. - * - * All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Lawrence Berkeley Laboratory. - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Berkeley and its contributors. - * 4. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - * - * @(#)zsvar.h 8.1 (Berkeley) 6/11/93 - */ - -#include <machine/bus.h> -#include <dev/ic/z8530sc.h> - -struct zs_channel { - struct zs_chanstate cs_zscs; /* Required: soft state */ - bus_space_tag_t cs_bustag; /* Machine-dependent */ - bus_space_handle_t cs_regs; - int cs_flags; -#define ZSCFL_INVERT_WIRING 0x01 -}; - -struct zsc_softc { - struct device zsc_dev; /* required: base device */ - struct zs_chanstate *zsc_cs[2]; /* channel soft state */ - struct zs_channel zsc_cs_store[2]; - /* Machine-dependent part follows... */ - bus_space_tag_t zsc_bustag; /* Bus type */ - bus_space_handle_t zsc_base; /* Device base address */ - void *sc_si; /* Softinterrupt handle */ -}; - -/* - * Functions to read and write individual registers in a channel. - * The SCC chip requires 3-4 PCLK cycles recovery time between accesses - */ - -uint8_t zs_read_reg(struct zs_chanstate *, uint8_t); -uint8_t zs_read_csr(struct zs_chanstate *); -uint8_t zs_read_data(struct zs_chanstate *); - -void zs_write_reg(struct zs_chanstate *, uint8_t, uint8_t); -void zs_write_csr(struct zs_chanstate *, uint8_t); -void zs_write_data(struct zs_chanstate *, uint8_t); - -/* Zilog Serial hardware interrupts (level 0) */ -#define splzs() spltty() -#define IPL_ZS IPL_TTY diff --git a/sys/arch/sgi/localbus/com_lbus.c b/sys/arch/sgi/localbus/com_lbus.c deleted file mode 100644 index 94acab3b3ce..00000000000 --- a/sys/arch/sgi/localbus/com_lbus.c +++ /dev/null @@ -1,100 +0,0 @@ -/* $OpenBSD: com_lbus.c,v 1.13 2018/12/03 13:46:30 visa Exp $ */ - -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/tty.h> - -#include <machine/bus.h> -#include <machine/intr.h> - -#include <dev/ic/comreg.h> -#include <dev/ic/comvar.h> -#include <dev/ic/ns16550reg.h> - -#include <sgi/localbus/macebusvar.h> - -int com_macebus_probe(struct device *, void *, void *); -void com_macebus_attach(struct device *, struct device *, void *); - -struct cfattach com_macebus_ca = { - sizeof(struct com_softc), com_macebus_probe, com_macebus_attach -}; - -int -com_macebus_probe(struct device *parent, void *match, void *aux) -{ - struct macebus_attach_args *maa = aux; - bus_space_handle_t ioh; - int rv; - - /* If it's in use as the console, then it's there. */ - if (maa->maa_baseaddr == comconsaddr && !comconsattached) - return (1); - - if (bus_space_map(maa->maa_iot, maa->maa_baseaddr, COM_NPORTS, 0, &ioh)) - return (0); - - rv = comprobe1(maa->maa_iot, ioh); - bus_space_unmap(maa->maa_iot, ioh, COM_NPORTS); - - return rv; -} - -void -com_macebus_attach(struct device *parent, struct device *self, void *aux) -{ - struct com_softc *sc = (void *)self; - struct macebus_attach_args *maa = aux; - - sc->sc_iot = maa->maa_iot; - sc->sc_hwflags = 0; - sc->sc_swflags = 0; - sc->sc_iobase = maa->maa_baseaddr; - sc->sc_frequency = 1843200; - - /* If it's in use as the console, then it's there. */ - if (maa->maa_baseaddr == comconsaddr && !comconsattached) { - if (comcnattach(sc->sc_iot, sc->sc_iobase, comconsrate, - sc->sc_frequency, (TTYDEF_CFLAG & ~(CSIZE | PARENB)) | CS8)) - panic("failed to setup serial console!"); - sc->sc_ioh = comconsioh; - } else { - if (bus_space_map(sc->sc_iot, maa->maa_baseaddr, COM_NPORTS, 0, - &sc->sc_ioh)) { - printf(": can't map i/o space\n"); - return; - } - } - - com_attach_subr(sc); - - macebus_intr_establish(maa->maa_intr, maa->maa_mace_intr, - IPL_TTY, comintr, (void *)sc, sc->sc_dev.dv_xname); -} diff --git a/sys/arch/sgi/localbus/crimebus.h b/sys/arch/sgi/localbus/crimebus.h deleted file mode 100644 index 94ead6c8e24..00000000000 --- a/sys/arch/sgi/localbus/crimebus.h +++ /dev/null @@ -1,113 +0,0 @@ -/* $OpenBSD: crimebus.h,v 1.9 2012/04/21 19:17:50 miod Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se). - * - * 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 ``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 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. - * - */ - -#ifndef _CRIMEBUS_H_ -#define _CRIMEBUS_H_ - -#include <machine/bus.h> - -#define CRIMEBUS_BASE 0x14000000 - -#define CRIME_REVISION 0x0000 - -#define CRIME_CONTROL 0x0008 -#define CRIME_CTRL_TRITON_SYSADC 0x2000 -#define CRIME_CTRL_CRIME_SYSADC 0x1000 -#define CRIME_CTRL_HARD_RESET 0x0800 -#define CRIME_CTRL_SOFT_RESET 0x0400 -#define CRIME_CTRL_DOG_ENABLE 0x0200 -#define CRIME_CTRL_ENDIAN_BIG 0x0100 - -#define CRIME_INT_STAT 0x0010 -#define CRIME_INT_MASK 0x0018 -#define CRIME_INT_SOFT 0x0020 -#define CRIME_INT_HARD 0x0028 - -/* - * CRIME_INT_STAT and CRIME_INT_MASK mapping. - */ -#define CRIME_INT_VIDEO_IN_1 0x00000001 /* Video in 1 */ -#define CRIME_INT_VIDEO_IN_2 0x00000002 /* Video in 2 */ -#define CRIME_INT_VIDEO_OUT 0x00000004 /* Video out */ -#define CRIME_INT_MACE_ETHER 0x00000008 /* Mace Ethernet NIC */ -#define CRIME_INT_SUPER_IO 0x00000010 /* Super I/O sub interrupt */ -#define CRIME_INT_SUB_MISC 0x00000020 /* Miscellaneous sub interrupt */ -#define CRIME_INT_SUB_AUDIO 0x00000040 /* Audio sub interrupt */ -#define CRIME_INT_PCI_BRIDGE 0x00000080 /* PCI bridge errors */ -#define CRIME_INT_PCI_SCSI_0 0x00000100 /* AIC SCSI controller 0 */ -#define CRIME_INT_PCI_SCSI_1 0x00000200 /* AIC SCSI controller 1 */ -#define CRIME_INT_PCI_SLOT_0 0x00000400 /* PCI expansion slot 0 */ -#define CRIME_INT_PCI_SLOT_1 0x00000800 /* PCI expansion slot 1 */ -#define CRIME_INT_PCI_SLOT_2 0x00001000 /* PCI expansion slot 2 */ -#define CRIME_INT_PCI_SHARE_0 0x00002000 /* PCI shared 0 */ -#define CRIME_INT_PCI_SHARE_1 0x00004000 /* PCI shared 1 */ -#define CRIME_INT_PCI_SHARE_2 0x00008000 /* PCI shared 2 */ -#define CRIME_INT_GBE_0 0x00010000 /* GBE0 (E) */ -#define CRIME_INT_GBE_1 0x00020000 /* GBE1 (E) */ -#define CRIME_INT_GBE_2 0x00040000 /* GBE2 (E) */ -#define CRIME_INT_GBE_3 0x00080000 /* GBE3 (E) */ -#define CRIME_INT_CPU_ERR 0x00100000 /* CPU Errors */ -#define CRIME_INT_MEM_ERR 0x00200000 /* Memory Errors */ -#define CRIME_INT_RE_EDGE_EMPTY 0x00400000 /* RE */ -#define CRIME_INT_RE_EDGE_FULL 0x00800000 /* RE */ -#define CRIME_INT_RE_EDGE_IDLE 0x01000000 /* RE */ -#define CRIME_INT_RE_LEVL_EMPTY 0x02000000 /* RE */ -#define CRIME_INT_RE_LEVL_FULL 0x04000000 /* RE */ -#define CRIME_INT_RE_LEVL_IDLE 0x08000000 /* RE */ -#define CRIME_INT_SOFT_0 0x10000000 /* ??? */ -#define CRIME_INT_SOFT_1 0x20000000 /* ??? */ -#define CRIME_INT_SOFT_2 0x40000000 /* ??? */ -#define CRIME_INT_VICE 0x80000000 /* Video Image Compression Engine */ - -#define CRIME_NINTS 32 - - -/* - * Watchdog? - */ -#define CRIME_KICK_DOG 0x0030 -#define CRIME_TIMER 0x0038 - -#define CRIME_CPU_ERROR_ADDR 0x0040 -#define CRIME_CPU_ERROR_STAT 0x0048 -#define CRIME_CPU_ERROR_ENAB 0x0050 - -#define CRIME_MEM_BANK0_CONTROL 0x0208 -#define CRIME_MEM_BANK_ADDR 0x01f -#define CRIME_MEM_BANK_128MB 0x100 -#define CRIME_MAX_BANKS 8 - -#define CRIME_MEMORY_OFFSET 0x40000000 /* 1GB */ -#define CRIME_MEMORY_MASK 0x3fffffff - -#define CRIME_MEM_ERROR_STAT 0x0250 -#define CRIME_MEM_ERROR_ADDR 0x0258 - -extern bus_space_t crimebus_tag; - -#endif /* _CRIMEBUS_H_ */ diff --git a/sys/arch/sgi/localbus/imc.c b/sys/arch/sgi/localbus/imc.c deleted file mode 100644 index bd8813eba03..00000000000 --- a/sys/arch/sgi/localbus/imc.c +++ /dev/null @@ -1,984 +0,0 @@ -/* $OpenBSD: imc.c,v 1.22 2017/05/11 15:47:45 visa Exp $ */ -/* $NetBSD: imc.c,v 1.32 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2001 Rafal K. Boni - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * Indigo/Indigo2/Indy on-board Memory Controller support code. - */ - -#include <sys/param.h> -#include <sys/device.h> -#include <sys/systm.h> - -#include <mips64/archtype.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> - -#include <sgi/sgi/ip22.h> -#include <sgi/localbus/imcreg.h> -#include <sgi/localbus/imcvar.h> -#include <sgi/localbus/intreg.h> - -#include <sgi/hpc/hpcreg.h> -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giovar.h> - -#include "eisa.h" - -#if NEISA > 0 -#include <dev/eisa/eisavar.h> -#endif - -int imc_match(struct device *, void *, void *); -void imc_attach(struct device *, struct device *, void *); -int imc_activate(struct device *, int); -int imc_print(void *, const char *); - -const struct cfattach imc_ca = { - sizeof(struct device), imc_match, imc_attach, NULL, imc_activate -}; - -struct cfdriver imc_cd = { - NULL, "imc", DV_DULL -}; - -uint32_t imc_bus_error(uint32_t, struct trapframe *); -int imc_watchdog_cb(void *, int); - -void imc_space_barrier(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, int); - -/* can't be static for gio_cnattach() */ -bus_space_t imcbus_tag = { - PHYS_TO_XKPHYS(0, CCA_NC), - NULL, - imc_read_1, imc_write_1, - imc_read_2, imc_write_2, - imc_read_4, imc_write_4, - imc_read_8, imc_write_8, - imc_read_raw_2, imc_write_raw_2, - imc_read_raw_4, imc_write_raw_4, - imc_read_raw_8, imc_write_raw_8, - imc_space_map, imc_space_unmap, imc_space_region, - imc_space_vaddr, imc_space_barrier -}; - -#if NEISA > 0 -void imc_eisa_read_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void imc_eisa_write_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -void imc_eisa_read_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void imc_eisa_write_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -void imc_eisa_read_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void imc_eisa_write_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -int imc_eisa_io_map(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -int imc_eisa_io_region(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, bus_space_handle_t *); -int imc_eisa_mem_map(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -int imc_eisa_mem_region(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, bus_space_handle_t *); - -static bus_space_t imcbus_eisa_io_tag = { - PHYS_TO_XKPHYS(EISA_IO_BASE, CCA_NC), - NULL, - imc_read_1, imc_write_1, - imc_read_2, imc_write_2, - imc_read_4, imc_write_4, - imc_read_8, imc_write_8, - imc_eisa_read_raw_2, imc_eisa_write_raw_2, - imc_eisa_read_raw_4, imc_eisa_write_raw_4, - imc_eisa_read_raw_8, imc_eisa_write_raw_8, - imc_eisa_io_map, imc_space_unmap, imc_eisa_io_region, - imc_space_vaddr, imc_space_barrier -}; -static bus_space_t imcbus_eisa_mem_tag = { - PHYS_TO_XKPHYS(0, CCA_NC), - NULL, - imc_read_1, imc_write_1, - imc_read_2, imc_write_2, - imc_read_4, imc_write_4, - imc_read_8, imc_write_8, - imc_read_raw_2, imc_write_raw_2, - imc_read_raw_4, imc_write_raw_4, - imc_read_raw_8, imc_write_raw_8, - imc_eisa_mem_map, imc_space_unmap, imc_eisa_mem_region, - imc_space_vaddr, imc_space_barrier -}; -#endif - -bus_addr_t imc_pa_to_device(paddr_t, int); - -/* can't be static for gio_cnattach() */ -struct machine_bus_dma_tag imc_bus_dma_tag = { - NULL, /* _cookie */ - _dmamap_create, - _dmamap_destroy, - _dmamap_load, - _dmamap_load_mbuf, - _dmamap_load_uio, - _dmamap_load_raw, - _dmamap_load_buffer, - _dmamap_unload, - _dmamap_sync, - _dmamem_alloc, - _dmamem_free, - _dmamem_map, - _dmamem_unmap, - _dmamem_mmap, - imc_pa_to_device, - 0 -}; - -/* - * Bus access primitives. - */ - -uint8_t -imc_read_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint8_t *)(h + o); -} - -uint16_t -imc_read_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint16_t *)(h + o); -} - -uint32_t -imc_read_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint32_t *)(h + o); -} - -uint64_t -imc_read_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint64_t *)(h + o); -} - -void -imc_write_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint8_t v) -{ - *(volatile uint8_t *)(h + o) = v; -} - -void -imc_write_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint16_t v) -{ - *(volatile uint16_t *)(h + o) = v; -} - -void -imc_write_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint32_t v) -{ - *(volatile uint32_t *)(h + o) = v; -} - -void -imc_write_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint64_t v) -{ - *(volatile uint64_t *)(h + o) = v; -} - -void -imc_read_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)(h + o); - len >>= 1; - while (len-- != 0) { - *(uint16_t *)buf = *addr; - buf += 2; - } -} - -void -imc_write_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)(h + o); - len >>= 1; - while (len-- != 0) { - *addr = *(uint16_t *)buf; - buf += 2; - } -} - -void -imc_read_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *(uint32_t *)buf = *addr; - buf += 4; - } -} - -void -imc_write_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *addr = *(uint32_t *)buf; - buf += 4; - } -} - -void -imc_read_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *(uint64_t *)buf = *addr; - buf += 8; - } -} - -void -imc_write_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *addr = *(uint64_t *)buf; - buf += 8; - } -} - -int -imc_space_map(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ - *bshp = t->bus_base + offs; - return 0; -} - -void -imc_space_unmap(bus_space_tag_t t, bus_space_handle_t bsh, bus_size_t size) -{ -} - -int -imc_space_region(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ - *nbshp = bsh + offset; - return 0; -} - -void * -imc_space_vaddr(bus_space_tag_t t, bus_space_handle_t h) -{ - return (void *)h; -} - -void -imc_space_barrier(bus_space_tag_t t, bus_space_handle_t h, bus_size_t offs, - bus_size_t len, int flags) -{ - mips_sync(); -} - -#if NEISA > 0 -void -imc_eisa_read_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)(h + o); - len >>= 1; - while (len-- != 0) { - *(uint16_t *)buf = swap16(*addr); - buf += 2; - } -} - -void -imc_eisa_write_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)(h + o); - len >>= 1; - while (len-- != 0) { - *addr = swap16(*(uint16_t *)buf); - buf += 2; - } -} - -void -imc_eisa_read_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *(uint32_t *)buf = swap32(*addr); - buf += 4; - } -} - -void -imc_eisa_write_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *addr = swap32(*(uint32_t *)buf); - buf += 4; - } -} - -void -imc_eisa_read_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *(uint64_t *)buf = swap64(*addr); - buf += 8; - } -} - -void -imc_eisa_write_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *addr = swap64(*(uint64_t *)buf); - buf += 8; - } -} - -int -imc_eisa_io_map(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, int flags, - bus_space_handle_t *bshp) -{ - if (offs + size > EISA_IO_END - EISA_IO_BASE) - return EINVAL; - - *bshp = t->bus_base + offs; - return 0; -} - -int -imc_eisa_io_region(bus_space_tag_t t, bus_space_handle_t bsh, bus_size_t offset, - bus_size_t size, bus_space_handle_t *nbshp) -{ - if ((bsh - t->bus_base) + offset + size > EISA_IO_END - EISA_IO_BASE) - return EINVAL; - - *nbshp = bsh + offset; - return 0; -} - -int -imc_eisa_mem_map(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, int flags, - bus_space_handle_t *bshp) -{ - if ((offs >= EISA_MEM0_BASE && offs + size <= EISA_MEM0_END) || - (offs >= EISA_MEM1_BASE && offs + size <= EISA_MEM1_END)) { - *bshp = t->bus_base + offs; - return 0; - } - - return EINVAL; -} - -int -imc_eisa_mem_region(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ - bus_addr_t orig = bsh - t->bus_base; - - if ((orig >= EISA_MEM0_BASE && orig + offset + size <= EISA_MEM0_END) || - (orig >= EISA_MEM1_BASE && orig + offset + size <= EISA_MEM1_END)) { - *nbshp = t->bus_base + offset; - return 0; - } - - return EINVAL; -} -#endif - -bus_addr_t -imc_pa_to_device(paddr_t pa, int flags) -{ - return (bus_addr_t)pa; -} - -/* - * For some reason, reading the arbitration register sometimes returns - * wrong values, at least on IP20 (where the usual value is 0x400, but - * nonsense values such as 0x34f have been witnessed). - * Because of this, we'll treat the register as write-only, once we have - * been able to read a supposedly safe value. - * This variable contains the last known value written to this register. - */ -uint32_t imc_arb_value; - -/* - * Autoconf glue. - */ - -int -imc_match(struct device *parent, void *match, void *aux) -{ - struct mainbus_attach_args *maa = (void *)aux; - - switch (sys_config.system_type) { - case SGI_IP20: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - break; - default: - return 0; - } - - return strcmp(maa->maa_name, imc_cd.cd_name) == 0; -} - -void -imc_attach(struct device *parent, struct device *self, void *aux) -{ - struct imc_attach_args iaa; -#if NEISA > 0 - struct eisabus_attach_args eba; -#endif - uint32_t reg, lastreg; - uint32_t id, rev; - int have_eisa; - - id = imc_read(IMC_SYSID); - rev = id & IMC_SYSID_REVMASK; - - /* EISA exists on Indigo2 only */ - if (sys_config.system_type != SGI_IP20 && - sys_config.system_subtype == IP22_INDIGO2) - have_eisa = (id & IMC_SYSID_HAVEISA) != 0; - else - have_eisa = 0; - - printf(": revision %d\n", rev); - - /* Clear CPU/GIO error status registers to clear any leftover bits. */ - imc_bus_reset(); - - /* Disable watchdog if leftover from previous reboot */ - imc_watchdog_cb(self, 0); - - /* Hook the bus error handler into the ISR */ - set_intr(INTPRI_BUSERR, CR_INT_4, imc_bus_error); - - /* - * Enable parity reporting on GIO/main memory transactions, except - * on systems with the ECC memory controller, where enabling parity - * interferes with regular operation and causes sticky false errors. - * - * Disable parity checking on CPU bus transactions (as turning - * it on seems to cause spurious bus errors), but enable parity - * checking on CPU reads from main memory (note that this bit - * has the opposite sense... Turning it on turns the checks off!). - * - * Finally, turn on interrupt writes to the CPU from the MC. - */ - reg = imc_read(IMC_CPUCTRL0); - if (ip22_ecc) - reg &= ~(IMC_CPUCTRL0_GPR | IMC_CPUCTRL0_MPR); - else - reg |= IMC_CPUCTRL0_GPR | IMC_CPUCTRL0_MPR; - reg &= ~IMC_CPUCTRL0_NCHKMEMPAR; - reg |= IMC_CPUCTRL0_INTENA; - imc_write(IMC_CPUCTRL0, reg); - - /* Setup the MC write buffer depth */ - /* - * XXX This hardcoded value is not documented anywhere, and can be - * XXX traced back to DaveM's internship at SGI in 1996, so it can - * XXX be considered correct at least for IP24 (and, to a lesser - * XXX extent, IP22). IP20 and IP28 systems seem to run happy with - * XXX this value as well. - */ - reg = imc_read(IMC_CPUCTRL1); - reg = (reg & ~IMC_CPUCTRL1_MCHWMSK) | 13; - - /* - * Force endianness on the onboard HPC and both slots. - * This should be safe for Fullhouse, but leave it conditional - * for now. - */ - switch (sys_config.system_type) { - case SGI_IP22: - if (sys_config.system_subtype == IP22_INDIGO2) - break; - /* FALLTHROUGH */ - case SGI_IP20: - reg |= IMC_CPUCTRL1_HPCFX; - reg |= IMC_CPUCTRL1_EXP0FX; - reg |= IMC_CPUCTRL1_EXP1FX; - reg &= ~IMC_CPUCTRL1_HPCLITTLE; - reg &= ~IMC_CPUCTRL1_EXP0LITTLE; - reg &= ~IMC_CPUCTRL1_EXP1LITTLE; - break; - } - imc_write(IMC_CPUCTRL1, reg); - - /* - * Try and read the GIO64 arbitrator configuration register value. - * See comments above the declaration of imc_arb_value for why we - * are doing this. - */ - reg = 0; lastreg = ~reg; - while (reg != lastreg || (reg & ~0xffff) != 0) { - lastreg = reg; - reg = imc_read(IMC_GIO64ARB); - /* read another harmless register */ - (void)imc_read(IMC_CPUCTRL0); - } - - /* - * Set GIO64 arbitrator configuration register: - * - * Preserve PROM-set graphics-related bits, as they seem to depend - * on the graphics variant present and I'm not sure how to figure - * that out or 100% sure what the correct settings are for each. - */ - reg &= (IMC_GIO64ARB_GRX64 | IMC_GIO64ARB_GRXRT | IMC_GIO64ARB_GRXMST); - - /* - * Rest of settings are machine/board dependent - */ - switch (sys_config.system_type) { - case SGI_IP20: - reg |= IMC_GIO64ARB_ONEGIO; - reg |= IMC_GIO64ARB_EXP0RT | IMC_GIO64ARB_EXP1RT; - reg |= IMC_GIO64ARB_EXP0MST | IMC_GIO64ARB_EXP1MST; - reg &= ~(IMC_GIO64ARB_HPC64 | - IMC_GIO64ARB_HPCEXP64 | IMC_GIO64ARB_EISA64 | - IMC_GIO64ARB_EXP064 | IMC_GIO64ARB_EXP164 | - IMC_GIO64ARB_EXP0PIPE | IMC_GIO64ARB_EXP1PIPE); - break; - default: - /* - * GIO64 invariant for all IP22 platforms: one GIO bus, - * HPC1 @ 64 - */ - reg |= IMC_GIO64ARB_ONEGIO | IMC_GIO64ARB_HPC64; - - switch (sys_config.system_subtype) { - default: - case IP22_INDY: - case IP22_CHALLS: - /* XXX is MST mutually exclusive? */ - reg |= IMC_GIO64ARB_EXP0RT | IMC_GIO64ARB_EXP1RT; - reg |= IMC_GIO64ARB_EXP0MST | IMC_GIO64ARB_EXP1MST; - - /* EISA (VINO, really) can bus-master, is 64-bit */ - reg |= IMC_GIO64ARB_EISAMST | IMC_GIO64ARB_EISA64; - break; - - case IP22_INDIGO2: - /* - * All Fullhouse boards have a 64-bit HPC2 and pipelined - * EXP0 slot. - */ - reg |= IMC_GIO64ARB_HPCEXP64 | IMC_GIO64ARB_EXP0PIPE; - - /* - * The EISA bus is the real thing, and is a 32-bit bus. - */ - reg &= ~IMC_GIO64ARB_EISA64; - - if (rev < 2) { - /* EXP0 realtime, EXP1 can master */ - reg |= IMC_GIO64ARB_EXP0RT | - IMC_GIO64ARB_EXP1MST; - } else { - /* EXP1 pipelined as well, EISA masters */ - reg |= IMC_GIO64ARB_EXP1PIPE | - IMC_GIO64ARB_EISAMST; - } - break; - } - } - - imc_write(IMC_GIO64ARB, reg); - imc_arb_value = reg; - - memset(&iaa, 0, sizeof(iaa)); - iaa.iaa_name = "gio"; - iaa.iaa_st = &imcbus_tag; - iaa.iaa_dmat = &imc_bus_dma_tag; - config_found(self, &iaa, imc_print); - -#if NEISA > 0 - if (have_eisa) { - memset(&eba, 0, sizeof(eba)); - eba.eba_busname = "eisa"; - eba.eba_iot = &imcbus_eisa_io_tag; - eba.eba_memt = &imcbus_eisa_mem_tag; - eba.eba_dmat = &imc_bus_dma_tag; - eba.eba_ec = NULL; - config_found(self, &eba, imc_print); - } -#endif - -#ifndef SMALL_KERNEL - /* Register watchdog */ - wdog_register(imc_watchdog_cb, self); -#endif -} - -int -imc_activate(struct device *self, int act) -{ - int rv = 0; - - switch (act) { - case DVACT_POWERDOWN: -#ifndef SMALL_KERNEL - wdog_shutdown(self); -#endif - rv = config_activate_children(self, act); - break; - } - - return (rv); -} - -int -imc_print(void *aux, const char *name) -{ - struct imc_attach_args *iaa = aux; - - if (name != NULL) - printf("%s at %s", iaa->iaa_name, name); - - return UNCONF; -} - -void -imc_bus_reset() -{ - imc_write(IMC_CPU_ERRSTAT, 0); - imc_write(IMC_GIO_ERRSTAT, 0); -} - -uint32_t -imc_bus_error(uint32_t hwpend, struct trapframe *tf) -{ - uint32_t cpustat, giostat; - paddr_t cpuaddr, gioaddr; - int cpuquiet = 0, gioquiet = 0; - - cpustat = imc_read(IMC_CPU_ERRSTAT); - giostat = imc_read(IMC_GIO_ERRSTAT); - - if (sys_config.system_type == SGI_IP26) { - /* - * We are sharing the bus error interrupt with the streaming - * cache controller. This interrupt might not be ours. - */ - if (cpustat == 0 && giostat == 0) - return 0; - } - - if (cpustat != 0) - cpuaddr = imc_read(IMC_CPU_ERRADDR); - if (giostat != 0) - gioaddr = imc_read(IMC_GIO_ERRADDR); - - switch (sys_config.system_type) { - case SGI_IP28: - /* - * R10000 speculative execution may attempt to access - * non-existing memory when in the kernel. We do not - * want to flood the console about those. - */ - if (cpustat & IMC_CPU_ERRSTAT_ADDR) { - if (IS_XKPHYS((vaddr_t)tf->pc)) - cpuquiet = 1; - } - if (giostat != 0) { - /* - * Ignore speculative writes to interrupt controller - * registers. - */ - if ((giostat & IMC_ECC_ERRSTAT_FUW) && - (gioaddr & ~0x3f) == INT2_IP22) - gioquiet = 1; - /* XXX is it wise to hide these? */ - if ((giostat & IMC_GIO_ERRSTAT_TMO) && - !IS_GIO_ADDRESS(gioaddr)) - gioquiet = 1; - } - break; - } - - if (cpustat != 0 && cpuquiet == 0) { - vaddr_t pc = tf->pc; - uint32_t insn = 0xffffffff; - - if (tf->pc < 0) - guarded_read_4(pc, &insn); - else - copyin((void *)pc, &insn, sizeof insn); - - printf("bus error: cpu_stat %08x addr %08lx pc %p insn %08x\n", - cpustat, cpuaddr, (void *)pc, insn); - } - if (giostat != 0 && gioquiet == 0) { - printf("bus error: gio_stat %08x addr %08lx\n", - giostat, gioaddr); - } - - if (cpustat != 0) - imc_write(IMC_CPU_ERRSTAT, 0); - if (giostat != 0) - imc_write(IMC_GIO_ERRSTAT, 0); - - return hwpend; -} - -int -imc_watchdog_cb(void *v, int period) -{ - uint32_t reg; - - if (period == 0) { - /* reset... */ - imc_write(IMC_WDOG, 0); - /* ...and disable */ - reg = imc_read(IMC_CPUCTRL0); - reg &= ~(IMC_CPUCTRL0_WDOG); - imc_write(IMC_CPUCTRL0, reg); - - return 0; - } else { - /* enable... */ - reg = imc_read(IMC_CPUCTRL0); - reg |= IMC_CPUCTRL0_WDOG; - imc_write(IMC_CPUCTRL0, reg); - /* ...and reset */ - imc_write(IMC_WDOG, 0); - - /* - * The watchdog period is not controllable; it will fire - * when the 20 bit counter, running on a 64 usec clock, - * overflows. - */ - return (64 << 20) / 1000000; - } -} - -/* intended to be called from gio/gio.c only */ -int -imc_gio64_arb_config(int slot, uint32_t flags) -{ - uint32_t reg; - - if (sys_config.system_type == SGI_IP20 || - sys_config.system_subtype != IP22_INDIGO2) { - /* GIO_SLOT_GFX is only usable on Fullhouse */ - if (slot == GIO_SLOT_GFX) - return EINVAL; - } else { - /* GIO_SLOT_EXP1 is unusable on Fullhouse */ - if (slot == GIO_SLOT_EXP1) - return EINVAL; - } - - /* GIO_SLOT_GFX is always pipelined */ - if (slot == GIO_SLOT_GFX && (flags & GIO_ARB_NOPIPE)) - return EINVAL; - - /* IP20 does not support pipelining (XXX what about Indy?) */ - if (((flags & GIO_ARB_PIPE) || (flags & GIO_ARB_NOPIPE)) && - sys_config.system_type == SGI_IP20) - return EINVAL; - - reg = imc_arb_value; - - if (flags & GIO_ARB_RT) { - if (slot == GIO_SLOT_EXP0) - reg |= IMC_GIO64ARB_EXP0RT; - else if (slot == GIO_SLOT_EXP1) - reg |= IMC_GIO64ARB_EXP1RT; - else if (slot == GIO_SLOT_GFX) - reg |= IMC_GIO64ARB_GRXRT; - } - - if (flags & GIO_ARB_MST) { - if (slot == GIO_SLOT_EXP0) - reg |= IMC_GIO64ARB_EXP0MST; - else if (slot == GIO_SLOT_EXP1) - reg |= IMC_GIO64ARB_EXP1MST; - else if (slot == GIO_SLOT_GFX) - reg |= IMC_GIO64ARB_GRXMST; - } - - if (flags & GIO_ARB_PIPE) { - if (slot == GIO_SLOT_EXP0) - reg |= IMC_GIO64ARB_EXP0PIPE; - else if (slot == GIO_SLOT_EXP1) - reg |= IMC_GIO64ARB_EXP1PIPE; - } - - if (flags & GIO_ARB_LB) { - if (slot == GIO_SLOT_EXP0) - reg &= ~IMC_GIO64ARB_EXP0RT; - else if (slot == GIO_SLOT_EXP1) - reg &= ~IMC_GIO64ARB_EXP1RT; - else if (slot == GIO_SLOT_GFX) - reg &= ~IMC_GIO64ARB_GRXRT; - } - - if (flags & GIO_ARB_SLV) { - if (slot == GIO_SLOT_EXP0) - reg &= ~IMC_GIO64ARB_EXP0MST; - else if (slot == GIO_SLOT_EXP1) - reg &= ~IMC_GIO64ARB_EXP1MST; - else if (slot == GIO_SLOT_GFX) - reg &= ~IMC_GIO64ARB_GRXMST; - } - - if (flags & GIO_ARB_NOPIPE) { - if (slot == GIO_SLOT_EXP0) - reg &= ~IMC_GIO64ARB_EXP0PIPE; - else if (slot == GIO_SLOT_EXP1) - reg &= ~IMC_GIO64ARB_EXP1PIPE; - } - - if (flags & GIO_ARB_32BIT) { - if (slot == GIO_SLOT_EXP0) - reg &= ~IMC_GIO64ARB_EXP064; - else if (slot == GIO_SLOT_EXP1) - reg &= ~IMC_GIO64ARB_EXP164; - } - - if (flags & GIO_ARB_64BIT) { - if (slot == GIO_SLOT_EXP0) - reg |= IMC_GIO64ARB_EXP064; - else if (slot == GIO_SLOT_EXP1) - reg |= IMC_GIO64ARB_EXP164; - } - - if (flags & GIO_ARB_HPC2_32BIT) - reg &= ~IMC_GIO64ARB_HPCEXP64; - - if (flags & GIO_ARB_HPC2_64BIT) - reg |= IMC_GIO64ARB_HPCEXP64; - - imc_write(IMC_GIO64ARB, reg); - imc_arb_value = reg; - - return 0; -} - -/* - * According to chapter 19 of the "IRIX Device Driver Programmer's Guide", - * some GIO devices, which do not drive all data lines, may cause false - * memory read parity errors on the SysAD bus. The workaround is to disable - * parity checking. - */ -void -imc_disable_sysad_parity(void) -{ - uint32_t reg; - - if (ip22_ecc) - return; - - reg = imc_read(IMC_CPUCTRL0); - reg |= IMC_CPUCTRL0_NCHKMEMPAR; - imc_write(IMC_CPUCTRL0, reg); -} - -void -imc_enable_sysad_parity(void) -{ - uint32_t reg; - - if (ip22_ecc) - return; - - reg = imc_read(IMC_CPUCTRL0); - reg &= ~IMC_CPUCTRL0_NCHKMEMPAR; - imc_write(IMC_CPUCTRL0, reg); -} - -#if 0 -int -imc_is_sysad_parity_enabled(void) -{ - uint32_t reg; - - if (ip22_ecc) - return 0; - - reg = imc_read(IMC_CPUCTRL0); - return ~reg & IMC_CPUCTRL0_NCHKMEMPAR; -} -#endif diff --git a/sys/arch/sgi/localbus/imcreg.h b/sys/arch/sgi/localbus/imcreg.h deleted file mode 100644 index 0f7cfa7abb8..00000000000 --- a/sys/arch/sgi/localbus/imcreg.h +++ /dev/null @@ -1,179 +0,0 @@ -/* $OpenBSD: imcreg.h,v 1.5 2014/07/02 17:44:35 miod Exp $ */ -/* $NetBSD: imcreg.h,v 1.4 2005/12/11 12:18:52 christos Exp $ */ - -/* - * Copyright (c) 2001 Rafal K. Boni - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -#define IMC_BASE 0x1fa00000 - -#define IMC_CPUCTRL0 0x04 /* CPU control, register 0 */ - -#define IMC_CPUCTRL0_REFMASK 0x0000000f /* # lines to refresh */ -#define IMC_CPUCTRL0_RFE 0x00000010 /* refresh enable */ -#define IMC_CPUCTRL0_GPR 0x00000020 /* GIO parity enable */ -#define IMC_CPUCTRL0_MPR 0x00000040 /* memory parity enable */ -#define IMC_CPUCTRL0_CPR 0x00000080 /* cpu bus parity enable */ -#define IMC_CPUCTRL0_WDOG 0x00000100 /* watchdog enable */ -#define IMC_CPUCTRL0_SIN 0x00000200 /* reset system */ -#define IMC_CPUCTRL0_GRR 0x00000400 /* graphics reset */ -#define IMC_CPUCTRL0_ENLOCK 0x00000800 /* enable EISA memory lock */ -#define IMC_CPUCTRL0_CMDPAR 0x00001000 /* SysCmd parity enable */ -#define IMC_CPUCTRL0_INTENA 0x00002000 /* enable CPU interrupts */ -#define IMC_CPUCTRL0_SNOOPENA 0x00004000 /* enable gfx DMA snoop */ -#define IMC_CPUCTRL0_PROM_WRENA 0x00008000 /* disable buserr on PROM - * writes */ -#define IMC_CPUCTRL0_WRST 0x00010000 /* warm restart (reset cpu) */ -/* Bit 17 reserved 0x00020000 */ -#define IMC_CPUCTRL0_LITTLE 0x00040000 /* MC little-endian toggle */ -#define IMC_CPUCTRL0_WRRST 0x00080000 /* cpu warm reset */ -#define IMC_CPUCTRL0_MUXHWMSK 0x01f00000 /* MUX fifo high-water mask */ -#define IMC_CPUCTRL0_BADPAR 0x02000000 /* generate bad parity on - * CPU->memory writes */ -#define IMC_CPUCTRL0_NCHKMEMPAR 0x04000000 /* disable CPU parity check - * on memory reads. */ -#define IMC_CPUCTRL0_BACK2 0x08000000 /* enable back2back GIO wrt */ -#define IMC_CPUCTRL0_BUSRTMSK 0xf0000000 /* stall cycle for berr data */ - -#define IMC_CPUCTRL1 0x0c /* CPU control, register 1 */ -#define IMC_CPUCTRL1_MCHWMSK 0x0000000f /* MC FIFO high water mask */ -#define IMC_CPUCTRL1_ABORTEN 0x00000010 /* Enable GIO bus timeouts */ -/* Bits 5 - 11 reserved 0x00000fe0 */ -#define IMC_CPUCTRL1_HPCFX 0x00001000 /* HPC endian fix */ -#define IMC_CPUCTRL1_HPCLITTLE 0x00002000 /* HPC DMA is little-endian */ -#define IMC_CPUCTRL1_EXP0FX 0x00004000 /* EXP0 endian fix */ -#define IMC_CPUCTRL1_EXP0LITTLE 0x00008000 /* EXP0 DMA is little-endian */ -#define IMC_CPUCTRL1_EXP1FX 0x00010000 /* EXP1 endian fix */ -#define IMC_CPUCTRL1_EXP1LITTLE 0x00020000 /* EXP1 DMA is little-endian */ - -#define IMC_WDOG 0x14 /* Watchdog counter */ -#define IMC_WDOG_MASK 0x001fffff /* counter mask */ - -#define IMC_SYSID 0x1c /* MC revision register */ -#define IMC_SYSID_REVMASK 0x0000000f /* MC revision mask */ -#define IMC_SYSID_HAVEISA 0x00000010 /* EISA present */ - -#define IMC_RPSSDIV 0x2c /* RPSS divider */ -#define IMC_RPSSDIV_DIVMSK 0x000000ff /* RPC divider mask */ -#define IMC_RPSSDIV_INCMSK 0x0000ff00 /* RPC increment mask */ - -#define IMC_EEPROM 0x34 /* EEPROM serial interface */ -/* Bit 1 is reserved 0x00000001 */ -#define IMC_EEPROM_CS 0x00000002 /* EEPROM chip select */ -#define IMC_EEPROM_SCK 0x00000004 /* EEPROM serial clock */ -#define IMC_EEPROM_SO 0x00000008 /* Serial data to EEPROM */ -#define IMC_EEPROM_SI 0x00000010 /* Serial data from EEPROM */ - -#define IMC_CTRLD 0x44 /* Refresh counter preload */ -#define IMC_CTRLD_MSK 0x000000ff /* Counter preload mask */ - -#define IMC_REFCTR 0x4c /* Refresh counter */ -#define IMC_REFCTR_MSK 0x000000ff /* Refresh counter mask */ - -#define IMC_GIO64ARB 0x84 /* GIO64 arbitration params */ -#define IMC_GIO64ARB_HPC64 0x00000001 /* HPC addr size (32/64bit) */ -#define IMC_GIO64ARB_GRX64 0x00000002 /* Gfx addr size (32/64bit) */ -#define IMC_GIO64ARB_EXP064 0x00000004 /* EXP0 addr size (32/64bit) */ -#define IMC_GIO64ARB_EXP164 0x00000008 /* EXP1 addr size (32/64bit) */ -#define IMC_GIO64ARB_EISA64 0x00000010 /* EISA addr size (32/64bit) */ -#define IMC_GIO64ARB_HPCEXP64 0x00000020 /* HPC2 addr size (32/64bit) */ -#define IMC_GIO64ARB_GRXRT 0x00000040 /* Gfx is realtime device */ -#define IMC_GIO64ARB_EXP0RT 0x00000080 /* EXP0 is realtime device */ -#define IMC_GIO64ARB_EXP1RT 0x00000100 /* EXP1 is realtime device */ -#define IMC_GIO64ARB_EISAMST 0x00000200 /* EISA can be busmaster */ -#define IMC_GIO64ARB_ONEGIO 0x00000400 /* Only one GIO64 bus */ -#define IMC_GIO64ARB_GRXMST 0x00000800 /* Gfx can be busmaster */ -#define IMC_GIO64ARB_EXP0MST 0x00001000 /* EXP0 can be busmaster */ -#define IMC_GIO64ARB_EXP1MST 0x00002000 /* EXP1 can be busmaster */ -#define IMC_GIO64ARB_EXP0PIPE 0x00004000 /* EXP0 is pipelined */ -#define IMC_GIO64ARB_EXP1PIPE 0x00008000 /* EXP1 is pipelined */ - -#define IMC_CPUTIME 0x8c /* Arbiter CPU time period */ - -#define IMC_LBTIME 0x9c /* Arbiter long-burst time */ - -#define IMC_MEMCFG0 0xc4 /* Mem config, register 0 */ -#define IMC_MEMCFG1 0xcc /* Mem config, register 1 */ -#define IMC_MEMC_BANK_MASK 0x0000ffff -#define IMC_MEMC_BANK_SHIFT 16 -#define IMC_MEMC_ADDR_MASK 0x00ff -#define IMC_MEMC_ADDR_SHIFT 0 -#define IMC_MEMC_SIZE_MASK 0x1f00 -#define IMC_MEMC_SIZE_SHIFT 8 -#define IMC_MEMC_LSHIFT 22 /* 4MB units */ -#define IMC_MEMC_LSHIFT_HUGE 24 /* 16MB units */ -#define IMC_MEMC_VALID 0x2000 -#define IMC_MEMC_SUBBANKS 0x4000 - -#define IMC_CPU_MEMACC 0xd4 /* CPU mem access config */ - -#define IMC_GIO_MEMACC 0xdc /* GIO mem access config */ - -#define IMC_CPU_ERRADDR 0xe4 /* CPU error address */ -#define IMC_CPU_ERRSTAT 0xec /* CPU error status */ -#define IMC_CPU_ERRSTAT_RD 0x00000100 /* memory parity error */ -#define IMC_CPU_ERRSTAT_PAR 0x00000200 /* CPU parity error */ -#define IMC_CPU_ERRSTAT_ADDR 0x00000400 /* memory bus error */ -#define IMC_CPU_ERRSTAT_SYSAD 0x00000800 /* SysAD parity error */ -#define IMC_CPU_ERRSTAT_SYSCMD 0x00001000 /* syscmd parity error */ - -#define IMC_GIO_ERRADDR 0xf4 /* GIO error address */ -#define IMC_GIO_ERRSTAT 0xfc /* GIO error status */ -#define IMC_GIO_ERRSTAT_RD 0x00000100 /* read parity error */ -#define IMC_GIO_ERRSTAT_WR 0x00000200 /* write parity error */ -#define IMC_GIO_ERRSTAT_TMO 0x00000400 /* bus timeout */ -#define IMC_GIO_ERRSTAT_PROM 0x00000800 /* PROM write while disabled */ -#define IMC_GIO_ERRSTAT_ADDR 0x00001000 /* parity error during */ - /* address cycle */ -#define IMC_GIO_ERRSTAT_BC 0x00002000 /* parity error during */ - /* byte count cycle */ -#define IMC_GIO_ERRSTAT_PIO_RD 0x00004000 /* data parity error during */ - /* PIO read */ -#define IMC_GIO_ERRSTAT_PIO_WR 0x00008000 /* data parity error during */ - /* PIO write */ -/* {CPU,GIO}_ERRSTAT bits in ECC mode */ -#define IMC_ECC_ERRSTAT_FUW 0x00000001 /* fast mode uncached write */ -#define IMC_ECC_ERRSTAT_MULTI 0x00000002 /* multi bit error */ - -#define IMC_RPSS 0x1004 /* RPSS counter */ - -/* - * IP26/IP28 ECC Controller defines - */ - -#define ECC_BASE 0x60000000 -/* control register */ -#define ECC_CTRL 0x00 -#define ECC_CTRL_ENABLE 0x00000000 /* fast mode */ -#define ECC_CTRL_DISABLE 0x00010000 /* slow mode */ -#define ECC_CTRL_WRITE 0x00020000 /* write low bits to chip */ -#define ECC_CTRL_INT_CLR 0x00030000 /* clear pending interrupts */ -#define ECC_CTRL_CHK_ENABLE 0x00050000 /* enable ECC err generation */ -#define ECC_CTRL_CHK_DISABLE 0x00060000 /* disable ECC err generation */ - -/* ecc control chip modes */ -#define ECC_MODE_PASSTHROUGH 0x0002 /* error detection only */ -#define ECC_MODE_NORMAL 0x0003 /* error detection and correction */ diff --git a/sys/arch/sgi/localbus/imcvar.h b/sys/arch/sgi/localbus/imcvar.h deleted file mode 100644 index 08b43a742ea..00000000000 --- a/sys/arch/sgi/localbus/imcvar.h +++ /dev/null @@ -1,73 +0,0 @@ -/* $OpenBSD: imcvar.h,v 1.3 2012/09/29 21:46:02 miod Exp $ */ -/* $NetBSD: imcvar.h,v 1.1 2006/08/30 23:44:52 rumble Exp $ */ - -/* - * Copyright (c) 2006 Stephen M. Rumble - * 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. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -struct imc_attach_args { - const char *iaa_name; - bus_space_tag_t iaa_st; - bus_dma_tag_t iaa_dmat; -}; - -void imc_bus_reset(void); -int imc_gio64_arb_config(int, uint32_t); -void imc_disable_sysad_parity(void); -void imc_enable_sysad_parity(void); -int imc_is_sysad_parity_enabled(void); - -#define imc_read(o) \ - *(volatile uint32_t *)PHYS_TO_XKPHYS(IMC_BASE + (o), CCA_NC) -#define imc_write(o,v) \ - *(volatile uint32_t *)PHYS_TO_XKPHYS(IMC_BASE + (o), CCA_NC) = (v) - -uint8_t imc_read_1(bus_space_tag_t, bus_space_handle_t, bus_size_t); -uint16_t imc_read_2(bus_space_tag_t, bus_space_handle_t, bus_size_t); -void imc_read_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void imc_write_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, uint8_t); -void imc_write_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, uint16_t); -void imc_write_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -uint32_t imc_read_4(bus_space_tag_t, bus_space_handle_t, bus_size_t); -uint64_t imc_read_8(bus_space_tag_t, bus_space_handle_t, bus_size_t); -void imc_write_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, uint32_t); -void imc_write_8(bus_space_tag_t, bus_space_handle_t, bus_size_t, uint64_t); -void imc_read_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void imc_write_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -void imc_read_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void imc_write_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -int imc_space_map(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -void imc_space_unmap(bus_space_tag_t, bus_space_handle_t, bus_size_t); -int imc_space_region(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, bus_space_handle_t *); -void *imc_space_vaddr(bus_space_tag_t, bus_space_handle_t); - -extern struct machine_bus_dma_tag imc_bus_dma_tag; -extern bus_space_t imcbus_tag; diff --git a/sys/arch/sgi/localbus/int.c b/sys/arch/sgi/localbus/int.c deleted file mode 100644 index 69c4653625d..00000000000 --- a/sys/arch/sgi/localbus/int.c +++ /dev/null @@ -1,539 +0,0 @@ -/* $OpenBSD: int.c,v 1.15 2018/02/24 11:42:31 visa Exp $ */ -/* $NetBSD: int.c,v 1.24 2011/07/01 18:53:46 dyoung Exp $ */ - -/* - * Copyright (c) 2009 Stephen M. Rumble - * Copyright (c) 2004 Christopher SEKIYA - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -/* - * INT2 (IP20, IP22) / INT3 (IP24) interrupt controllers - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/malloc.h> -#include <sys/proc.h> -#include <sys/atomic.h> - -#include <mips64/archtype.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/intr.h> - -#include <dev/ic/i8253reg.h> - -#include <sgi/localbus/intreg.h> -#include <sgi/localbus/intvar.h> -#include <sgi/sgi/ip22.h> - -int int2_match(struct device *, void *, void *); -void int2_attach(struct device *, struct device *, void *); -int int2_mappable_intr(void *); - -const struct cfattach int_ca = { - sizeof(struct device), int2_match, int2_attach -}; - -struct cfdriver int_cd = { - NULL, "int", DV_DULL -}; - -paddr_t int2_base; -paddr_t int2_get_base(void); - -#define int2_read(r) *(volatile uint8_t *)(int2_base + (r)) -#define int2_write(r, v) *(volatile uint8_t *)(int2_base + (r)) = (v) - -void int_8254_cal(void); -void int_8254_startclock(struct cpu_info *); -uint32_t int_8254_intr0(uint32_t, struct trapframe *); - -/* - * INT2 Interrupt handling declarations: 16 local sources on 2 levels. - * - * In addition to this, INT3 provides 8 so-called mappable interrupts, which - * are cascaded to either one of the unused two INT2 VME interrupts. - * To make things easier from a software viewpoint, we pretend there are - * 16 of them - one set of 8 per cascaded interrupt. This allows for - * faster recognition on where to connect these interrupts - as long as - * interrupt vector assignment makes sure no mappable interrupt is - * registered on both cascaded interrupts. - */ - -struct int2_intrhand { - struct intrhand ih; - uint32_t flags; -#define IH_FL_DISABLED 0x01 -}; - -#define INT2_NINTS (8 + 8 + 2 * 8) -struct int2_intrhand *int2_intrhand[INT2_NINTS]; - -uint32_t int2_intem; -uint8_t int2_l0imask[NIPLS], int2_l1imask[NIPLS]; - -void int2_splx(int); -uint32_t int2_l0intr(uint32_t, struct trapframe *); -void int2_l0makemasks(void); -uint32_t int2_l1intr(uint32_t, struct trapframe *); -void int2_l1makemasks(void); - -/* - * Level 0 interrupt handler. - */ - -uint32_t save_l0imr, save_l0isr, save_l0ipl; -#define INTR_FUNCTIONNAME int2_l0intr -#define MASK_FUNCTIONNAME int2_l0makemasks - -#define INTR_LOCAL_DECLS -#define MASK_LOCAL_DECLS -#define INTR_GETMASKS \ -do { \ - isr = int2_read(INT2_LOCAL0_STATUS); \ - imr = int2_read(INT2_LOCAL0_MASK); \ - bit = 7; \ -save_l0isr = isr; save_l0imr = imr; save_l0ipl = frame->ipl; \ -} while (0) -#define INTR_MASKPENDING \ - int2_write(INT2_LOCAL0_MASK, imr & ~isr) -#define INTR_IMASK(ipl) int2_l0imask[ipl] -#define INTR_HANDLER(bit) (struct intrhand *)int2_intrhand[bit + 0] -#define INTR_SPURIOUS(bit) \ -do { \ - printf("spurious int2 interrupt %d\n", bit); \ -} while (0) -/* explicit masking with int2_intem to cope with handlers disabling themselves */ -#define INTR_MASKRESTORE \ - int2_write(INT2_LOCAL0_MASK, int2_intem & imr) -#define INTR_MASKSIZE 8 - -#define INTR_HANDLER_SKIP(ih) \ - (((struct int2_intrhand *)(ih))->flags /* & IH_FL_DISABLED */) - -#include <sgi/sgi/intr_template.c> - -/* - * Level 1 interrupt handler. - */ - -uint32_t save_l1imr, save_l1isr, save_l1ipl; -#define INTR_FUNCTIONNAME int2_l1intr -#define MASK_FUNCTIONNAME int2_l1makemasks - -#define INTR_LOCAL_DECLS -#define MASK_LOCAL_DECLS -#define INTR_GETMASKS \ -do { \ - isr = int2_read(INT2_LOCAL1_STATUS); \ - imr = int2_read(INT2_LOCAL1_MASK); \ - bit = 7; \ -save_l1isr = isr; save_l1imr = imr; save_l1ipl = frame->ipl; \ -} while (0) -#define INTR_MASKPENDING \ - int2_write(INT2_LOCAL1_MASK, imr & ~isr) -#define INTR_IMASK(ipl) int2_l1imask[ipl] -#define INTR_HANDLER(bit) (struct intrhand *)int2_intrhand[bit + 8] -#define INTR_SPURIOUS(bit) \ -do { \ - printf("spurious int2 interrupt %d\n", bit + 8); \ -} while (0) -/* explicit masking with int2_intem to cope with handlers disabling themselves */ -#define INTR_MASKRESTORE \ - int2_write(INT2_LOCAL1_MASK, (int2_intem >> 8) & imr) -#define INTR_MASKSIZE 8 - -#define INTR_HANDLER_SKIP(ih) \ - (((struct int2_intrhand *)(ih))->flags /* & IH_FL_DISABLED */) - -#include <sgi/sgi/intr_template.c> - -void * -int2_intr_establish(int irq, int level, int (*ih_fun) (void *), - void *ih_arg, const char *ih_what) -{ - struct int2_intrhand **p, *q, *ih; - int s; - - level &= ~IPL_MPSAFE; - -#ifdef DIAGNOSTIC - if (irq < 0 || irq >= INT2_NINTS) - panic("int2_intr_establish: illegal irq %d", irq); - /* Mappable interrupts can't be above IPL_TTY */ - if ((irq >> 3) >= 2 && level > IPL_TTY) - return NULL; -#endif - - ih = malloc(sizeof *ih, M_DEVBUF, M_NOWAIT); - if (ih == NULL) - return NULL; - - ih->ih.ih_next = NULL; - ih->ih.ih_fun = ih_fun; - ih->ih.ih_arg = ih_arg; - ih->ih.ih_level = level; - ih->ih.ih_irq = irq; - ih->ih.ih_flags = 0; - if (ih_what != NULL) - evcount_attach(&ih->ih.ih_count, ih_what, &ih->ih.ih_irq); - ih->flags = 0; - - s = splhigh(); - - for (p = &int2_intrhand[irq]; (q = *p) != NULL; - p = (struct int2_intrhand **)&q->ih.ih_next) - continue; - *p = ih; - - int2_intem |= 1 << irq; - switch (irq >> 3) { - case 0: - int2_l0makemasks(); - break; - case 1: - int2_l1makemasks(); - break; - /* - * We do not maintain masks for mappable interrupts. They are - * masked as a whole, by the level 0 or 1 interrupt they cascade to. - */ - case 2: - int2_write(INT2_IP22_MAP_MASK0, - int2_read(INT2_IP22_MAP_MASK0) | (1 << (irq & 7))); - break; - case 3: - int2_write(INT2_IP22_MAP_MASK1, - int2_read(INT2_IP22_MAP_MASK1) | (1 << (irq & 7))); - break; - } - - splx(s); /* will cause hardware mask update */ - - return ih; -} - -void -int2_splx(int newipl) -{ - struct cpu_info *ci = curcpu(); - register_t sr; - - ci->ci_ipl = newipl; - - sr = disableintr(); /* XXX overkill? */ - int2_write(INT2_LOCAL1_MASK, (int2_intem >> 8) & ~int2_l1imask[newipl]); - int2_write(INT2_LOCAL0_MASK, int2_intem & ~int2_l0imask[newipl]); - setsr(sr); - - if (ci->ci_softpending != 0 && newipl < IPL_SOFTINT) - setsoftintr0(); -} - -/* - * Mappable interrupts handler. - */ - -int -int2_mappable_intr(void *arg) -{ - uint which = (unsigned long)arg; - vaddr_t imrreg; - uint64_t imr, isr; - uint i, intnum; - struct int2_intrhand *ih; - int rc, ret; - - imrreg = which == 0 ? INT2_IP22_MAP_MASK0 : INT2_IP22_MAP_MASK1; - isr = int2_read(INT2_IP22_MAP_STATUS); - imr = int2_read(imrreg); - - isr &= imr; - if (isr == 0) - return 0; /* not for us */ - - /* - * Don't bother masking sources here - all mappable interrupts are - * tied to either a level 1 or level 0 interrupt, and the dispatcher - * is registered at IPL_TTY, so we can safely assume we are running - * at IPL_TTY now. - */ - for (i = 0; i < 8; i++) { - intnum = i + 16 + (which << 3); - if (isr & (1 << i)) { - rc = 0; - for (ih = int2_intrhand[intnum]; ih != NULL; - ih = (struct int2_intrhand *)ih->ih.ih_next) { - if (ih->flags /* & IH_FL_DISABLED */) - continue; - ret = (*ih->ih.ih_fun)(ih->ih.ih_arg); - if (ret != 0) { - rc = 1; - atomic_inc_long((unsigned long *) - &ih->ih.ih_count.ec_count); - } - if (ret == 1) - break; - } - if (rc == 0) - printf("spurious int2 mapped interrupt %d\n", - i); - } - } - - return 1; -} - -int -int2_match(struct device *parent, void *match, void *aux) -{ - struct mainbus_attach_args *maa = (void *)aux; - - switch (sys_config.system_type) { - case SGI_IP20: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - break; - default: - return 0; - } - - return !strcmp(maa->maa_name, int_cd.cd_name); -} - -void -int2_attach(struct device *parent, struct device *self, void *aux) -{ - if (int2_base == 0) - int2_base = int2_get_base(); - - printf(" addr 0x%lx\n", XKPHYS_TO_PHYS(int2_base)); - - /* Clean out interrupt masks */ - int2_write(INT2_LOCAL0_MASK, 0); - int2_write(INT2_LOCAL1_MASK, 0); - int2_write(INT2_IP22_MAP_MASK0, 0); - int2_write(INT2_IP22_MAP_MASK1, 0); - - /* Reset timer interrupts */ - int2_write(INT2_TIMER_CONTROL, - TIMER_SEL0 | TIMER_16BIT | TIMER_SWSTROBE); - int2_write(INT2_TIMER_CONTROL, - TIMER_SEL1 | TIMER_16BIT | TIMER_SWSTROBE); - int2_write(INT2_TIMER_CONTROL, - TIMER_SEL2 | TIMER_16BIT | TIMER_SWSTROBE); - mips_sync(); - delay(4); - int2_write(INT2_TIMER_CLEAR, 0x03); - - set_intr(INTPRI_L1, CR_INT_1, int2_l1intr); - set_intr(INTPRI_L0, CR_INT_0, int2_l0intr); - register_splx_handler(int2_splx); - - if (sys_config.system_type != SGI_IP20) { - /* Wire mappable interrupt handlers */ - int2_intr_establish(INT2_L0_INTR(INT2_L0_IP22_MAP0), IPL_TTY, - int2_mappable_intr, NULL, NULL); - int2_intr_establish(INT2_L1_INTR(INT2_L1_IP22_MAP1), IPL_TTY, - int2_mappable_intr, (void *)1, NULL); - } - - /* - * The 8254 timer does not interrupt on (some?) IP24 systems. - */ - if (sys_config.system_type == SGI_IP20 || - sys_config.system_subtype == IP22_INDIGO2) - int_8254_cal(); -} - -paddr_t -int2_get_base(void) -{ - uint32_t address; - - switch (sys_config.system_type) { - case SGI_IP20: - address = INT2_IP20; - break; - default: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - if (sys_config.system_subtype == IP22_INDIGO2) - address = INT2_IP22; - else - address = INT2_IP24; - break; - } - - return PHYS_TO_XKPHYS((uint64_t)address, CCA_NC); -} - -/* - * Returns nonzero if the given interrupt source is pending. - */ -int -int2_is_intr_pending(int irq) -{ - paddr_t reg; - - if (int2_base == 0) - int2_base = int2_get_base(); - switch (irq >> 3) { - case 0: - reg = INT2_LOCAL0_STATUS; - break; - case 1: - reg = INT2_LOCAL1_STATUS; - break; - case 2: - case 3: - reg = INT2_IP22_MAP_STATUS; - break; - default: - return 0; - } - - return int2_read(reg) & (1 << (irq & 7)); -} - -/* - * Temporarily disable an interrupt handler. Note that disable/enable - * calls can not be stacked. - * - * The interrupt source will become masked if it is the only handler. - * (This is intended for panel(4) which is not supposed to be a shared - * interrupt) - */ -void -int2_intr_disable(void *v) -{ - struct int2_intrhand *ih = (struct int2_intrhand *)v; - int s; - - s = splhigh(); - if ((ih->flags & IH_FL_DISABLED) == 0) { - ih->flags |= IH_FL_DISABLED; - if (ih == int2_intrhand[ih->ih.ih_irq] && - ih->ih.ih_next == NULL) { - /* disable interrupt source */ - int2_intem &= ~(1 << ih->ih.ih_irq); - } - } - splx(s); -} - -/* - * Reenable an interrupt handler. - */ -void -int2_intr_enable(void *v) -{ - struct int2_intrhand *ih = (struct int2_intrhand *)v; - int s; - - s = splhigh(); - if ((ih->flags & IH_FL_DISABLED) != 0) { - ih->flags &= ~IH_FL_DISABLED; - if (ih == int2_intrhand[ih->ih.ih_irq] && - ih->ih.ih_next == NULL) { - /* reenable interrupt source */ - int2_intem |= 1 << ih->ih.ih_irq; - } - } - splx(s); -} - -/* - * A master clock is wired to TIMER_2, which in turn clocks the two other - * timers. The master frequency is 1MHz. - * - * TIMER_0 and TIMER_1 interrupt on HW_INT_2 and HW_INT_3, respectively. - * - * NB: Apparently int2 doesn't like counting down from one, but two works. - */ - -static struct evcount int_clock_count; -static int int_clock_irq = 2; - -void -int_8254_cal(void) -{ - uint freq = 1000000 / 2 / hz; - - /* Timer0 is our hz. */ - int2_write(INT2_TIMER_CONTROL, - TIMER_SEL0 | TIMER_RATEGEN | TIMER_16BIT); - int2_write(INT2_TIMER_0, freq & 0xff); - mips_sync(); - delay(4); - int2_write(INT2_TIMER_0, freq >> 8); - - /* Timer2 clocks timer0 and timer1. */ - int2_write(INT2_TIMER_CONTROL, - TIMER_SEL2 | TIMER_RATEGEN | TIMER_16BIT); - int2_write(INT2_TIMER_2, 2); - mips_sync(); - delay(4); - int2_write(INT2_TIMER_2, 0); - - set_intr(INTPRI_CLOCK, CR_INT_2, int_8254_intr0); - evcount_attach(&int_clock_count, "clock", &int_clock_irq); - md_startclock = int_8254_startclock; -} - -uint32_t -int_8254_intr0(uint32_t hwpend, struct trapframe *tf) -{ - struct cpu_info *ci = curcpu(); - - int2_write(INT2_TIMER_CLEAR, 0x01); - ci->ci_pendingticks++; - if (ci->ci_clock_started != 0) { - if (tf->ipl < IPL_CLOCK) { - while (ci->ci_pendingticks) { - int_clock_count.ec_count++; - hardclock(tf); - ci->ci_pendingticks--; - } - } - } - - return hwpend; -} - -void -int_8254_startclock(struct cpu_info *ci) -{ - ci->ci_clock_started++; -} diff --git a/sys/arch/sgi/localbus/intreg.h b/sys/arch/sgi/localbus/intreg.h deleted file mode 100644 index c06b4df8c02..00000000000 --- a/sys/arch/sgi/localbus/intreg.h +++ /dev/null @@ -1,98 +0,0 @@ -/* $OpenBSD: intreg.h,v 1.2 2012/04/15 20:44:52 miod Exp $ */ -/* $NetBSD: int2reg.h,v 1.5 2009/02/12 06:33:57 rumble Exp $ */ - -/* - * Copyright (c) 2004 Christopher SEKIYA - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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 INT has known locations on all SGI machines */ -#define INT2_IP20 0x1fb801c0 -#define INT2_IP22 0x1fbd9000 -#define INT2_IP24 0x1fbd9880 - -/* The following registers are all 8 bit. */ -#define INT2_LOCAL0_STATUS 0x03 -#define INT2_LOCAL0_STATUS_FIFO 0x01 -#define INT2_LOCAL0_MASK 0x07 -#define INT2_LOCAL1_STATUS 0x0b -#define INT2_LOCAL1_MASK 0x0f -#define INT2_IP22_MAP_STATUS 0x13 -#define INT2_IP22_MAP_MASK0 0x17 -#define INT2_IP22_MAP_MASK1 0x1b -#define INT2_IP22_MAP_POL 0x1f -#define INT2_IP20_LED 0x1f -#define INT2_TIMER_CLEAR 0x23 -#define INT2_ERROR_STATUS 0x27 -#define INT2_TIMER_0 0x33 -#define INT2_TIMER_1 0x37 -#define INT2_TIMER_2 0x3b -#define INT2_TIMER_CONTROL 0x3f - -/* LOCAL0 bits */ -#define INT2_L0_FIFO 0 -#define INT2_L0_GIO_SLOT0 0 /* IP24 */ -#define INT2_L0_GIO_LVL0 0 /* IP20/IP22 */ -#define INT2_L0_IP20_PARALLEL 1 -#define INT2_L0_IP22_SCSI0 1 -#define INT2_L0_SCSI1 2 -#define INT2_L0_ENET 3 -#define INT2_L0_GFX_DMA 4 -#define INT2_L0_IP20_SERIAL 5 -#define INT2_L0_IP22_PARALLEL 5 -#define INT2_L0_GIO_LVL1 6 /* IP20/IP22 */ -#define INT2_L0_IP20_VME0 7 -#define INT2_L0_IP22_MAP0 7 - -/* LOCAL1 bits */ -#define INT2_L1_IP24_ISDN_ISAC 0 -#define INT2_L1_IP20_GR1MODE 1 /* not an interrupt but a status bit */ -#define INT2_L1_IP22_PANEL 1 -#define INT2_L1_IP24_ISDN_HSCX 2 -#define INT2_L1_IP20_VME1 3 -#define INT2_L1_IP22_MAP1 3 -#define INT2_L1_IP20_DSP 4 -#define INT2_L1_IP22_HPC_DMA 4 -#define INT2_L1_ACFAIL 5 -#define INT2_L1_VIDEO 6 -#define INT2_L1_RETRACE 7 -#define INT2_L1_GIO_LVL2 7 /* IP20/IP22 */ - -/* MAP bits */ -#define INT2_MAP_NEWPORT 0 /* IP24 */ -#define INT2_MAP_PASSWD 1 -#define INT2_MAP_ISDN_POWER 2 /* IP24 */ -#define INT2_MAP_EISA 3 /* IP22 */ -#define INT2_MAP_PCKBC 4 -#define INT2_MAP_SERIAL 5 -#define INT2_MAP_GFX0_DRAIN 6 /* IP22 */ -#define INT2_MAP_GIO_SLOT0 6 /* IP24 */ -#define INT2_MAP_GFX1_DRAIN 7 /* IP22 */ -#define INT2_MAP_GIO_SLOT1 7 /* IP24 */ - -#define INT2_L0_INTR(x) ((x) + 0) -#define INT2_L1_INTR(x) ((x) + 8) -#define INT2_MAP0_INTR(x) ((x) + 16) -#define INT2_MAP1_INTR(x) ((x) + 24) diff --git a/sys/arch/sgi/localbus/intvar.h b/sys/arch/sgi/localbus/intvar.h deleted file mode 100644 index b9deb77d107..00000000000 --- a/sys/arch/sgi/localbus/intvar.h +++ /dev/null @@ -1,35 +0,0 @@ -/* $OpenBSD: intvar.h,v 1.3 2012/04/18 11:01:55 miod Exp $ */ -/* $NetBSD: int2var.h,v 1.3 2008/08/23 17:25:54 tsutsui Exp $ */ - -/* - * Copyright (c) 2004 Christopher SEKIYA - * 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. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - */ - -void *int2_intr_establish(int, int, int (*)(void *), - void *, const char *); -int int2_is_intr_pending(int); -void int2_intr_disable(void *); -void int2_intr_enable(void *); diff --git a/sys/arch/sgi/localbus/macebus.c b/sys/arch/sgi/localbus/macebus.c deleted file mode 100644 index fcc43a1892e..00000000000 --- a/sys/arch/sgi/localbus/macebus.c +++ /dev/null @@ -1,647 +0,0 @@ -/* $OpenBSD: macebus.c,v 1.70 2021/03/11 11:17:00 jsg Exp $ */ - -/* - * Copyright (c) 2000-2004 Opsycon AB (www.opsycon.se) - * - * 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 ``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 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. - * - */ - -/* - * This is a combined macebus/crimebus driver. It handles configuration of all - * devices on the processor bus. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/conf.h> -#include <sys/malloc.h> -#include <sys/device.h> -#include <sys/proc.h> -#include <sys/atomic.h> - -#include <mips64/archtype.h> -#include <mips64/mips_cpu.h> - -#include <machine/autoconf.h> -#include <machine/intr.h> - -#include <sgi/localbus/crimebus.h> -#include <sgi/localbus/macebus.h> -#include <sgi/localbus/macebusvar.h> - -int macebusmatch(struct device *, void *, void *); -void macebusattach(struct device *, struct device *, void *); -int macebusprint(void *, const char *); -int macebussubmatch(struct device *, void *, void *); - -void macebus_intr_makemasks(void); -void macebus_splx(int); -uint32_t macebus_iointr(uint32_t, struct trapframe *); -uint32_t macebus_aux(uint32_t, struct trapframe *); -int macebus_iointr_skip(struct intrhand *, uint64_t, uint64_t); -void crime_setintrmask(int); - -u_int8_t mace_read_1(bus_space_tag_t, bus_space_handle_t, bus_size_t); -u_int16_t mace_read_2(bus_space_tag_t, bus_space_handle_t, bus_size_t); -u_int32_t mace_read_4(bus_space_tag_t, bus_space_handle_t, bus_size_t); -u_int64_t mace_read_8(bus_space_tag_t, bus_space_handle_t, bus_size_t); - -void mace_write_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int8_t); -void mace_write_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int16_t); -void mace_write_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int32_t); -void mace_write_8(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int64_t); - -void mace_read_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - u_int8_t *, bus_size_t); -void mace_write_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const u_int8_t *, bus_size_t); -void mace_read_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - u_int8_t *, bus_size_t); -void mace_write_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const u_int8_t *, bus_size_t); -void mace_read_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - u_int8_t *, bus_size_t); -void mace_write_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const u_int8_t *, bus_size_t); - -int mace_space_map(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -void mace_space_unmap(bus_space_tag_t, bus_space_handle_t, bus_size_t); -int mace_space_region(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, bus_space_handle_t *); - -void *mace_space_vaddr(bus_space_tag_t, bus_space_handle_t); -void mace_space_barrier(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, int); - -bus_addr_t macebus_pa_to_device(paddr_t, int); - -struct cfattach macebus_ca = { - sizeof(struct device), macebusmatch, macebusattach -}; - -struct cfdriver macebus_cd = { - NULL, "macebus", DV_DULL -}; - -bus_space_t macebus_tag = { - PHYS_TO_XKPHYS(MACEBUS_BASE, CCA_NC), - NULL, - mace_read_1, mace_write_1, - mace_read_2, mace_write_2, - mace_read_4, mace_write_4, - mace_read_8, mace_write_8, - mace_read_raw_2, mace_write_raw_2, - mace_read_raw_4, mace_write_raw_4, - mace_read_raw_8, mace_write_raw_8, - mace_space_map, mace_space_unmap, mace_space_region, - mace_space_vaddr, mace_space_barrier -}; - -bus_space_t crimebus_tag = { - PHYS_TO_XKPHYS(CRIMEBUS_BASE, CCA_NC), - NULL, - mace_read_1, mace_write_1, - mace_read_2, mace_write_2, - mace_read_4, mace_write_4, - mace_read_8, mace_write_8, - mace_read_raw_2, mace_write_raw_2, - mace_read_raw_4, mace_write_raw_4, - mace_read_raw_8, mace_write_raw_8, - mace_space_map, mace_space_unmap, mace_space_region, - mace_space_vaddr, mace_space_barrier -}; - -bus_space_handle_t crime_h; -bus_space_handle_t mace_h; - -struct machine_bus_dma_tag mace_bus_dma_tag = { - NULL, /* _cookie */ - _dmamap_create, - _dmamap_destroy, - _dmamap_load, - _dmamap_load_mbuf, - _dmamap_load_uio, - _dmamap_load_raw, - _dmamap_load_buffer, - _dmamap_unload, - _dmamap_sync, - _dmamem_alloc, - _dmamem_free, - _dmamem_map, - _dmamem_unmap, - _dmamem_mmap, - macebus_pa_to_device, - CRIME_MEMORY_MASK -}; - -/* - * CRIME/MACE interrupt handling declarations: 32 CRIME sources, 16 MACE - * sources (multiplexed by CRIME); 1 level. - * We define another level for periodic tasks as well. - */ - -struct crime_intrhand { - struct intrhand ih; - uint32_t mace_irqmask; -}; -struct crime_intrhand *crime_intrhand[CRIME_NINTS]; - -#define INTPRI_MACEIO (INTPRI_CLOCK + 1) -#define INTPRI_MACEAUX (INTPRI_MACEIO + 1) - -uint64_t crime_intem, mace_intem; -uint64_t crime_imask[NIPLS]; - -/* - * List of macebus child devices. - */ - -#define MACEBUSDEV(name, addr, i, i2) \ - { name, &macebus_tag, &macebus_tag, &mace_bus_dma_tag, addr, i, i2 } -struct macebus_attach_args macebus_children[] = { - MACEBUSDEV("com", MACE_ISA_SER1_OFFS, 4, MACE_ISA_INT_SERIAL_1), - MACEBUSDEV("com", MACE_ISA_SER2_OFFS, 4, MACE_ISA_INT_SERIAL_2), - MACEBUSDEV("dsrtc", MACE_ISA_RTC_OFFS, -1, 0), -#if 0 - MACEBUSDEV("lpt", MACE_ISA_EPP_OFFS, 4, MACE_ISA_INT_PARALLEL), -#endif - MACEBUSDEV("macepcibr", MACE_PCI_OFFS, 7, 0), - MACEBUSDEV("mavb", MACE_IO_AUDIO_OFFS, 6, MACE_ISA_INT_AUDIO), - MACEBUSDEV("mec", MACE_ETHERNET_OFFS, 3, 0), - MACEBUSDEV("mkbc", MACE_IO_KBC_OFFS, 5, - MACE_ISA_INT_KBD | MACE_ISA_INT_KBD_POLL | - MACE_ISA_INT_MOUSE | MACE_ISA_INT_MOUSE_POLL), - MACEBUSDEV("power", 0, 5, MACE_ISA_INT_RTC) -}; -#undef MACEBUSDEV - -/* - * Match bus only to targets which have this bus. - */ -int -macebusmatch(struct device *parent, void *match, void *aux) -{ - if (sys_config.system_type == SGI_O2) - return (1); - return (0); -} - -int -macebusprint(void *aux, const char *macebus) -{ - struct macebus_attach_args *maa = aux; - - if (macebus != NULL) - printf("%s at %s", maa->maa_name, macebus); - - if (maa->maa_baseaddr != 0) - printf(" base 0x%08lx", maa->maa_baseaddr); - if (maa->maa_intr >= 0) - printf(" irq %d", maa->maa_intr); - - return (UNCONF); -} - -int -macebussubmatch(struct device *parent, void *vcf, void *args) -{ - struct cfdata *cf = vcf; - struct macebus_attach_args *maa = args; - - if (strcmp(cf->cf_driver->cd_name, maa->maa_name) != 0) - return 0; - - if (cf->cf_loc[0] != -1 && cf->cf_loc[0] != (int)maa->maa_baseaddr) - return 0; - - return (*cf->cf_attach->ca_match)(parent, cf, maa); -} - -void -macebusattach(struct device *parent, struct device *self, void *aux) -{ - u_int32_t creg; - uint i; - - /* - * Map and setup CRIME control registers. - */ - if (bus_space_map(&crimebus_tag, 0x00000000, 0x400, 0, &crime_h)) { - printf(": can't map CRIME control registers\n"); - return; - } - - creg = bus_space_read_8(&crimebus_tag, crime_h, CRIME_REVISION); - printf(": crime rev %d.%d\n", (creg & 0xf0) >> 4, creg & 0xf); - - bus_space_write_8(&crimebus_tag, crime_h, CRIME_CPU_ERROR_STAT, 0); - bus_space_write_8(&crimebus_tag, crime_h, CRIME_MEM_ERROR_STAT, 0); - - bus_space_write_8(&crimebus_tag, crime_h, CRIME_INT_MASK, 0); - bus_space_write_8(&crimebus_tag, crime_h, CRIME_INT_SOFT, 0); - bus_space_write_8(&crimebus_tag, crime_h, CRIME_INT_HARD, 0); - bus_space_write_8(&crimebus_tag, crime_h, CRIME_INT_STAT, 0); - - /* - * Map and setup MACE ISA control registers. - */ - if (bus_space_map(&macebus_tag, MACE_ISA_OFFS, 0x400, 0, &mace_h)) { - printf("%s: can't map MACE control registers\n", - self->dv_xname); - return; - } - - bus_space_write_8(&macebus_tag, mace_h, MACE_ISA_INT_MASK, 0); - bus_space_write_8(&macebus_tag, mace_h, MACE_ISA_INT_STAT, 0); - - /* - * On O2 systems all interrupts are handled by the macebus interrupt - * handler. Register all except clock. - */ - set_intr(INTPRI_MACEIO, CR_INT_0, macebus_iointr); - register_splx_handler(macebus_splx); - - /* Set up a handler called when clock interrupts go off. */ - set_intr(INTPRI_MACEAUX, CR_INT_5, macebus_aux); - - /* - * Attach subdevices. - */ - for (i = 0; i < nitems(macebus_children); i++) - config_found_sm(self, macebus_children + i, - macebusprint, macebussubmatch); -} - -/* - * Bus access primitives. These are really ugly... - */ - -u_int8_t -mace_read_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile u_int8_t *)(h + (o << 8) + 7); -} - -u_int16_t -mace_read_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - panic(__func__); -} - -u_int32_t -mace_read_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile u_int32_t *)(h + o); -} - -u_int64_t -mace_read_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile u_int64_t *)(h + o); -} - -void -mace_write_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, u_int8_t v) -{ - *(volatile u_int8_t *)(h + (o << 8) + 7) = v; -} - -void -mace_write_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, u_int16_t v) -{ - panic(__func__); -} - -void -mace_write_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, u_int32_t v) -{ - *(volatile u_int32_t *)(h + o) = v; -} - -void -mace_write_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, u_int64_t v) -{ - *(volatile u_int64_t *)(h + o) = v; -} - -void -mace_read_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - u_int8_t *buf, bus_size_t len) -{ - panic(__func__); -} - -void -mace_write_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const u_int8_t *buf, bus_size_t len) -{ - panic(__func__); -} - -void -mace_read_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - u_int8_t *buf, bus_size_t len) -{ - volatile u_int32_t *addr = (volatile u_int32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *(u_int32_t *)buf = *addr; - buf += 4; - } -} - -void -mace_write_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const u_int8_t *buf, bus_size_t len) -{ - volatile u_int32_t *addr = (volatile u_int32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *addr = *(u_int32_t *)buf; - buf += 4; - } -} - -void -mace_read_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - u_int8_t *buf, bus_size_t len) -{ - volatile u_int64_t *addr = (volatile u_int64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *(u_int64_t *)buf = *addr; - buf += 8; - } -} - -void -mace_write_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const u_int8_t *buf, bus_size_t len) -{ - volatile u_int64_t *addr = (volatile u_int64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *addr = *(u_int64_t *)buf; - buf += 8; - } -} - -int -mace_space_map(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ - if (ISSET(flags, BUS_SPACE_MAP_CACHEABLE)) - offs += - PHYS_TO_XKPHYS(0, CCA_CACHED) - PHYS_TO_XKPHYS(0, CCA_NC); - *bshp = t->bus_base + offs; - return 0; -} - -void -mace_space_unmap(bus_space_tag_t t, bus_space_handle_t bsh, bus_size_t size) -{ -} - -int -mace_space_region(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ - *nbshp = bsh + offset; - return (0); -} - -void * -mace_space_vaddr(bus_space_tag_t t, bus_space_handle_t h) -{ - return (void *)h; -} - -void -mace_space_barrier(bus_space_tag_t t, bus_space_handle_t h, bus_size_t offs, - bus_size_t len, int flags) -{ - mips_sync(); -} - -/* - * Macebus bus_dma helpers. - * Mace accesses memory contiguously at 0x40000000 onwards. - */ - -bus_addr_t -macebus_pa_to_device(paddr_t pa, int flags) -{ - return (pa | CRIME_MEMORY_OFFSET); -} - -/* - * Macebus interrupt handler driver. - */ - -/* - * Establish an interrupt handler called from the dispatcher. - * The interrupt function established should return zero if there was nothing - * to serve (no int) and non-zero when an interrupt was serviced. - */ -void * -macebus_intr_establish(int irq, uint32_t mace_irqmask, int level, - int (*ih_fun)(void *), void *ih_arg, const char *ih_what) -{ - struct crime_intrhand **p, *q, *ih; - int s; - - level &= ~IPL_MPSAFE; - -#ifdef DIAGNOSTIC - if (irq >= CRIME_NINTS || irq < 0) - panic("intr_establish: illegal irq %d", irq); -#endif - - ih = malloc(sizeof *ih, M_DEVBUF, M_NOWAIT); - if (ih == NULL) - return NULL; - - ih->ih.ih_next = NULL; - ih->ih.ih_fun = ih_fun; - ih->ih.ih_arg = ih_arg; - ih->ih.ih_level = level; - ih->ih.ih_irq = irq; - ih->ih.ih_flags = 0; - ih->mace_irqmask = mace_irqmask; - evcount_attach(&ih->ih.ih_count, ih_what, &ih->ih.ih_irq); - - s = splhigh(); - - /* - * Figure out where to put the handler. - * This is O(N^2), but we want to preserve the order, and N is - * generally small. - */ - for (p = &crime_intrhand[irq]; (q = *p) != NULL; - p = (struct crime_intrhand **)&q->ih.ih_next) - ; - *p = ih; - - crime_intem |= 1UL << irq; - macebus_intr_makemasks(); - - /* enable further MACE sources if necessary */ - if (mace_irqmask != 0) { - mace_intem |= mace_irqmask; - bus_space_write_8(&macebus_tag, mace_h, MACE_ISA_INT_MASK, - mace_intem); - } - - splx(s); /* causes hw mask update */ - - return (ih); -} - -void -macebus_intr_disestablish(void *ih) -{ - /* XXX */ - panic("%s not implemented", __func__); -} - -void -macebus_splx(int newipl) -{ - struct cpu_info *ci = curcpu(); - - /* Update masks to new ipl. Order highly important! */ - ci->ci_ipl = newipl; - crime_setintrmask(newipl); - /* If we still have softints pending trigger processing. */ - if (ci->ci_softpending != 0 && newipl < IPL_SOFTINT) - setsoftintr0(); -} - -/* - * Crime interrupt handler. - */ - -#define INTR_FUNCTIONNAME macebus_iointr -#define MASK_FUNCTIONNAME macebus_intr_makemasks - -#define INTR_LOCAL_DECLS \ - uint64_t mace_isr, mace_imr; -#define MASK_LOCAL_DECLS -#define INTR_GETMASKS \ -do { \ - isr = bus_space_read_8(&crimebus_tag, crime_h, CRIME_INT_STAT); \ - imr = bus_space_read_8(&crimebus_tag, crime_h, CRIME_INT_MASK); \ - if (((CRIME_INT_SUPER_IO | CRIME_INT_SUB_MISC | CRIME_INT_SUB_AUDIO) & \ - isr & imr) != 0) { \ - mace_isr = bus_space_read_8(&macebus_tag, mace_h, \ - MACE_ISA_INT_STAT); \ - mace_imr = bus_space_read_8(&macebus_tag, mace_h, \ - MACE_ISA_INT_MASK); \ - } else \ - mace_isr = mace_imr = 0; \ - bit = CRIME_NINTS - 1; \ -} while (0) -#define INTR_MASKPENDING \ - bus_space_write_8(&crimebus_tag, crime_h, CRIME_INT_MASK, imr & ~isr) -#define INTR_IMASK(ipl) crime_imask[ipl] -#define INTR_HANDLER(bit) (struct intrhand *)crime_intrhand[bit] -#define INTR_SPURIOUS(bit) \ -do { \ - if (((CRIME_INT_SUPER_IO | CRIME_INT_SUB_MISC | CRIME_INT_SUB_AUDIO) & \ - (1 << (bit))) != 0) { \ - if ((mace_isr & mace_imr) != 0) \ - printf("spurious crime interrupt %d" \ - " mace isr %p imr %p\n", \ - bit, (void *)mace_isr, (void *)mace_imr); \ - } else \ - printf("spurious crime interrupt %d\n", bit); \ -} while (0) -#define INTR_MASKRESTORE \ - bus_space_write_8(&crimebus_tag, crime_h, CRIME_INT_MASK, imr) -#define INTR_MASKSIZE CRIME_NINTS - -#define INTR_HANDLER_SKIP(ih) \ - macebus_iointr_skip((void *)ih, mace_isr, mace_imr) - -#include <sgi/sgi/intr_template.c> - -int -macebus_iointr_skip(struct intrhand *ih, uint64_t mace_isr, uint64_t mace_imr) -{ - struct crime_intrhand *mih = (struct crime_intrhand *)ih; - - /* do not skip pure CRIME interrupts */ - if (mih->mace_irqmask == 0) - return 0; - - /* - * Several CRIME interrupts (such as superio and miscellaneous) are - * shared by multiple devices, so narrow the selection with the - * MACE interrupt status. - */ - - if ((mace_isr & mace_imr & mih->mace_irqmask) != 0) - return 0; - - return 1; -} - -/* - * Macebus auxiliary functions run each clock interrupt. - */ -uint32_t -macebus_aux(uint32_t hwpend, struct trapframe *cf) -{ - u_int64_t mask; - - mask = bus_space_read_8(&macebus_tag, mace_h, MACE_ISA_MISC_REG); - mask |= MACE_ISA_MISC_RLED_OFF | MACE_ISA_MISC_GLED_OFF; - - /* GREEN - Idle */ - /* AMBER - System mode */ - /* RED - User mode */ - if (cf->sr & SR_KSU_USER) { - mask &= ~MACE_ISA_MISC_RLED_OFF; - } else if (curproc == NULL || - curproc == curcpu()->ci_schedstate.spc_idleproc) { - mask &= ~MACE_ISA_MISC_GLED_OFF; - } else { - mask &= ~(MACE_ISA_MISC_RLED_OFF | MACE_ISA_MISC_GLED_OFF); - } - bus_space_write_8(&macebus_tag, mace_h, MACE_ISA_MISC_REG, mask); - - return 0; /* Real clock int handler will claim the interrupt. */ -} - -void -crime_setintrmask(int level) -{ - *(volatile uint64_t *)(PHYS_TO_XKPHYS(CRIMEBUS_BASE, CCA_NC) + - CRIME_INT_MASK) = crime_intem & ~crime_imask[level]; -} diff --git a/sys/arch/sgi/localbus/macebus.h b/sys/arch/sgi/localbus/macebus.h deleted file mode 100644 index 78c35bfe4c2..00000000000 --- a/sys/arch/sgi/localbus/macebus.h +++ /dev/null @@ -1,121 +0,0 @@ -/* $OpenBSD: macebus.h,v 1.15 2009/10/26 18:00:06 miod Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.com). - * - * 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 ``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 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. - * - */ - -/* - * Physical address of MACEBUS. - */ -#define MACEBUS_BASE 0x1f000000 - -/* - * Offsets for various I/O sections on MACEBUS - */ -#define MACE_PCI_OFFS 0x00080000 -#define MACE_VIN1_OFFS 0x00100000 -#define MACE_VIN2_OFFS 0x00180000 -#define MACE_VOUT_OFFS 0x00200000 -#define MACE_ETHERNET_OFFS 0x00280000 -#define MACE_IO_OFFS 0x00300000 -#define MACE_IO_SIZE 0x00050000 -#define MACE_ISAX_OFFS 0x00380000 -#define MACE_ISAX_SIZE 0x00020000 - -/* - * PCI control registers (relative MACE_PCI_OFFS) - */ -#define MACE_PCI_ERROR_ADDRESS 0x0000 -#define MACE_PCI_ERROR_FLAGS 0x0004 -#define MACE_PCI_CONTROL 0x0008 -#define MACE_PCI_REVISION 0x000c -#define MACE_PCI_FLUSH 0x000c -#define MACE_PCI_CFGADDR 0x0cf8 -#define MACE_PCI_CFGDATA 0x0cfc - -#define MACE_PCI_INTCTRL 0x000000ff /* Interrupt control mask */ - -/* PCI_ERROR_FLAGS Bits */ -#define PERR_MASTER_ABORT 0x80000000 -#define PERR_TARGET_ABORT 0x40000000 -#define PERR_DATA_PARITY_ERR 0x20000000 -#define PERR_RETRY_ERR 0x10000000 -#define PERR_ILLEGAL_CMD 0x08000000 -#define PERR_SYSTEM_ERR 0x04000000 -#define PERR_INTERRUPT_TEST 0x02000000 -#define PERR_PARITY_ERR 0x01000000 -#define PERR_OVERRUN 0x00800000 -#define PERR_RSVD 0x00400000 -#define PERR_MEMORY_ADDR 0x00200000 -#define PERR_CONFIG_ADDR 0x00100000 -#define PERR_MASTER_ABORT_ADDR_VALID 0x00080000 -#define PERR_TARGET_ABORT_ADDR_VALID 0x00040000 -#define PERR_DATA_PARITY_ADDR_VALID 0x00020000 -#define PERR_RETRY_ADDR_VALID 0x00010000 - -/* - * MACE IO definitions. - */ -#define MACE_IO_AUDIO_OFFS (MACE_IO_OFFS+0x00000000) -#define MACE_IO_KBC_OFFS (MACE_IO_OFFS+0x00020000) - -/* - * MACE ISA definitions. - */ -#define MACE_ISA_OFFS (MACE_IO_OFFS+0x00010000) - -#define MACE_ISA_RING_BASE 0x0000 -#define MACE_ISA_RING_ALIGN 0x00010000 -#define MACE_ISA_MISC_REG 0x0008 /* Various status and controls */ -#define MACE_ISA_INT_STAT 0x0010 -#define MACE_ISA_INT_MASK 0x0018 - -/* MACE_ISA_MISC_REG definitions */ -#define MACE_ISA_MISC_RLED_OFF 0x0010 /* Turns off RED LED */ -#define MACE_ISA_MISC_GLED_OFF 0x0020 /* Turns off GREEN LED */ - -/* MACE_ISA_INT_* definitions */ -#define MACE_ISA_INT_AUDIO 0x000000ff /* Audio ints */ -#define MACE_ISA_INT_AUDIO_SC 0x02 -#define MACE_ISA_INT_AUDIO_DMA1 0x04 -#define MACE_ISA_INT_AUDIO_DMA2 0x10 -#define MACE_ISA_INT_AUDIO_DMA3 0x40 -#define MACE_ISA_INT_RTC 0x00000100 /* RTC */ -#define MACE_ISA_INT_KBD 0x00000200 /* Keyboard */ -#define MACE_ISA_INT_KBD_POLL 0x00000400 /* Keyboard polled */ -#define MACE_ISA_INT_MOUSE 0x00000800 /* Mouse */ -#define MACE_ISA_INT_MOUSE_POLL 0x00001000 /* Mouse polled */ -#define MACE_ISA_INT_TIMER 0x0000e000 /* Timer/counter compare */ -#define MACE_ISA_INT_PARALLEL 0x000f0000 /* Parallel port */ -#define MACE_ISA_INT_SERIAL_1 0x03f00000 /* Serial port 1 */ -#define MACE_ISA_INT_SERIAL_2 0xfc000000 /* Serial port 2 */ - -/* ISA Peripherals */ -#define MACE_ISA_EPP_OFFS (MACE_ISAX_OFFS+0x00000000) -#define MACE_ISA_ECP_OFFS (MACE_ISAX_OFFS+0x00008000) -#define MACE_ISA_SER1_OFFS (MACE_ISAX_OFFS+0x00010000) -#define MACE_ISA_SER2_OFFS (MACE_ISAX_OFFS+0x00018000) -#define MACE_ISA_RTC_OFFS (MACE_ISAX_OFFS+0x00020000) -#define MACE_ISA_GAME_OFFS (MACE_ISAX_OFFS+0x00030000) diff --git a/sys/arch/sgi/localbus/macebusvar.h b/sys/arch/sgi/localbus/macebusvar.h deleted file mode 100644 index 39b93d4dbee..00000000000 --- a/sys/arch/sgi/localbus/macebusvar.h +++ /dev/null @@ -1,52 +0,0 @@ -/* $OpenBSD: macebusvar.h,v 1.2 2018/12/03 13:46:30 visa Exp $ */ - -/* - * Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#ifndef _MACEBUSVAR_H_ -#define _MACEBUSVAR_H_ - -#include <machine/bus.h> - -extern bus_space_t macebus_tag; -extern struct machine_bus_dma_tag mace_bus_dma_tag; - -struct macebus_attach_args { - char *maa_name; - - bus_space_tag_t maa_iot; - bus_space_tag_t maa_memt; - bus_dma_tag_t maa_dmat; - bus_addr_t maa_baseaddr; - int maa_intr; /* crime intr bit */ - uint32_t maa_mace_intr; /* narrowing mace intr mask */ -}; - -void *macebus_intr_establish(int, uint32_t, int, int (*)(void *), - void *, const char *); -void macebus_intr_disestablish(void *); - -#endif /* _MACEBUSVAR_H_ */ diff --git a/sys/arch/sgi/localbus/tcc.c b/sys/arch/sgi/localbus/tcc.c deleted file mode 100644 index c8a85dfc5e5..00000000000 --- a/sys/arch/sgi/localbus/tcc.c +++ /dev/null @@ -1,337 +0,0 @@ -/* $OpenBSD: tcc.c,v 1.11 2021/03/11 11:17:00 jsg Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * POWER Indigo2 TBus Cache Controller (Stream Cache) support code. - */ - -#include <sys/param.h> -#include <sys/device.h> -#include <sys/systm.h> -#include <sys/kernel.h> - -#include <uvm/uvm_extern.h> - -#include <mips64/archtype.h> -#include <mips64/cache.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> - -#include <sgi/sgi/ip22.h> -#include <sgi/localbus/tccreg.h> -#include <sgi/localbus/tccvar.h> - -int tcc_match(struct device *, void *, void *); -void tcc_attach(struct device *, struct device *, void *); - -const struct cfattach tcc_ca = { - sizeof(struct device), tcc_match, tcc_attach -}; - -struct cfdriver tcc_cd = { - NULL, "tcc", DV_DULL -}; - -uint32_t tcc_bus_error(uint32_t, struct trapframe *); - -CACHE_PROTOS(tcc) - -int -tcc_match(struct device *parent, void *match, void *aux) -{ - struct mainbus_attach_args *maa = (void *)aux; - - switch (sys_config.system_type) { - case SGI_IP26: - return strcmp(maa->maa_name, tcc_cd.cd_name) == 0; - default: - return 0; - } -} - -void -tcc_attach(struct device *parent, struct device *self, void *aux) -{ - uint32_t ctrl, rev; - - ctrl = (uint32_t)tcc_read(TCC_GCACHE_CTRL); - rev = (ctrl & TCC_GCACHE_REV_MASK) >> TCC_GCACHE_REV_SHIFT; - printf(": streaming cache revision %d\n", rev); - - tcc_bus_reset(); - - /* Enable bus error and machine check interrupts. */ - set_intr(INTPRI_BUSERR_TCC, CR_INT_4, tcc_bus_error); - tcc_write(TCC_INTR, TCC_INTR_MCHECK_ENAB | TCC_INTR_BERR_ENAB); - - /* Enable all cache sets. */ - tcc_write(TCC_GCACHE_CTRL, (ctrl | TCC_GCACHE_SET_ALL) & - ~TCC_GCACHE_DISABLE_WB); - - /* Enable prefetching. */ - tcc_prefetch_enable(); -} - -void -tcc_bus_reset() -{ - tcc_write(TCC_INTR, (tcc_read(TCC_INTR) & TCC_INTR_ENABLE_MASK) | - TCC_INTR_MCHECK | TCC_INTR_BERR); - tcc_write(TCC_ERROR, TCC_ERROR_NESTED_MCHECK | TCC_ERROR_NESTED_BERR); -} - -uint32_t -tcc_bus_error(uint32_t hwpend, struct trapframe *tf) -{ - uint64_t intr, error, addr, errack; - unsigned int errtype; - - intr = tcc_read(TCC_INTR); - error = tcc_read(TCC_ERROR); - - errtype = (error & TCC_ERROR_TYPE_MASK) >> TCC_ERROR_TYPE_SHIFT; - - /* - * Execution of the `sync' instruction is not supported by the - * T-Bus and raises a machine check exception. - * Do not report anything on console in that case, so that - * userland does not suffer too much. - */ - if (errtype != TCC_ERROR_TYPE_TBUS || (intr & TCC_INTR_MCHECK) == 0) { - addr = tcc_read(TCC_BERR_ADDR); - - printf("tcc bus error: intr %llx error %llx (%u) addr %08llx\n", - intr, error, errtype, addr); - } - - /* Ack error condition */ - errack = 0; - if (intr & TCC_INTR_MCHECK) - errack |= TCC_ERROR_NESTED_MCHECK; - if (intr & TCC_INTR_BERR) - errack |= TCC_ERROR_NESTED_BERR; - tcc_write(TCC_INTR, (intr & TCC_INTR_ENABLE_MASK) | - (intr & (TCC_INTR_MCHECK | TCC_INTR_BERR))); - tcc_write(TCC_ERROR, errack); - - return hwpend; -} - -/* - * Cache maintenance routines - */ - -#define tcc_cache_hit(addr,op) \ -__asm__ volatile ("lw $0, %0(%1)" :: "i" (TCC_CACHEOP_HIT), \ - "r" (PHYS_TO_XKPHYS(TCC_CACHEOP_BASE | (addr) | (op), CCA_NC)) : "memory") -#define tcc_cache_index(s,i,op) \ -__asm__ volatile ("lw $0, %0(%1)" :: "i" (TCC_CACHEOP_INDEX | (op)), \ - "r" (PHYS_TO_XKPHYS(TCC_CACHEOP_BASE | ((s) << TCC_CACHEOP_SET_SHIFT) | \ - ((i) << TCC_CACHEOP_INDEX_SHIFT), CCA_NC)) : "memory") - -void tcc_virtual(struct cpu_info *, vaddr_t, vsize_t, uint64_t); - -void -tcc_ConfigCache(struct cpu_info *ci) -{ - struct cache_info l2; - - l2 = ci->ci_l2; - - tfp_ConfigCache(ci); - - if (l2.size != 0) { - ci->ci_l2 = l2; - - ci->ci_SyncCache = tcc_SyncCache; - ci->ci_SyncDCachePage = tcc_SyncDCachePage; - ci->ci_HitSyncDCachePage = tcc_SyncDCachePage; - ci->ci_HitSyncDCache = tcc_HitSyncDCache; - ci->ci_HitInvalidateDCache = tcc_HitInvalidateDCache; - ci->ci_IOSyncDCache = tcc_IOSyncDCache; - } -} - -void -tcc_SyncCache(struct cpu_info *ci) -{ - uint64_t idx; - - mips_sync(); - tcc_prefetch_invalidate(); - tfp_InvalidateICache(ci, 0, ci->ci_l1inst.size); - - /* - * The following relies upon the fact that the (line, set) - * fields are contiguous. Therefore by pretending there is - * a huge number of sets and only one line, we can span the - * whole cache. - */ - idx = (uint64_t)ci->ci_l2.size / TCC_CACHE_LINE; - while (idx != 0) { - idx--; - tcc_cache_index(idx, 0, - TCC_CACHEOP_WRITEBACK | TCC_CACHEOP_INVALIDATE); - } - tcc_prefetch_invalidate(); -} - -void -tcc_SyncDCachePage(struct cpu_info *ci, vaddr_t va, paddr_t pa) -{ - vaddr_t epa; - - mips_sync(); - tcc_prefetch_invalidate(); - epa = pa + PAGE_SIZE; - do { - tcc_cache_hit(pa, - TCC_CACHEOP_WRITEBACK | TCC_CACHEOP_INVALIDATE); - pa += TCC_CACHE_LINE; - } while (pa != epa); - tcc_prefetch_invalidate(); -} - -void -tcc_virtual(struct cpu_info *ci, vaddr_t va, vsize_t sz, uint64_t op) -{ - paddr_t pa; - - if (IS_XKPHYS(va)) { - pa = XKPHYS_TO_PHYS(va); - - while (sz != 0) { - tcc_cache_hit(pa, op); - pa += TCC_CACHE_LINE; - sz -= TCC_CACHE_LINE; - } - return; - } - - while (sz != 0) { - /* get the proper physical address */ - if (pmap_extract(pmap_kernel(), va, &pa) == 0) { -#ifdef DIAGNOSTIC - panic("%s: invalid va %p", __func__, (void *)va); -#else - /* should not happen */ -#endif - } - - while (sz != 0) { - tcc_cache_hit(pa, op); - pa += TCC_CACHE_LINE; - va += TCC_CACHE_LINE; - sz -= TCC_CACHE_LINE; - if (sz == 0) - return; - if ((va & PAGE_MASK) == 0) - break; /* need new pmap_extract() */ - } - } -} - -void -tcc_HitSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - - /* extend the range to integral cache lines */ - va = _va & ~(TCC_CACHE_LINE - 1); - sz = ((_va + _sz + TCC_CACHE_LINE - 1) & ~(TCC_CACHE_LINE - 1)) - va; - - mips_sync(); - tcc_prefetch_invalidate(); - tcc_virtual(ci, va, sz, TCC_CACHEOP_WRITEBACK | TCC_CACHEOP_INVALIDATE); - tcc_prefetch_invalidate(); -} - -void -tcc_HitInvalidateDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz) -{ - vaddr_t va; - vsize_t sz; - - /* extend the range to integral cache lines */ - va = _va & ~(TCC_CACHE_LINE - 1); - sz = ((_va + _sz + TCC_CACHE_LINE - 1) & ~(TCC_CACHE_LINE - 1)) - va; - - mips_sync(); - tcc_prefetch_invalidate(); - tcc_virtual(ci, va, sz, TCC_CACHEOP_INVALIDATE); - tcc_prefetch_invalidate(); -} - -void -tcc_IOSyncDCache(struct cpu_info *ci, vaddr_t _va, size_t _sz, int how) -{ - vaddr_t va; - vsize_t sz; - int partial_start, partial_end; - - /* extend the range to integral cache lines */ - va = _va & ~(TCC_CACHE_LINE - 1); - sz = ((_va + _sz + TCC_CACHE_LINE - 1) & ~(TCC_CACHE_LINE - 1)) - va; - - mips_sync(); - - switch (how) { - default: - case CACHE_SYNC_R: - /* writeback partial cachelines */ - if (((_va | _sz) & (TCC_CACHE_LINE - 1)) != 0) { - partial_start = va != _va; - partial_end = va + sz != _va + _sz; - } else { - partial_start = partial_end = 0; - } - tcc_prefetch_invalidate(); - if (partial_start) { - tcc_virtual(ci, va, TCC_CACHE_LINE, - TCC_CACHEOP_WRITEBACK | TCC_CACHEOP_INVALIDATE); - va += TCC_CACHE_LINE; - sz -= TCC_CACHE_LINE; - } - if (sz != 0 && partial_end) { - sz -= TCC_CACHE_LINE; - tcc_virtual(ci, va + sz, TCC_CACHE_LINE, - TCC_CACHEOP_WRITEBACK | TCC_CACHEOP_INVALIDATE); - } - if (sz != 0) - tcc_virtual(ci, va, sz, TCC_CACHEOP_INVALIDATE); - break; - - case CACHE_SYNC_X: - tcc_prefetch_invalidate(); - tcc_virtual(ci, va, sz, TCC_CACHEOP_WRITEBACK); - break; - - case CACHE_SYNC_W: - tcc_prefetch_invalidate(); - tcc_virtual(ci, va, sz, - TCC_CACHEOP_WRITEBACK | TCC_CACHEOP_INVALIDATE); - break; - } - tcc_prefetch_invalidate(); - - tfp_IOSyncDCache(ci, _va, _sz, how); -} diff --git a/sys/arch/sgi/localbus/tccreg.h b/sys/arch/sgi/localbus/tccreg.h deleted file mode 100644 index e58e83dcea8..00000000000 --- a/sys/arch/sgi/localbus/tccreg.h +++ /dev/null @@ -1,117 +0,0 @@ -/* $OpenBSD: tccreg.h,v 1.1 2012/09/29 21:46:02 miod Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * POWER Indigo2 TBus Cache Controller (Stream Cache) support code. - */ - -#define TCC_BASE 0x0000000018000000UL - -/* - * TCC Control Registers - */ - -#define TCC_FIFO_CTRL 0x0000000 - -#define TCC_GCACHE_CTRL 0x0000008 -#define TCC_GCACHE_SET_0 0x00000001 /* cache set enables */ -#define TCC_GCACHE_SET_1 0x00000002 -#define TCC_GCACHE_SET_2 0x00000004 -#define TCC_GCACHE_SET_3 0x00000008 -#define TCC_GCACHE_SET_ALL 0x0000000f -#define TCC_GCACHE_DISABLE_WB 0x00000020 /* prevents writebacks */ -#define TCC_GCACHE_REV_MASK 0x03c00000 -#define TCC_GCACHE_REV_SHIFT 18 - -#define TCC_INTR 0x0000010 -#define TCC_INTR_MASK_0 0x00000001 -#define TCC_INTR_MASK_1 0x00000002 -#define TCC_INTR_MASK_2 0x00000004 -#define TCC_INTR_MASK_3 0x00000008 -#define TCC_INTR_MASK_4 0x00000010 -#define TCC_INTR_MASK_5 0x00000020 -#define TCC_INTR_GFX_FIFO_HIWAT 0x00000040 -#define TCC_INTR_GFX_FIFO_LOWAT 0x00000080 -#define TCC_INTR_COUNTER 0x00000100 -#define TCC_INTR_BERR 0x00000200 -#define TCC_INTR_MCHECK 0x00000400 -#define TCC_INTR_PENDING_MASK 0x000007ff -#define TCC_INTR_GFX_FIFO_HIWAT_ENAB 0x00000800 -#define TCC_INTR_GFX_FIFO_LOWAT_ENAB 0x00001000 -#define TCC_INTR_COUNTER_ENAB 0x00002000 -#define TCC_INTR_BERR_ENAB 0x00004000 -#define TCC_INTR_MCHECK_ENAB 0x00008000 -#define TCC_INTR_ENABLE_MASK 0x0000f800 - -#define TCC_BERR_ADDR 0x0000018 - -#define TCC_ERROR 0x0000020 -#define TCC_ERROR_NESTED_BERR 0x00000001 -#define TCC_ERROR_NESTED_MCHECK 0x00000002 -#define TCC_ERROR_TYPE_MASK 0x0000001c -#define TCC_ERROR_TYPE_SHIFT 2 - -#define TCC_ERROR_TYPE_TDB_PAR 0 -#define TCC_ERROR_TYPE_TCC_PAR 1 -#define TCC_ERROR_TYPE_CMD_PAR 2 -#define TCC_ERROR_TYPE_SYSAD 3 -#define TCC_ERROR_TYPE_GCACHE_PAR 4 -#define TCC_ERROR_TYPE_TBUS 5 - -#define TCC_PARITY_CTRL 0x0000028 - -#define TCC_COUNT 0x0000030 - -#define TCC_COMPARE 0x0000038 - -#define TCC_PREFETCH_CTRL 0x0010038 - -#define TCC_PREFETCH_INVALIDATE 0x0000000000000001 /* one-shot */ -#define TCC_PREFETCH_TIMEOUT_MASK 0x000000000000001e -#define TCC_PREFETCH_TIMEOUT_MAX 15 -#define TCC_PREFETCH_TIMEOUT_SHIFT 1 -#define TCC_PREFETCH_BUF_A_ENABLE 0x0000000000000020 -#define TCC_PREFETCH_BUF_B_ENABLE 0x0000000000000040 -#define TCC_PREFETCH_QUEUE_DEPTH_MASK 0x0000000000000380 -#define TCC_PREFETCH_QUEUE_DEPTH_MAX 7 -#define TCC_PREFETCH_QUEUE_DEPTH_SHIFT 7 - -/* - * The following default prefetch settings has been borrowed from IRIX's - * <sys/IP26.h>. We can only assume these settings are optimal for most - * workloads. - */ -#define TCC_PREFETCH_ENABLE \ - (TCC_PREFETCH_BUF_A_ENABLE | TCC_PREFETCH_BUF_B_ENABLE | \ - (3 << TCC_PREFETCH_TIMEOUT_SHIFT) | \ - (TCC_PREFETCH_QUEUE_DEPTH_MAX << TCC_PREFETCH_QUEUE_DEPTH_SHIFT)) - -/* - * TCC Cache Operations - */ - -#define TCC_CACHEOP_BASE 0x0000000100000000UL - -#define TCC_CACHEOP_HIT 0x00000000 -#define TCC_CACHEOP_INDEX 0x00000004 -#define TCC_CACHEOP_WRITEBACK 0x00000008 -#define TCC_CACHEOP_INVALIDATE 0x00000010 -#define TCC_CACHEOP_SET_SHIFT 5 -#define TCC_CACHEOP_INDEX_SHIFT 7 -#define TCC_CACHE_SETS 4 -#define TCC_CACHE_LINE 128UL diff --git a/sys/arch/sgi/localbus/tccvar.h b/sys/arch/sgi/localbus/tccvar.h deleted file mode 100644 index 40a98880dd0..00000000000 --- a/sys/arch/sgi/localbus/tccvar.h +++ /dev/null @@ -1,43 +0,0 @@ -/* $OpenBSD: tccvar.h,v 1.1 2012/09/29 21:46:02 miod Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#define tcc_read(o) \ - *(volatile uint64_t *)PHYS_TO_XKPHYS(TCC_BASE + (o), CCA_NC) -#define tcc_write(o,v) \ - *(volatile uint64_t *)PHYS_TO_XKPHYS(TCC_BASE + (o), CCA_NC) = (v) - -static __inline__ void -tcc_prefetch_disable(void) -{ - tcc_write(TCC_PREFETCH_CTRL, TCC_PREFETCH_INVALIDATE); -} - -static __inline__ void -tcc_prefetch_enable(void) -{ - tcc_write(TCC_PREFETCH_CTRL, TCC_PREFETCH_ENABLE); -} - -static __inline__ void -tcc_prefetch_invalidate(void) -{ - tcc_write(TCC_PREFETCH_CTRL, - tcc_read(TCC_PREFETCH_CTRL) | TCC_PREFETCH_INVALIDATE); -} - -void tcc_bus_reset(void); diff --git a/sys/arch/sgi/pci/ioc.c b/sys/arch/sgi/pci/ioc.c deleted file mode 100644 index a78c9e5f998..00000000000 --- a/sys/arch/sgi/pci/ioc.c +++ /dev/null @@ -1,834 +0,0 @@ -/* $OpenBSD: ioc.c,v 1.40 2016/01/02 05:49:35 visa Exp $ */ - -/* - * Copyright (c) 2008 Joel Sing. - * Copyright (c) 2008, 2009, 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * IOC3 device driver. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <mips64/archtype.h> -#include <machine/autoconf.h> -#include <machine/bus.h> - -#ifdef TGT_ORIGIN -#include <sgi/sgi/ip27.h> -#include <sgi/sgi/l1.h> -#endif - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcivar.h> -#include <dev/pci/pcidevs.h> - -#include <sgi/pci/iocreg.h> -#include <sgi/pci/iocvar.h> - -#include <dev/onewire/onewirereg.h> -#include <dev/onewire/onewirevar.h> - -#include <sgi/dev/owmacvar.h> -#include <sgi/dev/owserialvar.h> - -int ioc_match(struct device *, void *, void *); -void ioc_attach(struct device *, struct device *, void *); - -struct ioc_intr { - struct ioc_softc *ii_ioc; - - int (*ii_func)(void *); - void *ii_arg; - - struct evcount ii_count; - int ii_level; -}; - -struct ioc_softc { - struct device sc_dev; - - bus_space_tag_t sc_memt; - bus_space_handle_t sc_memh; - bus_dma_tag_t sc_dmat; - pci_chipset_tag_t sc_pc; - pcitag_t sc_tag; - - void *sc_ih_enet; /* Ethernet interrupt */ - void *sc_ih_superio; /* SuperIO interrupt */ - struct ioc_intr *sc_intr[IOC_NDEVS]; - - struct onewire_bus sc_bus; - - struct owmac_softc *sc_owmac; - struct owserial_softc *sc_owserial; - - int sc_attach_flags; -}; - -struct cfattach ioc_ca = { - sizeof(struct ioc_softc), ioc_match, ioc_attach, -}; - -struct cfdriver ioc_cd = { - NULL, "ioc", DV_DULL, -}; - -void ioc_attach_child(struct ioc_softc *, const char *, bus_addr_t, int); -int ioc_search_onewire(struct device *, void *, void *); -int ioc_search_mundane(struct device *, void *, void *); -int ioc_print(void *, const char *); - -int ioc_intr_dispatch(struct ioc_softc *, int); -int ioc_intr_ethernet(void *); -int ioc_intr_shared(void *); -int ioc_intr_superio(void *); - -int iocow_reset(void *); -int iocow_read_bit(struct ioc_softc *); -int iocow_send_bit(void *, int); -int iocow_read_byte(void *); -int iocow_triplet(void *, int); -int iocow_pulse(struct ioc_softc *, int, int); - -#ifdef TGT_ORIGIN -/* - * A mask of nodes on which an ioc driver has attached. - * We use this on IP35 systems, to prevent attaching a pci IOC3 card which NIC - * has failed, as the onboard IOC3. - * XXX This obviously will not work in N mode... but then IP35 are supposed to - * XXX always run in M mode. - */ -static uint64_t ioc_nodemask = 0; -#endif - -int -ioc_match(struct device *parent, void *match, void *aux) -{ - struct pci_attach_args *pa = aux; - - if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_SGI && - PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_SGI_IOC3) - return (1); - - return (0); -} - -int -ioc_print(void *aux, const char *iocname) -{ - struct ioc_attach_args *iaa = aux; - - if (iocname != NULL) - printf("%s at %s", iaa->iaa_name, iocname); - - /* no base for onewire, and don't display it for rtc */ - if ((int)iaa->iaa_base > 0 && (int)iaa->iaa_base < IOC3_BYTEBUS_0) - printf(" base 0x%lx", iaa->iaa_base); - - return (UNCONF); -} - -void -ioc_attach(struct device *parent, struct device *self, void *aux) -{ - struct ioc_softc *sc = (struct ioc_softc *)self; - struct pci_attach_args *pa = aux; - pci_intr_handle_t ih_enet, ih_superio; - bus_space_tag_t memt; - bus_space_handle_t memh; - bus_size_t memsize; - pcireg_t data; - int has_superio, has_enet, is_obio; - int subdevice_mask; - bus_addr_t rtcbase; - - if (pci_mapreg_map(pa, PCI_MAPREG_START, PCI_MAPREG_TYPE_MEM, 0, - &memt, &memh, NULL, &memsize, 0)) { - printf(": can't map mem space\n"); - return; - } - - sc->sc_pc = pa->pa_pc; - sc->sc_tag = pa->pa_tag; - sc->sc_dmat = pa->pa_dmat; - - /* - * Initialise IOC3 ASIC. - */ - data = pci_conf_read(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG); - data |= PCI_COMMAND_MEM_ENABLE | PCI_COMMAND_PARITY_ENABLE | - PCI_COMMAND_SERR_ENABLE; - data &= ~PCI_COMMAND_INTERRUPT_DISABLE; - pci_conf_write(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG, data); - - printf("\n"); - - sc->sc_memt = memt; - sc->sc_memh = memh; - - /* - * Attach the 1-Wire bus now, so that we can get our own part - * number and deduce which devices are really available on the - * board. - */ - - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_GPCR_S, - IOC3_GPCR_MLAN); - (void)bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC3_GPCR_S); - config_search(ioc_search_onewire, self, aux); - - /* - * Now figure out what our configuration is. - */ - - has_superio = has_enet = 0; - is_obio = 0; - subdevice_mask = 0; - if (sc->sc_owserial != NULL) { - if (strncmp(sc->sc_owserial->sc_product, "030-0873-", 9) == 0) { - /* - * MENET board; these attach as four ioc devices - * behind an xbridge. However the fourth one lacks - * the superio chip. - */ - subdevice_mask = (1 << IOCDEV_EF); - has_enet = 1; - if (pa->pa_device != 3) { - subdevice_mask |= (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B); - has_superio = 1; - } - } else - if (strncmp(sc->sc_owserial->sc_product, "030-0891-", 9) == 0) { - /* IP30 on-board IOC3 */ - subdevice_mask = (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B) | (1 << IOCDEV_LPT) | - (1 << IOCDEV_KBC) | (1 << IOCDEV_RTC) | - (1 << IOCDEV_EF); - rtcbase = IOC3_BYTEBUS_1; - has_superio = has_enet = 1; - is_obio = 1; - } else - if (strncmp(sc->sc_owserial->sc_product, "030-1155-", 9) == 0) { - /* CADDuo board */ - subdevice_mask = (1 << IOCDEV_KBC) | (1 << IOCDEV_EF); - has_superio = has_enet = 1; - } else - if (strncmp(sc->sc_owserial->sc_product, "030-1657-", 9) == 0 || - strncmp(sc->sc_owserial->sc_product, "030-1664-", 9) == 0) { - /* PCI_SIO_UFC dual serial board */ - subdevice_mask = (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B); - has_superio = 1; - } else - goto unknown; - } else { -#ifdef TGT_ORIGIN - /* - * If no owserial device has been found, then it is - * very likely that we are the on-board IOC3 found - * on IP27 and IP35 systems, unless we have already - * found an on-board IOC3 on this node. - * - * Origin 2000 (real IP27) systems are a real annoyance, - * because they actually have two IOC3 on their BASEIO - * board, with the various devices split accross them - * (two IOC3 chips are needed to provide the four serial - * ports). We can rely upon the PCI device numbers (2 and 6) - * to tell onboard IOC3 from PCI IOC3 devices. - */ - switch (sys_config.system_type) { - case SGI_IP27: - switch (sys_config.system_subtype) { - case IP27_O2K: - if (pci_get_widget(sc->sc_pc) == - IP27_O2K_BRIDGE_WIDGET) - switch (pa->pa_device) { - case IP27_IOC_SLOTNO: - subdevice_mask = - (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B) | - (1 << IOCDEV_RTC) | - (1 << IOCDEV_EF); - break; - case IP27_IOC2_SLOTNO: - subdevice_mask = - (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B) | - (1 << IOCDEV_LPT) | -#if 0 /* not worth doing */ - (1 << IOCDEV_RTC) | -#endif - (1 << IOCDEV_KBC); - break; - default: - break; - } - break; - case IP27_O200: - if (pci_get_widget(sc->sc_pc) == - IP27_O200_BRIDGE_WIDGET) - switch (pa->pa_device) { - case IP27_IOC_SLOTNO: - subdevice_mask = - (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B) | - (1 << IOCDEV_LPT) | - (1 << IOCDEV_KBC) | - (1 << IOCDEV_RTC) | - (1 << IOCDEV_EF); - break; - default: - break; - } - break; - default: - break; - } - break; - case SGI_IP35: - if (!ISSET(ioc_nodemask, 1UL << currentnasid)) { - SET(ioc_nodemask, 1UL << currentnasid); - - switch (sys_config.system_subtype) { - /* - * Origin 300 onboard IOC3 do not have PS/2 - * ports; since they can only be connected to - * other 300 or 350 bricks (the latter using - * IOC4 devices), it is safe to do this - * regardless of the current nasid. - * XXX What about Onyx 300 though??? - */ - case IP35_O300: - subdevice_mask = - (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B) | - (1 << IOCDEV_LPT) | - (1 << IOCDEV_RTC) | - (1 << IOCDEV_EF); - break; - /* - * Origin 3000 I-Bricks have only one serial - * port, and no keyboard or parallel ports. - */ - case IP35_CBRICK: - subdevice_mask = - (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_RTC) | - (1 << IOCDEV_EF); - break; - default: - subdevice_mask = - (1 << IOCDEV_SERIAL_A) | - (1 << IOCDEV_SERIAL_B) | - (1 << IOCDEV_LPT) | - (1 << IOCDEV_KBC) | - (1 << IOCDEV_RTC) | - (1 << IOCDEV_EF); - break; - } - } - break; - default: - break; - } - - if (subdevice_mask != 0) { - rtcbase = IOC3_BYTEBUS_0; - has_superio = 1; - if (ISSET(subdevice_mask, 1 << IOCDEV_EF)) - has_enet = 1; - is_obio = 1; - } else -#endif /* TGT_ORIGIN */ - { -unknown: - /* - * Well, we don't really know what kind of device - * we are. We should probe various registers - * to figure out, but for now we'll just - * chicken out. - */ - printf("%s: unknown flavour\n", self->dv_xname); - return; - } - } - - /* - * Acknowledge all pending interrupts, and disable them. - * Be careful not all registers may be wired depending on what - * devices are actually present. - */ - - if (has_superio) { - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IEC, ~0x0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IES, 0x0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IR, - bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IR)); - } - if (has_enet) { - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_ENET_IER, 0); - } - - /* - * IOC3 is not a real PCI device - it's a poor wrapper over a set - * of convenience chips. And when it is in full-blown configuration, - * it actually needs to use two interrupts, one for the superio - * chip, and the other for the Ethernet chip. - * - * This would not be a problem if the device advertized itself - * as a multifunction device. But it doesn't... - * - * Fortunately, the interrupt used are simply interrupt pins A - * and B; so with the help of the PCI bridge driver, we can - * register the two interrupts and almost pretend things are - * as normal as they could be. - */ - - if (has_enet) { - pa->pa_intrpin = PCI_INTERRUPT_PIN_A; - if (pci_intr_map(pa, &ih_enet) != 0) { - printf("%s: failed to map ethernet interrupt\n", - self->dv_xname); - goto unmap; - } - } - - if (has_superio) { - if (has_enet) - pa->pa_intrpin = - is_obio ? PCI_INTERRUPT_PIN_D : PCI_INTERRUPT_PIN_B; - else - pa->pa_intrpin = PCI_INTERRUPT_PIN_A; - - if (pci_intr_map(pa, &ih_superio) != 0) { - printf("%s: failed to map superio interrupt\n", - self->dv_xname); - goto unmap; - } - } - - if (has_enet) { - sc->sc_ih_enet = pci_intr_establish(sc->sc_pc, ih_enet, - IPL_NET, ioc_intr_ethernet, sc, self->dv_xname); - if (sc->sc_ih_enet == NULL) { - printf("%s: failed to establish ethernet interrupt " - "at %s\n", self->dv_xname, - pci_intr_string(sc->sc_pc, ih_enet)); - goto unmap; - } - } - - if (has_superio) { - sc->sc_ih_superio = pci_intr_establish(sc->sc_pc, ih_superio, - IPL_TTY, ioc_intr_superio, sc, self->dv_xname); - if (sc->sc_ih_superio == NULL) { - printf("%s: failed to establish superio interrupt " - "at %s\n", self->dv_xname, - pci_intr_string(sc->sc_pc, ih_superio)); - goto unregister; - } - } - - if (has_enet) - printf("%s: ethernet %s\n", - self->dv_xname, pci_intr_string(sc->sc_pc, ih_enet)); - if (has_superio) - printf("%s: superio %s\n", - self->dv_xname, pci_intr_string(sc->sc_pc, ih_superio)); - - /* - * Attach other sub-devices. - */ - - sc->sc_attach_flags = is_obio ? IOC_FLAGS_OBIO : 0; - - if (ISSET(subdevice_mask, 1 << IOCDEV_SERIAL_A)) { - /* - * Put serial ports in passthrough mode, - * to use the MI com(4) 16550 support. - */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_UARTA_SSCR, 0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_UARTB_SSCR, 0); - - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC3_UARTA_SHADOW, 0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC3_UARTB_SHADOW, 0); - - ioc_attach_child(sc, "com", IOC3_UARTA_BASE, IOCDEV_SERIAL_A); - if (ISSET(subdevice_mask, 1 << IOCDEV_SERIAL_B)) - ioc_attach_child(sc, "com", IOC3_UARTB_BASE, - IOCDEV_SERIAL_B); - } - if (ISSET(subdevice_mask, 1 << IOCDEV_KBC)) - ioc_attach_child(sc, "iockbc", 0, IOCDEV_KBC); - if (ISSET(subdevice_mask, 1 << IOCDEV_EF)) { - /* - * Make sure the PHY is correctly reset before attaching - * the interface. - */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC3_GPPR(5), 0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC3_GPCR_S, IOC3_GPCR_PHY_RESET); - delay(10); - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC3_GPPR(5), 1); - - ioc_attach_child(sc, "iec", 0, IOCDEV_EF); - } - if (ISSET(subdevice_mask, 1 << IOCDEV_LPT)) - ioc_attach_child(sc, "lpt", 0, IOCDEV_LPT); - if (ISSET(subdevice_mask, 1 << IOCDEV_RTC)) - ioc_attach_child(sc, "dsrtc", rtcbase, IOCDEV_RTC); - - return; - -unregister: - if (has_enet) - pci_intr_disestablish(sc->sc_pc, sc->sc_ih_enet); -unmap: - bus_space_unmap(memt, memh, memsize); -} - -void -ioc_attach_child(struct ioc_softc *sc, const char *name, bus_addr_t base, - int dev) -{ - struct ioc_attach_args iaa; - - memset(&iaa, 0, sizeof iaa); - - iaa.iaa_name = name; - pci_get_device_location(sc->sc_pc, sc->sc_tag, &iaa.iaa_location); - iaa.iaa_memt = sc->sc_memt; - iaa.iaa_memh = sc->sc_memh; - iaa.iaa_dmat = sc->sc_dmat; - iaa.iaa_base = base; - iaa.iaa_dev = dev; - iaa.iaa_flags = sc->sc_attach_flags; - - if (dev == IOCDEV_EF) { - if (sc->sc_owmac != NULL) - memcpy(iaa.iaa_enaddr, sc->sc_owmac->sc_enaddr, 6); - else { -#ifdef TGT_ORIGIN - /* - * On IP35 class machines, there are no - * Number-In-a-Can attached to the onboard - * IOC3; instead, the Ethernet address is - * stored in the Brick EEPROM, and can be - * retrieved with an L1 controller query. - */ - if (sys_config.system_type != SGI_IP35 || - l1_get_brick_ethernet_address(currentnasid, - iaa.iaa_enaddr) != 0) -#endif - memset(iaa.iaa_enaddr, 0xff, 6); - } - } - - config_found_sm(&sc->sc_dev, &iaa, ioc_print, ioc_search_mundane); -} - -int -ioc_search_mundane(struct device *parent, void *vcf, void *args) -{ - struct cfdata *cf = vcf; - struct ioc_attach_args *iaa = (struct ioc_attach_args *)args; - - if (strcmp(cf->cf_driver->cd_name, iaa->iaa_name) != 0) - return 0; - - if (cf->cf_loc[0] != -1 && cf->cf_loc[0] != (int)iaa->iaa_base) - return 0; - - return (*cf->cf_attach->ca_match)(parent, cf, iaa); -} - -/* - * Number-In-a-Can access driver (1-Wire interface through IOC) - */ - -int -ioc_search_onewire(struct device *parent, void *vcf, void *args) -{ - struct ioc_softc *sc = (struct ioc_softc *)parent; - struct cfdata *cf = vcf; - struct onewirebus_attach_args oba; - struct device *owdev, *dev; - extern struct cfdriver owmac_cd; - extern struct cfdriver owserial_cd; - struct owserial_softc *s; - - if (strcmp(cf->cf_driver->cd_name, "onewire") != 0) - return 0; - - sc->sc_bus.bus_cookie = sc; - sc->sc_bus.bus_reset = iocow_reset; - sc->sc_bus.bus_bit = iocow_send_bit; - sc->sc_bus.bus_read_byte = iocow_read_byte; - sc->sc_bus.bus_write_byte = NULL; /* use default routine */ - sc->sc_bus.bus_read_block = NULL; /* use default routine */ - sc->sc_bus.bus_write_block = NULL; /* use default routine */ - sc->sc_bus.bus_triplet = iocow_triplet; - sc->sc_bus.bus_matchrom = NULL; /* use default routine */ - sc->sc_bus.bus_search = NULL; /* use default routine */ - - oba.oba_bus = &sc->sc_bus; - oba.oba_flags = ONEWIRE_SCAN_NOW | ONEWIRE_NO_PERIODIC_SCAN; - - /* In case onewire is disabled in UKC... */ - if ((*cf->cf_attach->ca_match)(parent, cf, &oba) == 0) - return 0; - - owdev = config_attach(parent, cf, &oba, onewirebus_print); - - /* - * Find the first owmac child of the onewire bus, and keep - * a pointer to it. This allows us to pass the ethernet - * address to the ethernet subdevice. - */ - if (owdev != NULL) { - TAILQ_FOREACH(dev, &alldevs, dv_list) - if (dev->dv_parent == owdev && - dev->dv_cfdata->cf_driver == &owmac_cd) { - sc->sc_owmac = (struct owmac_softc *)dev; - break; - } - } - - /* - * Find the first owserial child of the onewire bus not - * reporting power supply information, and keep a pointer - * to it. This is a bit overkill since we do not need to - * keep the pointer after attach, but it makes that kind - * of code contained in the same place. - */ - if (owdev != NULL) { - TAILQ_FOREACH(dev, &alldevs, dv_list) - if (dev->dv_parent == owdev && - dev->dv_cfdata->cf_driver == &owserial_cd) { - s = (struct owserial_softc *)dev; - if (strncmp(s->sc_name, "PWR", 3) == 0) - continue; - sc->sc_owserial = s; - break; - } - } - - - return 1; -} - -int -iocow_reset(void *v) -{ - struct ioc_softc *sc = v; - return iocow_pulse(sc, 500, 65); -} - -int -iocow_read_bit(struct ioc_softc *sc) -{ - return iocow_pulse(sc, 6, 13); -} - -int -iocow_send_bit(void *v, int bit) -{ - struct ioc_softc *sc = v; - int rc; - - if (bit != 0) - rc = iocow_pulse(sc, 6, 110); - else - rc = iocow_pulse(sc, 80, 30); - return rc; -} - -int -iocow_read_byte(void *v) -{ - struct ioc_softc *sc = v; - unsigned int byte = 0; - int i; - - for (i = 0; i < 8; i++) - byte |= iocow_read_bit(sc) << i; - - return byte; -} - -int -iocow_triplet(void *v, int dir) -{ - struct ioc_softc *sc = v; - int rc; - - rc = iocow_read_bit(sc); - rc <<= 1; - rc |= iocow_read_bit(sc); - - switch (rc) { - case 0x0: - iocow_send_bit(v, dir); - break; - case 0x1: - iocow_send_bit(v, 0); - break; - default: - iocow_send_bit(v, 1); - break; - } - - return (rc); -} - -int -iocow_pulse(struct ioc_softc *sc, int pulse, int data) -{ - uint32_t mcr_value; - - mcr_value = (pulse << 10) | (data << 2); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_MCR, mcr_value); - do { - mcr_value = - bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC3_MCR); - } while ((mcr_value & 0x00000002) == 0); - - delay(500); - - return (mcr_value & 1); -} - -/* - * Interrupt handling. - */ - -/* - * List of interrupt bits to enable for each device. - * - * For the serial ports, we only enable the passthrough interrupt and - * let com(4) tinker with the appropriate registers, instead of adding - * an unnecessary layer there. - */ -static const uint32_t ioc_intrbits[IOC_NDEVS] = { - IOC3_IRQ_UARTA, - IOC3_IRQ_UARTB, - IOC3_IRQ_LPT, - IOC3_IRQ_KBC, - 0, /* RTC */ - 0 /* Ethernet, handled differently */ -}; - -void * -ioc_intr_establish(void *cookie, u_long dev, int level, int (*func)(void *), - void *arg, char *name) -{ - struct ioc_softc *sc = cookie; - struct ioc_intr *ii; - - if (dev < 0 || dev >= IOC_NDEVS) - return NULL; - - ii = (struct ioc_intr *)malloc(sizeof(*ii), M_DEVBUF, M_NOWAIT); - if (ii == NULL) - return NULL; - - ii->ii_ioc = sc; - ii->ii_func = func; - ii->ii_arg = arg; - ii->ii_level = level; - - evcount_attach(&ii->ii_count, name, &ii->ii_level); - sc->sc_intr[dev] = ii; - - /* enable hardware source if necessary */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IES, - ioc_intrbits[dev]); - - return (ii); -} - -int -ioc_intr_superio(void *v) -{ - struct ioc_softc *sc = (struct ioc_softc *)v; - uint32_t pending, mask; - int dev; - - pending = bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IR) & - bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IES); - - if (pending == 0) - return 0; - - /* Disable pending interrupts */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC3_SIO_IEC, pending); - - for (dev = 0; dev < IOC_NDEVS - 1 /* skip Ethernet */; dev++) { - mask = pending & ioc_intrbits[dev]; - if (mask != 0) { - (void)ioc_intr_dispatch(sc, dev); - - /* Ack, then reenable, pending interrupts */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC3_SIO_IR, mask); - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC3_SIO_IES, mask); - } - } - - return 1; -} - -int -ioc_intr_ethernet(void *v) -{ - struct ioc_softc *sc = (struct ioc_softc *)v; - - /* This interrupt source is not shared between several devices. */ - return ioc_intr_dispatch(sc, IOCDEV_EF); -} - -int -ioc_intr_shared(void *v) -{ - return ioc_intr_superio(v) | ioc_intr_ethernet(v); -} - -int -ioc_intr_dispatch(struct ioc_softc *sc, int dev) -{ - struct ioc_intr *ii; - int rc = 0; - - /* Call registered interrupt function. */ - if ((ii = sc->sc_intr[dev]) != NULL && ii->ii_func != NULL) { - rc = (*ii->ii_func)(ii->ii_arg); - if (rc != 0) - ii->ii_count.ec_count++; - } - - return rc; -} diff --git a/sys/arch/sgi/pci/iocreg.h b/sys/arch/sgi/pci/iocreg.h deleted file mode 100644 index e65473ffcb3..00000000000 --- a/sys/arch/sgi/pci/iocreg.h +++ /dev/null @@ -1,214 +0,0 @@ -/* $OpenBSD: iocreg.h,v 1.11 2016/01/02 05:49:36 visa Exp $ */ - -/* - * Copyright (c) 2008 Joel Sing. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Register definitions for SGI IOC3 ASIC. - */ - -#define IOC_NDEVS 6 - -#define IOCDEV_SERIAL_A 0 -#define IOCDEV_SERIAL_B 1 -#define IOCDEV_LPT 2 -#define IOCDEV_KBC 3 -#define IOCDEV_RTC 4 -#define IOCDEV_EF 5 - -/* SuperIO registers */ -#define IOC3_SIO_IR 0x0000001c /* SIO interrupt register */ -#define IOC3_SIO_IES 0x00000020 /* SIO interrupt enable */ -#define IOC3_SIO_IEC 0x00000024 /* SIO interrupt disable */ -#define IOC3_SIO_CR 0x00000028 /* SIO control register */ -#define IOC3_MCR 0x00000030 /* MicroLan control register */ - -/* GPIO registers */ -#define IOC3_GPCR_S 0x00000034 /* GPIO control bit set */ -#define IOC3_GPCR_C 0x00000038 /* GPIO control bit clear */ -#define IOC3_GPDR 0x0000003c /* GPIO data */ -#define IOC3_GPPR_BASE 0x00000040 /* 9 GPIO pin registers */ -#define IOC3_GPPR(x) (IOC3_GPPR_BASE + (x) * 4) - -/* Keyboard controller registers. */ -#define IOC3_KBC_CTRL_STATUS 0x0000009c -#define IOC3_KBC_KBD_RX 0x000000a0 -#define IOC3_KBC_AUX_RX 0x000000a4 -#define IOC3_KBC_KBD_TX 0x000000a8 -#define IOC3_KBC_AUX_TX 0x000000ac - -/* Non-16550 mode UART registers */ -#define IOC3_UARTA_SSCR 0x000000b8 /* control register */ -#define IOC3_UARTA_STPIR 0x000000bc /* TX producer index register */ -#define IOC3_UARTA_STCIR 0x000000c0 /* TX consumer index register */ -#define IOC3_UARTA_SRPIR 0x000000c4 /* RX producer index register */ -#define IOC3_UARTA_SRCIR 0x000000c8 /* RX consumer index register */ -#define IOC3_UARTA_SRTR 0x000000cc /* receive timer register */ -#define IOC3_UARTA_SHADOW 0x000000d0 /* 16550 shadow register */ - -#define IOC3_UARTB_SSCR 0x000000d4 -#define IOC3_UARTB_STPIR 0x000000d8 -#define IOC3_UARTB_STCIR 0x000000dc -#define IOC3_UARTB_SRPIR 0x000000e0 -#define IOC3_UARTB_SRCIR 0x000000e4 -#define IOC3_UARTB_SRTR 0x000000e8 -#define IOC3_UARTB_SHADOW 0x000000ec - -/* Ethernet registers */ -#define IOC3_ENET_MCR 0x000000f0 /* Master Control Register */ -#define IOC3_ENET_ISR 0x000000f4 /* Interrupt Status Register */ -#define IOC3_ENET_IER 0x000000f8 /* Interrupt Enable Register */ -#define IOC3_ENET_RCSR 0x000000fc /* RX Control and Status Reg. */ -#define IOC3_ENET_RBR_H 0x00000100 /* RX Base Register */ -#define IOC3_ENET_RBR_L 0x00000104 -#define IOC3_ENET_RBAR 0x00000108 /* RX Barrier Register */ -#define IOC3_ENET_RCIR 0x0000010c /* RX Consumer Index Register */ -#define IOC3_ENET_RPIR 0x00000110 /* RX Producer Index Register */ -#define IOC3_ENET_RTR 0x00000114 /* RX Timer Register */ -#define IOC3_ENET_TCSR 0x00000118 /* TX Control and Status Reg. */ -#define IOC3_ENET_RSR 0x0000011c /* Random Seed Register */ -#define IOC3_ENET_TCDC 0x00000120 /* TX Collision Detect Counter */ -#define IOC3_ENET_BIR 0x00000124 -#define IOC3_ENET_TBR_H 0x00000128 /* TX Base Register */ -#define IOC3_ENET_TBR_L 0x0000012c -#define IOC3_ENET_TCIR 0x00000130 /* TX Consumer Index Register */ -#define IOC3_ENET_TPIR 0x00000134 /* TX Producer Index Register */ -#define IOC3_ENET_MAR_H 0x00000138 /* MAC Address Register */ -#define IOC3_ENET_MAR_L 0x0000013c -#define IOC3_ENET_HAR_H 0x00000140 /* Hash filter Address Reg. */ -#define IOC3_ENET_HAR_L 0x00000144 -#define IOC3_ENET_MICR 0x00000148 /* MII Control Register */ -#define IOC3_ENET_MIDR_R 0x0000014c /* MII Data Register (read) */ -#define IOC3_ENET_MIDR_W 0x00000150 /* MII Data Register (write) */ - -/* bits in the SIO interrupt register */ -#define IOC3_IRQ_UARTA 0x00000040 /* UART A passthrough */ -#define IOC3_IRQ_UARTB 0x00008000 /* UART B passthrough */ -#define IOC3_IRQ_LPT 0x00040000 /* parallel port passthrough */ -#define IOC3_IRQ_KBC 0x00400000 /* keyboard controller */ - -/* bits in GPCR */ -#define IOC3_GPCR_PHY_RESET 0x00000020 /* reset Ethernet PHY */ -#define IOC3_GPCR_UARTA_PIO 0x00000040 /* UARTA in PIO mode */ -#define IOC3_GPCR_UARTB_PIO 0x00000080 /* UARTB in PIO mode */ -#define IOC3_GPCR_MLAN 0x00200000 /* MicroLan enable */ - -/* bits in SSCR */ -#define IOC3_SSCR_RESET 0x80000000 - -/* bits in ENET_MCR */ -#define IOC3_ENET_MCR_DUPLEX 0x00000001 -#define IOC3_ENET_MCR_PROMISC 0x00000002 -#define IOC3_ENET_MCR_PADEN 0x00000004 -#define IOC3_ENET_MCR_RXOFF_MASK 0x000001f8 -#define IOC3_ENET_MCR_RXOFF_SHIFT 3 -#define IOC3_ENET_MCR_PARITY_ENABLE 0x00000200 -#define IOC3_ENET_MCR_LARGE_SSRAM 0x00001000 -#define IOC3_ENET_MCR_TX_DMA 0x00002000 -#define IOC3_ENET_MCR_TX 0x00004000 -#define IOC3_ENET_MCR_RX_DMA 0x00008000 -#define IOC3_ENET_MCR_RX 0x00010000 -#define IOC3_ENET_MCR_LOOPBACK 0x00020000 -#define IOC3_ENET_MCR_RESET 0x80000000 - -/* bits in the ENET interrupt register */ -#define IOC3_ENET_ISR_RX_TIMER 0x00000001 /* RX periodic int */ -#define IOC3_ENET_ISR_RX_THRESHOLD 0x00000002 /* RX q above threshold */ -#define IOC3_ENET_ISR_RX_OFLOW 0x00000004 /* RX q overflow */ -#define IOC3_ENET_ISR_RX_BUF_OFLOW 0x00000008 /* RX buffer overflow */ -#define IOC3_ENET_ISR_RX_MEMORY 0x00000010 /* RX memory acc. err */ -#define IOC3_ENET_ISR_RX_PARITY 0x00000020 /* RX parity error */ -#define IOC3_ENET_ISR_TX_EMPTY 0x00010000 /* TX q empty */ -#define IOC3_ENET_ISR_TX_RETRY 0x00020000 -#define IOC3_ENET_ISR_TX_EXDEF 0x00040000 -#define IOC3_ENET_ISR_TX_LCOLL 0x00080000 /* TX Late Collision */ -#define IOC3_ENET_ISR_TX_GIANT 0x00100000 -#define IOC3_ENET_ISR_TX_BUF_UFLOW 0x00200000 /* TX buf underflow */ -#define IOC3_ENET_ISR_TX_EXPLICIT 0x00400000 /* TX int requested */ -#define IOC3_ENET_ISR_TX_COLL_WRAP 0x00800000 -#define IOC3_ENET_ISR_TX_DEFER_WRAP 0x01000000 -#define IOC3_ENET_ISR_TX_MEMORY 0x02000000 /* TX memory acc. err */ -#define IOC3_ENET_ISR_TX_PARITY 0x04000000 /* TX parity error */ - -#define IOC3_ENET_ISR_TX_ALL 0x07ff0000 /* all TX bits */ - -/* bits in ENET_RCSR */ -#define IOC3_ENET_RCSR_THRESHOLD_MASK 0x000001ff - -/* bits in ENET_RPIR */ -#define IOC3_ENET_PIR_SET 0x80000000 /* set new value */ - -/* bits in ENET_TCSR */ -#define IOC3_ENET_TCSR_IPGT_MASK 0x0000007f /* interpacket gap */ -#define IOC3_ENET_TCSR_IPGT_SHIFT 0 -#define IOC3_ENET_TCSR_IPGR1_MASK 0x00007f00 -#define IOC3_ENET_TCSR_IPGR1_SHIFT 8 -#define IOC3_ENET_TCSR_IPGR2_MASK 0x007f0000 -#define IOC3_ENET_TCSR_IPGR2_SHIFT 16 -#define IOC3_ENET_TCSR_NOTXCLOCK 0x80000000 -#define IOC3_ENET_TCSR_FULL_DUPLEX \ - ((17 << IOC3_ENET_TCSR_IPGR2_SHIFT) | \ - (11 << IOC3_ENET_TCSR_IPGR1_SHIFT) | \ - (21 << IOC3_ENET_TCSR_IPGT_SHIFT)) -#define IOC3_ENET_TCSR_HALF_DUPLEX \ - ((21 << IOC3_ENET_TCSR_IPGR2_SHIFT) | \ - (21 << IOC3_ENET_TCSR_IPGR1_SHIFT) | \ - (21 << IOC3_ENET_TCSR_IPGT_SHIFT)) - -/* bits in ENET_TCDC */ -#define IOC3_ENET_TCDC_COLLISION_MASK 0x0000ffff -#define IOC3_ENET_TCDC_DEFER_MASK 0xffff0000 -#define IOC3_ENET_TCDC_DEFER_SHIFT 16 - -/* bits in ENET_TCIR */ -#define IOC3_ENET_TCIR_IDLE 0x80000000 - -/* bits in ENET_MICR */ -#define IOC3_ENET_MICR_REG_MASK 0x0000001f -#define IOC3_ENET_MICR_PHY_MASK 0x000003e0 -#define IOC3_ENET_MICR_PHY_SHIFT 5 -#define IOC3_ENET_MICR_READ 0x00000400 -#define IOC3_ENET_MICR_WRITE 0x00000000 -#define IOC3_ENET_MICR_BUSY 0x00000800 - -#define IOC3_ENET_MIDR_MASK 0x0000ffff - -/* - * Offsets and sizes for subdevices handled by mi drivers. - */ - -#define IOC3_UARTA_BASE 0x00020178 -#define IOC3_UARTB_BASE 0x00020170 - -/* - * Ethernet SSRAM. - */ - -#define IOC3_SSRAM_BASE 0x00040000 -#define IOC3_SSRAM_SMALL_SIZE 0x00020000 -#define IOC3_SSRAM_LARGE_SIZE 0x00040000 - -#define IOC3_SSRAM_PARITY_BIT 0x00010000 -#define IOC3_SSRAM_DATA_MASK 0x0000ffff - -/* - * Offsets of devices connected to the four IOC3 `bytebus'. - */ - -#define IOC3_BYTEBUS_0 0x00080000 -#define IOC3_BYTEBUS_1 0x000a0000 -#define IOC3_BYTEBUS_2 0x000c0000 -#define IOC3_BYTEBUS_3 0x000e0000 diff --git a/sys/arch/sgi/pci/iocvar.h b/sys/arch/sgi/pci/iocvar.h deleted file mode 100644 index 12db7f144a6..00000000000 --- a/sys/arch/sgi/pci/iocvar.h +++ /dev/null @@ -1,38 +0,0 @@ -/* $OpenBSD: iocvar.h,v 1.6 2010/04/06 19:12:34 miod Exp $ */ - -/* - * Copyright (c) 2008, 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -struct ioc_attach_args { - const char *iaa_name; - - bus_space_tag_t iaa_memt; - bus_space_handle_t iaa_memh; - bus_dma_tag_t iaa_dmat; - - bus_addr_t iaa_base; - int iaa_dev; - - uint8_t iaa_enaddr[6]; - - int iaa_flags; -#define IOC_FLAGS_OBIO 0x00000001 - - struct sgi_device_location iaa_location; -}; - -void *ioc_intr_establish(void *, u_long, int, int (*)(void *), - void *, char *); diff --git a/sys/arch/sgi/pci/iof.c b/sys/arch/sgi/pci/iof.c deleted file mode 100644 index cc99d1883cb..00000000000 --- a/sys/arch/sgi/pci/iof.c +++ /dev/null @@ -1,330 +0,0 @@ -/* $OpenBSD: iof.c,v 1.9 2014/05/19 21:18:42 miod Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * IOC4 device driver. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcivar.h> -#include <dev/pci/pcidevs.h> - -#include <sgi/pci/iofreg.h> -#include <sgi/pci/iofvar.h> - -int iof_match(struct device *, void *, void *); -void iof_attach(struct device *, struct device *, void *); -void iof_attach_child(struct device *, const char *, bus_addr_t, uint); -int iof_search(struct device *, void *, void *); -int iof_print(void *, const char *); - -struct iof_intr { - struct iof_softc *ii_iof; - - int (*ii_func)(void *); - void *ii_arg; - - struct evcount ii_count; - int ii_level; -}; - -struct iof_softc { - struct device sc_dev; - - bus_space_tag_t sc_memt; - bus_space_handle_t sc_memh; - bus_dma_tag_t sc_dmat; - pci_chipset_tag_t sc_pc; - pcitag_t sc_tag; - - uint32_t sc_mcr; - - void *sc_ih; - struct iof_intr *sc_intr[IOC4_NDEVS]; -}; - -struct cfattach iof_ca = { - sizeof(struct iof_softc), iof_match, iof_attach, -}; - -struct cfdriver iof_cd = { - NULL, "iof", DV_DULL, -}; - -int iof_intr_dispatch(struct iof_softc *, int); -int iof_intr(void *); - -int -iof_match(struct device *parent, void *match, void *aux) -{ - struct pci_attach_args *pa = aux; - - if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_SGI && - PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_SGI_IOC4) - return 1; - - return 0; -} - -int -iof_print(void *aux, const char *iofname) -{ - struct iof_attach_args *iaa = aux; - - if (iofname != NULL) - printf("%s at %s", iaa->iaa_name, iofname); - - printf(" base 0x%lx", iaa->iaa_base); - - return UNCONF; -} - -void -iof_attach(struct device *parent, struct device *self, void *aux) -{ - struct iof_softc *sc = (struct iof_softc *)self; - struct pci_attach_args *pa = aux; - pci_intr_handle_t ih; - bus_space_tag_t memt; - bus_space_handle_t memh; - bus_size_t memsize; - const char *intrstr; - - printf(": "); - - if (pci_mapreg_map(pa, PCI_MAPREG_START, PCI_MAPREG_TYPE_MEM, 0, - &memt, &memh, NULL, &memsize, 0)) { - printf("can't map mem space\n"); - return; - } - - sc->sc_pc = pa->pa_pc; - sc->sc_tag = pa->pa_tag; - sc->sc_dmat = pa->pa_dmat; - - sc->sc_memt = memt; - sc->sc_memh = memh; - - sc->sc_mcr = bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC4_MCR); - - /* - * Acknowledge all pending interrupts, and disable them. - */ - - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IEC, ~0x0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IES, 0x0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IR, - bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IR)); - - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IEC, ~0x0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IES, 0x0); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IR, - bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IR)); - - if (pci_intr_map(pa, &ih) != 0) { - printf("failed to map interrupt!\n"); - goto unmap; - } - intrstr = pci_intr_string(sc->sc_pc, ih); - - sc->sc_ih = pci_intr_establish(sc->sc_pc, ih, IPL_TTY, iof_intr, - sc, self->dv_xname); - if (sc->sc_ih == NULL) { - printf("failed to establish interrupt at %s\n", intrstr); - goto unmap; - } - printf("%s\n", intrstr); - - /* - * Attach other sub-devices. - */ - - iof_attach_child(self, "com", IOC4_UARTA_BASE, IOC4DEV_SERIAL_A); - iof_attach_child(self, "com", IOC4_UARTB_BASE, IOC4DEV_SERIAL_B); - iof_attach_child(self, "com", IOC4_UARTC_BASE, IOC4DEV_SERIAL_C); - iof_attach_child(self, "com", IOC4_UARTD_BASE, IOC4DEV_SERIAL_D); - iof_attach_child(self, "iockbc", IOC4_KBC_BASE, IOC4DEV_KBC); - iof_attach_child(self, "dsrtc", IOC4_BYTEBUS_0, IOC4DEV_RTC); - - return; - -unmap: - bus_space_unmap(memt, memh, memsize); -} - -void -iof_attach_child(struct device *iof, const char *name, bus_addr_t base, - uint dev) -{ - struct iof_softc *sc = (struct iof_softc *)iof; - struct iof_attach_args iaa; - - iaa.iaa_name = name; - pci_get_device_location(sc->sc_pc, sc->sc_tag, &iaa.iaa_location); - iaa.iaa_memt = sc->sc_memt; - iaa.iaa_memh = sc->sc_memh; - iaa.iaa_dmat = sc->sc_dmat; - iaa.iaa_base = base; - iaa.iaa_dev = dev; - iaa.iaa_clock = sc->sc_mcr & IOC4_MCR_PCI_66MHZ ? 66666667 : 33333333; - - config_found_sm(iof, &iaa, iof_print, iof_search); -} - -int -iof_search(struct device *parent, void *vcf, void *args) -{ - struct cfdata *cf = vcf; - struct iof_attach_args *iaa = (struct iof_attach_args *)args; - - if (strcmp(cf->cf_driver->cd_name, iaa->iaa_name) != 0) - return 0; - - if (cf->cf_loc[0] != -1 && cf->cf_loc[0] != (int)iaa->iaa_base) - return 0; - - return (*cf->cf_attach->ca_match)(parent, cf, iaa); -} - -/* - * Interrupt handling. - */ - -/* - * List of interrupt bits to enable for each device. - * - * For the serial ports, we only enable the passthrough interrupt and - * let com(4) tinker with the appropriate registers, instead of adding - * an unnecessary layer there. - */ -static const struct { - uint32_t sio; - uint32_t other; -} ioc4_intrbits[IOC4_NDEVS] = { - { IOC4_SIRQ_UARTA, 0 }, - { IOC4_SIRQ_UARTB, 0 }, - { IOC4_SIRQ_UARTC, 0 }, - { IOC4_SIRQ_UARTD, 0 }, - { 0, IOC4_OIRQ_KBC }, - { 0, IOC4_OIRQ_ATAPI }, - { 0, 0 } /* no RTC interrupt */ -}; - -void * -iof_intr_establish(void *cookie, uint dev, int level, int (*func)(void *), - void *arg, char *name) -{ - struct iof_softc *sc = cookie; - struct iof_intr *ii; - - if (dev < 0 || dev >= IOC4_NDEVS) - return NULL; - - if (ioc4_intrbits[dev].sio == 0 && ioc4_intrbits[dev].other == 0) - return NULL; - - ii = (struct iof_intr *)malloc(sizeof(*ii), M_DEVBUF, M_NOWAIT); - if (ii == NULL) - return NULL; - - ii->ii_iof = sc; - ii->ii_func = func; - ii->ii_arg = arg; - ii->ii_level = level; - - evcount_attach(&ii->ii_count, name, &ii->ii_level); - sc->sc_intr[dev] = ii; - - /* enable hardware source if necessary */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IES, - ioc4_intrbits[dev].sio); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IES, - ioc4_intrbits[dev].other); - - return (ii); -} - -int -iof_intr(void *v) -{ - struct iof_softc *sc = (struct iof_softc *)v; - uint32_t spending, opending, mask; - int dev; - - spending = bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IR) & - bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IES); - opending = bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IR) & - bus_space_read_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IES); - - if (spending == 0 && opending == 0) - return 0; - - /* Disable pending interrupts */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_SIO_IEC, spending); - bus_space_write_4(sc->sc_memt, sc->sc_memh, IOC4_OTHER_IEC, opending); - - for (dev = 0; dev < IOC4_NDEVS; dev++) { - mask = spending & ioc4_intrbits[dev].sio; - if (mask != 0) { - (void)iof_intr_dispatch(sc, dev); - - /* Ack, then reenable, pending interrupts */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC4_SIO_IR, mask); - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC4_SIO_IES, mask); - } - mask = opending & ioc4_intrbits[dev].other; - if (mask != 0) { - (void)iof_intr_dispatch(sc, dev); - - /* Ack, then reenable, pending interrupts */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC4_OTHER_IR, mask); - bus_space_write_4(sc->sc_memt, sc->sc_memh, - IOC4_OTHER_IES, mask); - } - } - - return 1; -} - -int -iof_intr_dispatch(struct iof_softc *sc, int dev) -{ - struct iof_intr *ii; - int rc = 0; - - /* Call registered interrupt function. */ - if ((ii = sc->sc_intr[dev]) != NULL && ii->ii_func != NULL) { - rc = (*ii->ii_func)(ii->ii_arg); - if (rc != 0) - ii->ii_count.ec_count++; - } - - return rc; -} diff --git a/sys/arch/sgi/pci/iofreg.h b/sys/arch/sgi/pci/iofreg.h deleted file mode 100644 index 461f99a13b6..00000000000 --- a/sys/arch/sgi/pci/iofreg.h +++ /dev/null @@ -1,77 +0,0 @@ -/* $OpenBSD: iofreg.h,v 1.5 2013/12/30 05:27:01 miod Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Register definitions for SGI IOC4 ASIC. - */ - -#define IOC4_NDEVS 7 - -#define IOC4DEV_SERIAL_A 0 -#define IOC4DEV_SERIAL_B 1 -#define IOC4DEV_SERIAL_C 2 -#define IOC4DEV_SERIAL_D 3 -#define IOC4DEV_KBC 4 -#define IOC4DEV_ATAPI 5 -#define IOC4DEV_RTC 6 - -/* Interrupt control registers */ -#define IOC4_SIO_IR 0x00000008 -#define IOC4_OTHER_IR 0x0000000c -#define IOC4_SIO_IES 0x00000010 -#define IOC4_OTHER_IES 0x00000014 -#define IOC4_SIO_IEC 0x00000018 -#define IOC4_OTHER_IEC 0x0000001c -#define IOC4_SIO_CR 0x00000020 -#define IOC4_MCR 0x00000024 - -/* Keyboard controller registers */ -#define IOC4_KBC_CTRL_STATUS 0x00000200 -#define IOC4_KBC_KBD_RX 0x00000204 -#define IOC4_KBC_AUX_RX 0x00000208 -#define IOC4_KBC_KBD_TX 0x0000020c -#define IOC4_KBC_AUX_TX 0x00000210 - -/* bits in the SIO interrupt register */ -#define IOC4_SIRQ_UARTA 0x00000040 /* UART A passthrough */ -#define IOC4_SIRQ_UARTB 0x00004000 /* UART B passthrough */ -#define IOC4_SIRQ_UARTC 0x00400000 /* UART C passthrough */ -#define IOC4_SIRQ_UARTD 0x40000000 /* UART D passthrough */ - -/* bits in the OTHER interrupt register */ -#define IOC4_OIRQ_ATAPI 0x00000001 /* ATAPI passthrough */ -#define IOC4_OIRQ_KBC 0x00000040 /* keyboard controller */ - -/* bits in the MCR register */ -#define IOC4_MCR_PCI_66MHZ 0x00000001 - -#define IOC4_ATAPI_BASE 0x00000100 -#define IOC4_ATAPI_SIZE 0x00000100 - -#define IOC4_KBC_BASE 0x00000200 -#define IOC4_KBC_SIZE 0x00000014 - -#define IOC4_UARTA_BASE 0x00000380 -#define IOC4_UARTB_BASE 0x00000388 -#define IOC4_UARTC_BASE 0x00000390 -#define IOC4_UARTD_BASE 0x00000398 - -#define IOC4_BYTEBUS_0 0x00080000 -#define IOC4_BYTEBUS_1 0x000a0000 -#define IOC4_BYTEBUS_2 0x000c0000 -#define IOC4_BYTEBUS_3 0x000e0000 diff --git a/sys/arch/sgi/pci/iofvar.h b/sys/arch/sgi/pci/iofvar.h deleted file mode 100644 index a6dc905e05d..00000000000 --- a/sys/arch/sgi/pci/iofvar.h +++ /dev/null @@ -1,33 +0,0 @@ -/* $OpenBSD: iofvar.h,v 1.4 2010/04/06 19:12:34 miod Exp $ */ - -/* - * Copyright (c) 2009, 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -struct iof_attach_args { - const char *iaa_name; - - bus_space_tag_t iaa_memt; - bus_space_handle_t iaa_memh; - bus_dma_tag_t iaa_dmat; - - bus_addr_t iaa_base; - uint iaa_dev; - uint iaa_clock; - - struct sgi_device_location iaa_location; -}; - -void *iof_intr_establish(void *, uint, int, int (*)(void *), void *, char *); diff --git a/sys/arch/sgi/pci/macepcibridge.c b/sys/arch/sgi/pci/macepcibridge.c deleted file mode 100644 index 532e304cbdc..00000000000 --- a/sys/arch/sgi/pci/macepcibridge.c +++ /dev/null @@ -1,921 +0,0 @@ -/* $OpenBSD: macepcibridge.c,v 1.49 2018/12/03 13:46:30 visa Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se) - * - * 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 ``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 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. - * - */ - -/* - * Machine dependent PCI BUS Bridge driver on Mace (O2). - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/malloc.h> -#include <sys/device.h> -#include <sys/proc.h> -#include <sys/ioctl.h> -#include <sys/extent.h> - -#include <machine/autoconf.h> -#include <machine/cpu.h> -#include <machine/vmparam.h> - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcivar.h> -#include <dev/pci/ppbreg.h> -#include <dev/pci/pcidevs.h> - -#include <dev/cardbus/rbus.h> - -#include <mips64/archtype.h> -#include <sgi/localbus/crimebus.h> -#include <sgi/localbus/macebus.h> -#include <sgi/localbus/macebusvar.h> -#include <sgi/pci/macepcibrvar.h> - -#include "cardbus.h" - -int mace_pcibrmatch(struct device *, void *, void *); -void mace_pcibrattach(struct device *, struct device *, void *); - -void mace_pcibr_attach_hook(struct device *, struct device *, - struct pcibus_attach_args *); -int mace_pcibr_bus_maxdevs(void *, int); -pcitag_t mace_pcibr_make_tag(void *, int, int, int); -void mace_pcibr_decompose_tag(void *, pcitag_t, int *, int *, int *); -int mace_pcibr_conf_size(void *, pcitag_t); -pcireg_t mace_pcibr_conf_read(void *, pcitag_t, int); -void mace_pcibr_conf_write(void *, pcitag_t, int, pcireg_t); -int mace_pcibr_probe_device_hook(void *, struct pci_attach_args *); -int mace_pcibr_get_widget(void *); -int mace_pcibr_get_dl(void *, pcitag_t, struct sgi_device_location *); -int mace_pcibr_intr_map(struct pci_attach_args *, pci_intr_handle_t *); -const char *mace_pcibr_intr_string(void *, pci_intr_handle_t); -void *mace_pcibr_intr_establish(void *, pci_intr_handle_t, int, - int (*)(void *), void *, const char *); -void mace_pcibr_intr_disestablish(void *, void *); -int mace_pcibr_intr_line(void *, pci_intr_handle_t); -int mace_pcibr_ppb_setup(void *, pcitag_t, bus_addr_t *, bus_addr_t *, - bus_addr_t *, bus_addr_t *); -void *mace_pcibr_rbus_parent_io(struct pci_attach_args *); -void *mace_pcibr_rbus_parent_mem(struct pci_attach_args *); - -void *mace_pcib_space_vaddr(bus_space_tag_t, bus_space_handle_t); -void mace_pcib_space_barrier(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_size_t, int); -bus_addr_t mace_pcibr_pa_to_device(paddr_t, int); - -int mace_pcibr_rbus_space_map(bus_space_tag_t, bus_addr_t, bus_size_t, - int, bus_space_handle_t *); -void mace_pcibr_rbus_space_unmap(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_addr_t *); - -void mace_pcibr_configure(struct mace_pcibr_softc *); -void mace_pcibr_device_fixup(struct mace_pcibr_softc *, int, int); -int mace_pcibr_errintr(void *); - -struct cfattach macepcibr_ca = { - sizeof(struct mace_pcibr_softc), mace_pcibrmatch, mace_pcibrattach, -}; - -struct cfdriver macepcibr_cd = { - NULL, "macepcibr", DV_DULL, -}; - -bus_space_t mace_pcibbus_mem_tag = { - PHYS_TO_XKPHYS(MACE_PCI_MEM_BASE, CCA_NC), - NULL, - mace_pcib_read_1, mace_pcib_write_1, - mace_pcib_read_2, mace_pcib_write_2, - mace_pcib_read_4, mace_pcib_write_4, - mace_pcib_read_8, mace_pcib_write_8, - mace_pcib_read_raw_2, mace_pcib_write_raw_2, - mace_pcib_read_raw_4, mace_pcib_write_raw_4, - mace_pcib_read_raw_8, mace_pcib_write_raw_8, - mace_pcib_space_map, mace_pcib_space_unmap, mace_pcib_space_region, - mace_pcib_space_vaddr, mace_pcib_space_barrier -}; - -bus_space_t mace_pcibbus_io_tag = { - PHYS_TO_XKPHYS(MACE_PCI_IO_BASE, CCA_NC), - NULL, - mace_pcib_read_1, mace_pcib_write_1, - mace_pcib_read_2, mace_pcib_write_2, - mace_pcib_read_4, mace_pcib_write_4, - mace_pcib_read_8, mace_pcib_write_8, - mace_pcib_read_raw_2, mace_pcib_write_raw_2, - mace_pcib_read_raw_4, mace_pcib_write_raw_4, - mace_pcib_read_raw_8, mace_pcib_write_raw_8, - mace_pcib_space_map, mace_pcib_space_unmap, mace_pcib_space_region, - mace_pcib_space_vaddr, mace_pcib_space_barrier -}; - -static const struct mips_pci_chipset mace_pci_chipset = { - .pc_attach_hook = mace_pcibr_attach_hook, - .pc_bus_maxdevs = mace_pcibr_bus_maxdevs, - .pc_make_tag = mace_pcibr_make_tag, - .pc_decompose_tag = mace_pcibr_decompose_tag, - .pc_conf_size = mace_pcibr_conf_size, - .pc_conf_read = mace_pcibr_conf_read, - .pc_conf_write = mace_pcibr_conf_write, - .pc_probe_device_hook = mace_pcibr_probe_device_hook, - .pc_get_widget = mace_pcibr_get_widget, - .pc_get_dl = mace_pcibr_get_dl, - .pc_intr_map = mace_pcibr_intr_map, - .pc_intr_string = mace_pcibr_intr_string, - .pc_intr_establish = mace_pcibr_intr_establish, - .pc_intr_disestablish = mace_pcibr_intr_disestablish, - .pc_intr_line = mace_pcibr_intr_line, - .pc_ppb_setup = mace_pcibr_ppb_setup, -#if NCARDBUS > 0 - .pc_rbus_parent_io = mace_pcibr_rbus_parent_io, - .pc_rbus_parent_mem = mace_pcibr_rbus_parent_mem -#endif -}; - -/* - * PCI doesn't have any special needs; just use the generic versions - * of these functions. - */ -struct machine_bus_dma_tag mace_pci_bus_dma_tag = { - NULL, /* _cookie */ - _dmamap_create, - _dmamap_destroy, - _dmamap_load, - _dmamap_load_mbuf, - _dmamap_load_uio, - _dmamap_load_raw, - _dmamap_load_buffer, - _dmamap_unload, - _dmamap_sync, - _dmamem_alloc, - _dmamem_free, - _dmamem_map, - _dmamem_unmap, - _dmamem_mmap, - mace_pcibr_pa_to_device, - CRIME_MEMORY_MASK -}; - -const struct _perr_map { - pcireg_t mask; - pcireg_t flag; - const char *text; -} perr_map[] = { - { PERR_MASTER_ABORT, PERR_MASTER_ABORT_ADDR_VALID, "master abort" }, - { PERR_TARGET_ABORT, PERR_TARGET_ABORT_ADDR_VALID, "target abort" }, - { PERR_DATA_PARITY_ERR,PERR_DATA_PARITY_ADDR_VALID, "data parity error" }, - { PERR_RETRY_ERR, PERR_RETRY_ADDR_VALID, "retry error" }, - { PERR_ILLEGAL_CMD, 0, "illegal command" }, - { PERR_SYSTEM_ERR, 0, "system error" }, - { PERR_INTERRUPT_TEST,0, "interrupt test" }, - { PERR_PARITY_ERR, 0, "parity error" }, - { PERR_OVERRUN, 0, "overrun error" }, - { PERR_RSVD, 0, "reserved ??" }, - { PERR_MEMORY_ADDR, 0, "memory address" }, - { PERR_CONFIG_ADDR, 0, "config address" }, - { 0, 0, NULL } -}; - -static int mace_pcibrprint(void *, const char *pnp); - -int -mace_pcibrmatch(struct device *parent, void *match, void *aux) -{ - switch (sys_config.system_type) { - case SGI_O2: - return 1; - default: - return 0; - } -} - -void -mace_pcibrattach(struct device *parent, struct device *self, void *aux) -{ - struct mace_pcibr_softc *sc = (struct mace_pcibr_softc *)self; - struct pcibus_attach_args pba; - struct macebus_attach_args *maa = aux; - pcireg_t pcireg; - - sc->sc_mem_bus_space = &mace_pcibbus_mem_tag; - sc->sc_io_bus_space = &mace_pcibbus_io_tag; - - /* Map in PCI control registers */ - sc->sc_memt = maa->maa_memt; - if (bus_space_map(sc->sc_memt, maa->maa_baseaddr, 4096, 0, - &sc->sc_memh)) { - printf(": can't map PCI control registers\n"); - return; - } - pcireg = bus_space_read_4(sc->sc_memt, sc->sc_memh, MACE_PCI_REVISION); - - printf(": mace rev %d\n", pcireg); - - /* Register the PCI ERROR interrupt handler */ - macebus_intr_establish(maa->maa_intr, maa->maa_mace_intr, - IPL_HIGH, mace_pcibr_errintr, sc, sc->sc_dev.dv_xname); - - bcopy(&mace_pci_chipset, &sc->sc_pc, sizeof(mace_pci_chipset)); - sc->sc_pc.pc_conf_v = sc; - sc->sc_pc.pc_intr_v = NULL; - - /* - * The O2 firmware sucks. It makes a mess of I/O BARs and - * an even bigger mess for PCI-PCI bridges. - */ - mace_pcibr_configure(sc); - - /* - * Configure our PCI devices. - */ - bzero(&pba, sizeof(pba)); - pba.pba_busname = "pci"; - pba.pba_iot = sc->sc_io_bus_space; - pba.pba_memt = sc->sc_mem_bus_space; - pba.pba_dmat = &mace_pci_bus_dma_tag; - pba.pba_pc = &sc->sc_pc; - pba.pba_ioex = extent_create("mace_io", 0, 0xffffffff, M_DEVBUF, - NULL, 0, EX_NOWAIT | EX_FILLED); - if (pba.pba_ioex != NULL) { - /* - * I/O accesses at address zero cause PCI errors, so - * make sure the first few bytes are not available. - */ - extent_free(pba.pba_ioex, 0x20, (1UL << 32) - 0x20, EX_NOWAIT); - } - pba.pba_memex = extent_create("mace_mem", 0, 0xffffffff, M_DEVBUF, - NULL, 0, EX_NOWAIT | EX_FILLED); - if (pba.pba_memex != NULL) - extent_free(pba.pba_memex, MACE_PCI_MEM_OFFSET, - MACE_PCI_MEM_SIZE, EX_NOWAIT); - pba.pba_domain = pci_ndomains++; - pba.pba_bus = 0; - config_found(self, &pba, mace_pcibrprint); - - /* Clear PCI errors and set up error interrupt */ - bus_space_write_4(sc->sc_memt, sc->sc_memh, MACE_PCI_ERROR_FLAGS, 0); - pcireg = bus_space_read_4(sc->sc_memt, sc->sc_memh, MACE_PCI_CONTROL); - pcireg |= MACE_PCI_INTCTRL; - bus_space_write_4(sc->sc_memt, sc->sc_memh, MACE_PCI_CONTROL, pcireg); -} - -static int -mace_pcibrprint(void *aux, const char *pnp) -{ - struct pcibus_attach_args *pba = aux; - - if (pnp) - printf("%s at %s", pba->pba_busname, pnp); - printf(" bus %d", pba->pba_bus); - return (UNCONF); -} - -void -mace_pcibr_attach_hook(struct device *parent, struct device *self, - struct pcibus_attach_args *pba) -{ -} - -int -mace_pcibr_errintr(void *v) -{ - struct mace_pcibr_softc *sc = v; - bus_space_tag_t memt = sc->sc_memt; - bus_space_handle_t memh = sc->sc_memh; - const struct _perr_map *emap = perr_map; - pcireg_t stat, erraddr; - - /* Check and clear any PCI error, report found */ - stat = bus_space_read_4(memt, memh, MACE_PCI_ERROR_FLAGS); - erraddr = bus_space_read_4(memt, memh, MACE_PCI_ERROR_ADDRESS); - while (emap->mask) { - if (stat & emap->mask) { - printf("mace: pci err %s", emap->text); - if (emap->flag && stat & emap->flag) - printf(" at address 0x%08x", erraddr); - printf("\n"); - } - emap++; - } - bus_space_write_4(memt, memh, MACE_PCI_ERROR_FLAGS, 0); - return 1; -} - -/* - * PCI access drivers - */ - -pcitag_t -mace_pcibr_make_tag(void *cpv, int bus, int dev, int fnc) -{ - return (bus << 16) | (dev << 11) | (fnc << 8); -} - -void -mace_pcibr_decompose_tag(void *cpv, pcitag_t tag, int *busp, int *devp, - int *fncp) -{ - if (busp != NULL) - *busp = (tag >> 16) & 0xff; - if (devp != NULL) - *devp = (tag >> 11) & 0x1f; - if (fncp != NULL) - *fncp = (tag >> 8) & 0x7; -} - -int -mace_pcibr_bus_maxdevs(void *cpv, int busno) -{ - return busno == 0 ? 6 : 32; -} - -int -mace_pcibr_conf_size(void *cpv, pcitag_t tag) -{ - return PCI_CONFIG_SPACE_SIZE; -} - -pcireg_t -mace_pcibr_conf_read(void *cpv, pcitag_t tag, int offset) -{ - struct mace_pcibr_softc *sc = cpv; - bus_space_tag_t memt = sc->sc_memt; - bus_space_handle_t memh = sc->sc_memh; - pcireg_t data, stat; - int bus, dev; - int s; - - s = splhigh(); - - bus_space_write_4(memt, memh, MACE_PCI_ERROR_FLAGS, 0); - data = tag | offset; - bus_space_write_4(memt, memh, MACE_PCI_CFGADDR, data); - data = bus_space_read_4(memt, memh, MACE_PCI_CFGDATA); - bus_space_write_4(memt, memh, MACE_PCI_CFGADDR, 0); - - /* - * Onboard ahc on O2 can do Ultra speed despite not - * having SEEPROM nor external precision resistors. - */ - mace_pcibr_decompose_tag(cpv, tag, &bus, &dev, NULL); - if (bus == 0 && (dev == 1 || dev == 2) && offset == 0x40) - data |= 0x1000; /* REXTVALID */ - - /* Check and clear any PCI error, returns -1 if error is found */ - stat = bus_space_read_4(memt, memh, MACE_PCI_ERROR_FLAGS); - bus_space_write_4(memt, memh, MACE_PCI_ERROR_FLAGS, 0); - if (stat & (PERR_MASTER_ABORT | PERR_TARGET_ABORT | - PERR_DATA_PARITY_ERR | PERR_RETRY_ERR)) { - data = -1; - } - - splx(s); - return(data); -} - -void -mace_pcibr_conf_write(void *cpv, pcitag_t tag, int offset, pcireg_t data) -{ - struct mace_pcibr_softc *sc = cpv; - pcireg_t addr; - int s; - - s = splhigh(); - - addr = tag | offset; - bus_space_write_4(sc->sc_memt, sc->sc_memh, MACE_PCI_CFGADDR, addr); - bus_space_write_4(sc->sc_memt, sc->sc_memh, MACE_PCI_CFGDATA, data); - bus_space_write_4(sc->sc_memt, sc->sc_memh, MACE_PCI_CFGADDR, 0); - - splx(s); -} - -int -mace_pcibr_probe_device_hook(void *unused, struct pci_attach_args *notused) -{ - return 0; -} - -int -mace_pcibr_get_widget(void *unused) -{ - return 0; -} - -int -mace_pcibr_get_dl(void *cpv, pcitag_t tag, struct sgi_device_location *sdl) -{ - int bus, device, fn; - - memset(sdl, 0, sizeof *sdl); - mace_pcibr_decompose_tag(cpv, tag, &bus, &device, &fn); - if (bus != 0) - return 0; - sdl->device = device; - sdl->fn = fn; - return 1; -} - -int -mace_pcibr_intr_map(struct pci_attach_args *pa, pci_intr_handle_t *ihp) -{ - int bus, dev, pin = pa->pa_rawintrpin; - static const signed char intrmap[][PCI_INTERRUPT_PIN_MAX] = { - { -1, -1, -1, -1 }, - { 8, -1, -1, -1 }, /* ahc0 */ - { 9, -1, -1, -1 }, /* ahc1 */ - { 10, 13, 14, 15 }, /* slot */ - { 11, 15, 13, 14 }, /* no slots... */ - { 12, 14, 15, 13 } /* ... unless you solder them */ - }; - - *ihp = -1; - - if (pin == 0) { - /* No IRQ used. */ - return 1; - } -#ifdef DIAGNOSTIC - if (pin > PCI_INTERRUPT_PIN_MAX) { - printf("mace_pcibr_intr_map: bad interrupt pin %d\n", pin); - return 1; - } -#endif - - pci_decompose_tag(pa->pa_pc, pa->pa_tag, &bus, &dev, NULL); - - if (pa->pa_bridgetag) { - pin = PPB_INTERRUPT_SWIZZLE(pin, dev); - *ihp = pa->pa_bridgeih[pin - PCI_INTERRUPT_PIN_A]; - - return ((*ihp == -1) ? 1 : 0); - } - - if (dev < nitems(intrmap)) - *ihp = intrmap[dev][pin - PCI_INTERRUPT_PIN_A]; - - return ((*ihp == -1) ? 1 : 0); -} - -const char * -mace_pcibr_intr_string(void *lcv, pci_intr_handle_t ih) -{ - static char str[16]; - - snprintf(str, sizeof(str), "irq %ld", ih); - return(str); -} - -void * -mace_pcibr_intr_establish(void *lcv, pci_intr_handle_t ih, int level, - int (*func)(void *), void *arg, const char *name) -{ - return macebus_intr_establish(ih, 0, level, func, arg, name); -} - -void -mace_pcibr_intr_disestablish(void *lcv, void *ih) -{ - macebus_intr_disestablish(ih); -} - -int -mace_pcibr_intr_line(void *lcv, pci_intr_handle_t ih) -{ - return ih; -} - -/* - * Bus access primitives - */ - -u_int8_t -mace_pcib_read_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile u_int8_t *)(h + (o ^ 3)); -} - -u_int16_t -mace_pcib_read_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile u_int16_t *)(h + (o ^ 2)); -} - -u_int32_t -mace_pcib_read_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile u_int32_t *)(h + o); -} - -u_int64_t -mace_pcib_read_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile u_int64_t *)(h + o); -} - -void -mace_pcib_write_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, - u_int8_t v) -{ - *(volatile u_int8_t *)(h + (o ^ 3)) = v; -} - -void -mace_pcib_write_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, - u_int16_t v) -{ - *(volatile u_int16_t *)(h + (o ^ 2)) = v; -} - -void -mace_pcib_write_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, - u_int32_t v) -{ - *(volatile u_int32_t *)(h + o) = v; -} - -void -mace_pcib_write_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, - u_int64_t v) -{ - *(volatile u_int64_t *)(h + o) = v; -} - -void -mace_pcib_read_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - u_int8_t *buf, bus_size_t len) -{ - volatile u_int16_t *addr = (volatile u_int16_t *)(h + (o ^ 2)); - len >>= 1; - while (len-- != 0) { - *(u_int16_t *)buf = letoh16(*addr); - buf += 2; - } -} - -void -mace_pcib_write_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const u_int8_t *buf, bus_size_t len) -{ - volatile u_int16_t *addr = (volatile u_int16_t *)(h + (o ^ 2)); - len >>= 1; - while (len-- != 0) { - *addr = htole16(*(u_int16_t *)buf); - buf += 2; - } -} - -void -mace_pcib_read_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - u_int8_t *buf, bus_size_t len) -{ - volatile u_int32_t *addr = (volatile u_int32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *(u_int32_t *)buf = letoh32(*addr); - buf += 4; - } -} - -void -mace_pcib_write_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const u_int8_t *buf, bus_size_t len) -{ - volatile u_int32_t *addr = (volatile u_int32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *addr = htole32(*(u_int32_t *)buf); - buf += 4; - } -} - -void -mace_pcib_read_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - u_int8_t *buf, bus_size_t len) -{ - volatile u_int64_t *addr = (volatile u_int64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *(u_int64_t *)buf = letoh64(*addr); - buf += 8; - } -} - -void -mace_pcib_write_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const u_int8_t *buf, bus_size_t len) -{ - volatile u_int64_t *addr = (volatile u_int64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *addr = htole64(*(u_int64_t *)buf); - buf += 8; - } -} - -int -mace_pcib_space_map(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ -#ifdef DIAGNOSTIC - if (t->bus_base == mace_pcibbus_mem_tag.bus_base) { - if (offs < MACE_PCI_MEM_OFFSET || - ((offs + size - 1) >> 32) != 0) - return EINVAL; - } else { - if (((offs + size - 1) >> 32) != 0) - return EINVAL; - } -#endif - - if (ISSET(flags, BUS_SPACE_MAP_CACHEABLE)) - offs += - PHYS_TO_XKPHYS(0, CCA_CACHED) - PHYS_TO_XKPHYS(0, CCA_NC); - *bshp = t->bus_base + offs; - return 0; -} - -void -mace_pcib_space_unmap(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t size) -{ -} - -int -mace_pcib_space_region(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ - *nbshp = bsh + offset; - return (0); -} - -void * -mace_pcib_space_vaddr(bus_space_tag_t t, bus_space_handle_t h) -{ - return (void *)h; -} - -void -mace_pcib_space_barrier(bus_space_tag_t t, bus_space_handle_t h, - bus_size_t offs, bus_size_t len, int flags) -{ - mips_sync(); -} - -/* - * Mace PCI bus_dma helpers. - * The PCI bus accesses memory contiguously at 0x00000000 onwards. - */ - -bus_addr_t -mace_pcibr_pa_to_device(paddr_t pa, int flags) -{ - return (pa & CRIME_MEMORY_MASK); -} - -/* - * PCI configuration. - */ - -void -mace_pcibr_configure(struct mace_pcibr_softc *sc) -{ - pci_chipset_tag_t pc = &sc->sc_pc; - pcitag_t tag; - pcireg_t id, bhlcr; - int dev, nfuncs; - uint nppb, npccbb; - const struct pci_quirkdata *qd; - - nppb = npccbb = 0; - for (dev = 0; dev < pci_bus_maxdevs(pc, 0); dev++) { - tag = pci_make_tag(pc, 0, dev, 0); - - id = pci_conf_read(pc, tag, PCI_ID_REG); - if (PCI_VENDOR(id) == PCI_VENDOR_INVALID || - PCI_VENDOR(id) == 0) - continue; - - bhlcr = pci_conf_read(pc, tag, PCI_BHLC_REG); - if (PCI_HDRTYPE_TYPE(bhlcr) == 1) - nppb++; - if (PCI_HDRTYPE_TYPE(bhlcr) == 2) - npccbb++; - - qd = pci_lookup_quirkdata(PCI_VENDOR(id), PCI_PRODUCT(id)); - if (PCI_HDRTYPE_MULTIFN(bhlcr) || - (qd != NULL && (qd->quirks & PCI_QUIRK_MULTIFUNCTION) != 0)) - nfuncs = 8; - else - nfuncs = 1; - - mace_pcibr_device_fixup(sc, dev, nfuncs); - } - - /* - * Since there is only one working slot, there should be only - * up to one bridge (PCI-PCI or PCI-CardBus), which we'll map - * after the on-board device resources. - */ - if (nppb + npccbb != 1) - return; - - for (dev = 0; dev < pci_bus_maxdevs(pc, 0); dev++) { - tag = pci_make_tag(pc, 0, dev, 0); - - id = pci_conf_read(pc, tag, PCI_ID_REG); - if (PCI_VENDOR(id) == PCI_VENDOR_INVALID || - PCI_VENDOR(id) == 0) - continue; - - bhlcr = pci_conf_read(pc, tag, PCI_BHLC_REG); - switch (PCI_HDRTYPE_TYPE(bhlcr)) { - case 1: - ppb_initialize(pc, tag, 0, 1, 255); - break; - case 2: - pccbb_initialize(pc, tag, 0, 1, 1); - break; - } - } -} - -void -mace_pcibr_device_fixup(struct mace_pcibr_softc *sc, int dev, int nfuncs) -{ - pci_chipset_tag_t pc = &sc->sc_pc; - pcitag_t tag; - pcireg_t csr, bhlcr, type; - int function; - int reg, reg_start, reg_end; - - for (function = 0; function < nfuncs; function++) { - tag = pci_make_tag(pc, 0, dev, function); - - bhlcr = pci_conf_read(pc, tag, PCI_BHLC_REG); - switch (PCI_HDRTYPE_TYPE(bhlcr)) { - case 0: - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_END; - break; - case 1: /* PCI-PCI bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PPB_END; - break; - case 2: /* PCI-CardBus bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PCB_END; - break; - default: - continue; - } - - /* - * The firmware will only initialize memory BARs, and only - * the lower half of them if they are 64 bit. - * So here we disable I/O space and reset the I/O BARs to 0, - * and make sure the upper part of 64 bit memory BARs is - * correct. - * Device drivers will allocate resources themselves and - * enable I/O space on an as-needed basis. - */ - csr = pci_conf_read(pc, tag, PCI_COMMAND_STATUS_REG); - pci_conf_write(pc, tag, PCI_COMMAND_STATUS_REG, - csr & ~PCI_COMMAND_IO_ENABLE); - - for (reg = reg_start; reg < reg_end; reg += 4) { - if (pci_mapreg_probe(pc, tag, reg, &type) == 0) - continue; - - switch (type) { - case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT: - reg += 4; - /* FALLTHROUGH */ - case PCI_MAPREG_TYPE_IO: - pci_conf_write(pc, tag, reg, 0); - break; - } - } - } -} - -int -mace_pcibr_ppb_setup(void *cookie, pcitag_t tag, bus_addr_t *iostart, - bus_addr_t *ioend, bus_addr_t *memstart, bus_addr_t *memend) -{ - if (*memend != 0) { - /* - * Give all resources to the bridge - * (except for the few the on-board ahc(4) will use). - */ - *memstart = 0x81000000; - *memend = 0xffffffff; - } else { - *memstart = 0xffffffff; - *memend = 0; - } - - if (*ioend != 0) { - /* - * Give all resources to the bridge - * (except for the few the on-board ahc(4) will use). - */ - *iostart = 0x00010000; - *ioend = 0xffffffff; - } else { - *iostart = 0xffffffff; - *ioend = 0; - } - - return 0; -} - -#if NCARDBUS > 0 - -static struct rb_md_fnptr mace_pcibr_rb_md_fn = { - mace_pcibr_rbus_space_map, - mace_pcibr_rbus_space_unmap -}; - -int -mace_pcibr_rbus_space_map(bus_space_tag_t t, bus_addr_t addr, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ - return bus_space_map(t, addr, size, flags, bshp); -} - -void -mace_pcibr_rbus_space_unmap(bus_space_tag_t t, bus_space_handle_t h, - bus_size_t size, bus_addr_t *addrp) -{ - bus_space_unmap(t, h, size); - /* can't simply subtract because of possible cacheability */ - *addrp = XKPHYS_TO_PHYS(h) - XKPHYS_TO_PHYS(t->bus_base); -} - -void * -mace_pcibr_rbus_parent_io(struct pci_attach_args *pa) -{ - rbus_tag_t rb; - - rb = rbus_new_root_share(pa->pa_iot, pa->pa_ioex, - 0x0000, 0xffff); - if (rb != NULL) - rb->rb_md = &mace_pcibr_rb_md_fn; - - return rb; -} - -void * -mace_pcibr_rbus_parent_mem(struct pci_attach_args *pa) -{ - rbus_tag_t rb; - - rb = rbus_new_root_share(pa->pa_memt, pa->pa_memex, - 0, 0xffffffff); - if (rb != NULL) - rb->rb_md = &mace_pcibr_rb_md_fn; - - return rb; -} - -#endif /* NCARDBUS > 0 */ diff --git a/sys/arch/sgi/pci/macepcibrvar.h b/sys/arch/sgi/pci/macepcibrvar.h deleted file mode 100644 index 4f0dd00a708..00000000000 --- a/sys/arch/sgi/pci/macepcibrvar.h +++ /dev/null @@ -1,85 +0,0 @@ -/* $OpenBSD: macepcibrvar.h,v 1.6 2009/07/22 20:28:21 miod Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se) - * - * 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 ``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 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. - * - */ - -#ifndef _PCIBRVAR_H_ -#define _PCIBRVAR_H_ - -/* - * Addresses of the PCI I/O and memory spaces. - * - * Note that PCI memory space addresses need to have bit 31 set to - * reach hardware, otherwise they reach physical memory. - */ -#define MACE_PCI_IO_BASE 0x100000000UL -#define MACE_PCI_MEM_BASE 0x200000000UL -#define MACE_PCI_MEM_OFFSET 0x80000000 -#define MACE_PCI_MEM_SIZE 0x80000000 - -struct mace_pcibr_softc { - struct device sc_dev; - struct mips_bus_space *sc_mem_bus_space; - struct mips_bus_space *sc_io_bus_space; - struct mips_pci_chipset sc_pc; - bus_space_tag_t sc_memt; - bus_space_handle_t sc_memh; -}; - -u_int8_t mace_pcib_read_1(bus_space_tag_t, bus_space_handle_t, bus_size_t); -u_int16_t mace_pcib_read_2(bus_space_tag_t, bus_space_handle_t, bus_size_t); -u_int32_t mace_pcib_read_4(bus_space_tag_t, bus_space_handle_t, bus_size_t); -u_int64_t mace_pcib_read_8(bus_space_tag_t, bus_space_handle_t, bus_size_t); - -void mace_pcib_write_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int8_t); -void mace_pcib_write_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int16_t); -void mace_pcib_write_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int32_t); -void mace_pcib_write_8(bus_space_tag_t, bus_space_handle_t, bus_size_t, - u_int64_t); - -void mace_pcib_read_raw_2(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, u_int8_t *, bus_size_t); -void mace_pcib_write_raw_2(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, const u_int8_t *, bus_size_t); -void mace_pcib_read_raw_4(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, u_int8_t *, bus_size_t); -void mace_pcib_write_raw_4(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, const u_int8_t *, bus_size_t); -void mace_pcib_read_raw_8(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, u_int8_t *, bus_size_t); -void mace_pcib_write_raw_8(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, const u_int8_t *, bus_size_t); - -int mace_pcib_space_map(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -void mace_pcib_space_unmap(bus_space_tag_t, bus_space_handle_t, bus_size_t); -int mace_pcib_space_region(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, bus_space_handle_t *); - -#endif diff --git a/sys/arch/sgi/pci/pci_machdep.c b/sys/arch/sgi/pci/pci_machdep.c deleted file mode 100644 index 3220e7224a1..00000000000 --- a/sys/arch/sgi/pci/pci_machdep.c +++ /dev/null @@ -1,283 +0,0 @@ -/* $OpenBSD: pci_machdep.c,v 1.5 2009/07/23 19:24:30 miod Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/extent.h> - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcivar.h> -#include <dev/pci/pccbbreg.h> -#include <dev/pci/ppbreg.h> -#include <dev/pci/pcidevs.h> - -void ppb_device_explore(pci_chipset_tag_t, uint, int, int, struct extent *, - struct extent *); -void ppb_function_explore(pci_chipset_tag_t, pcitag_t, struct extent *, - struct extent *); - -/* - * Configure a PCI-PCI bridge. - */ -void -ppb_initialize(pci_chipset_tag_t pc, pcitag_t ppbtag, uint primary, - uint secondary, uint subordinate) -{ - int dev, nfuncs; - pcireg_t id, csr, bhlcr; - pcitag_t tag; - const struct pci_quirkdata *qd; - bus_addr_t iostart, ioend, memstart, memend; - struct extent *ioex, *memex; - struct extent_region *region; - - /* - * In a first pass, enable access to the configuration space, - * and figure out what resources the devices behind it will - * need. - * - * Note that, doing this, we do not intend to support any - * hotplug capabilities. This should not be a problem on - * sgi. - */ - - csr = pci_conf_read(pc, ppbtag, PCI_COMMAND_STATUS_REG); - csr &= ~(PCI_COMMAND_IO_ENABLE | PCI_COMMAND_MEM_ENABLE); - pci_conf_write(pc, ppbtag, PCI_COMMAND_STATUS_REG, csr); - - pci_conf_write(pc, ppbtag, PPB_REG_BUSINFO, - primary | (secondary << 8) | (subordinate << 16)); - - ioex = extent_create("ppb_io", 0, 0xffffffff, - M_DEVBUF, NULL, 0, EX_NOWAIT); - memex = extent_create("ppb_mem", 0, 0xffffffff, - M_DEVBUF, NULL, 0, EX_NOWAIT); - - for (dev = 0; dev < pci_bus_maxdevs(pc, secondary); dev++) { - tag = pci_make_tag(pc, secondary, dev, 0); - id = pci_conf_read(pc, tag, PCI_ID_REG); - - if (PCI_VENDOR(id) == PCI_VENDOR_INVALID || - PCI_VENDOR(id) == 0) - continue; - - bhlcr = pci_conf_read(pc, tag, PCI_BHLC_REG); - qd = pci_lookup_quirkdata(PCI_VENDOR(id), PCI_PRODUCT(id)); - if (PCI_HDRTYPE_MULTIFN(bhlcr) || - (qd != NULL && (qd->quirks & PCI_QUIRK_MULTIFUNCTION) != 0)) - nfuncs = 8; - else - nfuncs = 1; - - ppb_device_explore(pc, secondary, dev, nfuncs, ioex, memex); - } - - /* - * Now figure out the size of the resources we need... - */ - - iostart = memstart = 0xffffffff; - ioend = memend = 0; - - if (ioex != NULL) { - LIST_FOREACH(region, &ioex->ex_regions, er_link) { - if (region->er_start < iostart) - iostart = region->er_start; - if (region->er_end > ioend) - ioend = region->er_end; - } - extent_destroy(ioex); - } - if (memex != NULL) { - LIST_FOREACH(region, &memex->ex_regions, er_link) { - if (region->er_start < memstart) - memstart = region->er_start; - if (region->er_end > memend) - memend = region->er_end; - } - extent_destroy(memex); - } - - /* - * ... and ask the bridge to setup resources for them. - */ - - if (pc->pc_ppb_setup == NULL || (*pc->pc_ppb_setup)(pc->pc_conf_v, - ppbtag, &iostart, &ioend, &memstart, &memend) != 0) { - iostart = memstart = 0xffffffff; - ioend = memend = 0; - } - - pci_conf_write(pc, ppbtag, PPB_REG_MEM, - ((memstart & 0xfff00000) >> 16) | (memend & 0xfff00000)); - pci_conf_write(pc, ppbtag, PPB_REG_IOSTATUS, - (pci_conf_read(pc, ppbtag, PPB_REG_IOSTATUS) & 0xffff0000) | - ((iostart & 0x0000f000) >> 8) | (ioend & 0x0000f000)); - pci_conf_write(pc, ppbtag, PPB_REG_IO_HI, - ((iostart & 0xffff0000) >> 16) | (ioend & 0xffff0000)); - pci_conf_write(pc, ppbtag, PPB_REG_PREFMEM, 0x0000fff0); - pci_conf_write(pc, ppbtag, PPB_REG_PREFBASE_HI32, 0); - pci_conf_write(pc, ppbtag, PPB_REG_PREFLIM_HI32, 0); - - if (iostart <= ioend) - csr |= PCI_COMMAND_IO_ENABLE; - if (memstart <= memend) - csr |= PCI_COMMAND_MEM_ENABLE; - - pci_conf_write(pc, ppbtag, PCI_COMMAND_STATUS_REG, csr | - PCI_COMMAND_MASTER_ENABLE | PCI_COMMAND_INVALIDATE_ENABLE | - PCI_COMMAND_SERR_ENABLE); -} - -/* - * Figure out what resources a device behind a bridge would need and - * disable them. - */ -void -ppb_device_explore(pci_chipset_tag_t pc, uint bus, int dev, int nfuncs, - struct extent *ioex, struct extent *memex) -{ - pcitag_t tag; - pcireg_t id; - int function; - - for (function = 0; function < nfuncs; function++) { - tag = pci_make_tag(pc, bus, dev, function); - - id = pci_conf_read(pc, tag, PCI_ID_REG); - if (PCI_VENDOR(id) == PCI_VENDOR_INVALID || - PCI_VENDOR(id) == 0) - continue; - - ppb_function_explore(pc, tag, ioex, memex); - } -} - -/* - * Figure out what resources a device function would need and - * disable them. - */ -void -ppb_function_explore(pci_chipset_tag_t pc, pcitag_t tag, struct extent *ioex, - struct extent *memex) -{ - bus_addr_t base; - bus_size_t size; - int reg, reg_start, reg_end, reg_rom; - pcireg_t csr, bhlcr, type, mask; - - csr = pci_conf_read(pc, tag, PCI_COMMAND_STATUS_REG); - pci_conf_write(pc, tag, PCI_COMMAND_STATUS_REG, csr & - ~(PCI_COMMAND_IO_ENABLE | PCI_COMMAND_MEM_ENABLE)); - - bhlcr = pci_conf_read(pc, tag, PCI_BHLC_REG); - switch (PCI_HDRTYPE_TYPE(bhlcr)) { - case 0: - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_END; - reg_rom = PCI_ROM_REG; - break; - case 1: /* PCI-PCI bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PPB_END; - reg_rom = 0; /* 0x38 */ - break; - case 2: /* PCI-Cardbus bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PCB_END; - reg_rom = 0; - break; - default: - return; - } - - for (reg = reg_start; reg < reg_end; reg += 4) { - if (pci_mapreg_probe(pc, tag, reg, &type) == 0) - continue; - - if (pci_mapreg_info(pc, tag, reg, type, &base, &size, NULL)) - continue; - - switch (type) { - case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT: - pci_conf_write(pc, tag, reg + 4, 0); - /* FALLTHROUGH */ - case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_32BIT: - if (memex != NULL) - (void)extent_alloc(memex, size, size, 0, 0, 0, - &base); - break; - case PCI_MAPREG_TYPE_IO: - if (ioex != NULL) - (void)extent_alloc(ioex, size, size, 0, 0, 0, - &base); - break; - } - - pci_conf_write(pc, tag, reg, 0); - - if (type == (PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT)) - reg += 4; - } - - if (reg_rom != 0) { - pci_conf_write(pc, tag, reg_rom, ~PCI_ROM_ENABLE); - mask = pci_conf_read(pc, tag, reg_rom); - size = PCI_ROM_SIZE(mask); - - if (size != 0) { - if (memex != NULL) - (void)extent_alloc(memex, size, size, 0, 0, 0, - &base); - } - - pci_conf_write(pc, tag, reg_rom, 0); - } - - /* - * Note that we do not try to be recursive and configure PCI-PCI - * bridges behind PCI-PCI bridges. - */ -} - -/* - * Configure a PCI-CardBus bridge. - */ -void -pccbb_initialize(pci_chipset_tag_t pc, pcitag_t tag, uint primary, - uint secondary, uint subordinate) -{ - pcireg_t csr; - - csr = pci_conf_read(pc, tag, PCI_COMMAND_STATUS_REG); - csr &= ~(PCI_COMMAND_IO_ENABLE | PCI_COMMAND_MEM_ENABLE); - pci_conf_write(pc, tag, PCI_COMMAND_STATUS_REG, csr); - - pci_conf_write(pc, tag, PCI_BUSNUM, - primary | (secondary << 8) | (subordinate << 16)); - -#if 0 /* done by pccbb(4) */ - csr |= PCI_COMMAND_IO_ENABLE; - csr |= PCI_COMMAND_MEM_ENABLE; - - pci_conf_write(pc, tag, PCI_COMMAND_STATUS_REG, csr | - PCI_COMMAND_MASTER_ENABLE); -#endif -} diff --git a/sys/arch/sgi/pci/pci_machdep.h b/sys/arch/sgi/pci/pci_machdep.h deleted file mode 100644 index 3c656596bb6..00000000000 --- a/sys/arch/sgi/pci/pci_machdep.h +++ /dev/null @@ -1,123 +0,0 @@ -/* $OpenBSD: pci_machdep.h,v 1.17 2016/05/04 14:30:01 kettenis Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ -typedef struct mips_pci_chipset *pci_chipset_tag_t; -typedef u_long pcitag_t; -typedef u_long pci_intr_handle_t; - -struct pci_attach_args; -struct sgi_device_location; - -/* - * mips-specific PCI structure and type definitions. - * NOT TO BE USED DIRECTLY BY MACHINE INDEPENDENT CODE. - */ -struct mips_pci_chipset { - void *pc_conf_v; - void (*pc_attach_hook)(struct device *, - struct device *, struct pcibus_attach_args *); - int (*pc_bus_maxdevs)(void *, int); - pcitag_t (*pc_make_tag)(void *, int, int, int); - void (*pc_decompose_tag)(void *, pcitag_t, int *, - int *, int *); - int (*pc_conf_size)(void *, pcitag_t); - pcireg_t (*pc_conf_read)(void *, pcitag_t, int); - void (*pc_conf_write)(void *, pcitag_t, int, pcireg_t); - int (*pc_probe_device_hook)(void *, struct pci_attach_args *); - - int (*pc_get_widget)(void *); - int (*pc_get_dl)(void *, pcitag_t, struct sgi_device_location *); - - void *pc_intr_v; - int (*pc_intr_map)(struct pci_attach_args *, pci_intr_handle_t *); - const char *(*pc_intr_string)(void *, pci_intr_handle_t); - void *(*pc_intr_establish)(void *, pci_intr_handle_t, - int, int (*)(void *), void *, const char *); - void (*pc_intr_disestablish)(void *, void *); - int (*pc_intr_line)(void *, pci_intr_handle_t); - - int (*pc_ppb_setup)(void *, pcitag_t, bus_addr_t *, bus_addr_t *, - bus_addr_t *, bus_addr_t *); - - void *(*pc_rbus_parent_io)(struct pci_attach_args *); - void *(*pc_rbus_parent_mem)(struct pci_attach_args *); -}; - -/* - * Functions provided to machine-independent PCI code. - */ -#define pci_attach_hook(p, s, pba) \ - (*(pba)->pba_pc->pc_attach_hook)((p), (s), (pba)) -#define pci_bus_maxdevs(c, b) \ - (*(c)->pc_bus_maxdevs)((c)->pc_conf_v, (b)) -#define pci_make_tag(c, b, d, f) \ - (*(c)->pc_make_tag)((c)->pc_conf_v, (b), (d), (f)) -#define pci_decompose_tag(c, t, bp, dp, fp) \ - (*(c)->pc_decompose_tag)((c)->pc_conf_v, (t), (bp), (dp), (fp)) -#define pci_conf_size(c, t) \ - (*(c)->pc_conf_size)((c)->pc_conf_v, (t)) -#define pci_conf_read(c, t, r) \ - (*(c)->pc_conf_read)((c)->pc_conf_v, (t), (r)) -#define pci_conf_write(c, t, r, v) \ - (*(c)->pc_conf_write)((c)->pc_conf_v, (t), (r), (v)) -#define pci_intr_map(c, ihp) \ - (*(c)->pa_pc->pc_intr_map)((c), (ihp)) -#define pci_intr_map_msi(c, ihp) (-1) -#define pci_intr_map_msix(c, vec, ihp) (-1) -#define pci_intr_string(c, ih) \ - (*(c)->pc_intr_string)((c)->pc_intr_v, (ih)) -#define pci_intr_establish(c, ih, l, h, a, nm) \ - (*(c)->pc_intr_establish)((c)->pc_intr_v, (ih), (l), (h), (a), (nm)) -#define pci_intr_disestablish(c, iv) \ - (*(c)->pc_intr_disestablish)((c)->pc_intr_v, (iv)) -#define pci_intr_line(c, ih) \ - (*(c)->pc_intr_line)((c)->pc_intr_v, (ih)) -#define pci_probe_device_hook(c, a) \ - (*(c)->pc_probe_device_hook)((c)->pc_conf_v, (a)) -#define pci_dev_postattach(a, b) do { } while (0) - -#define pci_min_powerstate(c, t) (PCI_PMCSR_STATE_D3) -#define pci_set_powerstate_md(c, t, s, p) - -/* - * Functions provided to machine-dependent PCI code. - */ -#define pci_get_widget(c) \ - (*(c)->pc_get_widget)((c)->pc_conf_v) -#define pci_get_device_location(c,t,l) \ - (*(c)->pc_get_dl)((c)->pc_conf_v, (t), (l)) - -/* - * Functions provided to machine-independent rbus code. - */ -#define rbus_pccbb_parent_io(dev, pa) \ - (rbus_tag_t)((*(pa)->pa_pc->pc_rbus_parent_io)(pa)) -#define rbus_pccbb_parent_mem(dev, pa) \ - (rbus_tag_t)((*(pa)->pa_pc->pc_rbus_parent_mem)(pa)) - -void pccbb_initialize(pci_chipset_tag_t, pcitag_t, uint, uint, uint); -void ppb_initialize(pci_chipset_tag_t, pcitag_t, uint, uint, uint); diff --git a/sys/arch/sgi/sgi/autoconf.c b/sys/arch/sgi/sgi/autoconf.c deleted file mode 100644 index 55e24fec74c..00000000000 --- a/sys/arch/sgi/sgi/autoconf.c +++ /dev/null @@ -1,873 +0,0 @@ -/* $OpenBSD: autoconf.c,v 1.43 2018/01/27 22:55:23 naddy Exp $ */ -/* - * Copyright (c) 2009, 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ -/* - * Copyright (c) 1996 Per Fogelstrom - * Copyright (c) 1995 Theo de Raadt - * Copyright (c) 1988 University of Utah. - * Copyright (c) 1992, 1993 - * The Regents of the University of California. All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * the Systems Programming Group of the University of Utah Computer - * Science Department and Ralph Campbell. - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Berkeley and its contributors. - * 4. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - */ - -/* - * Setup the system to run on the current machine. - * - * cpu_configure() is called at boot time. Available - * devices are determined (from possibilities mentioned in ioconf.c), - * and the drivers are initialized. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/buf.h> -#include <sys/conf.h> -#include <sys/reboot.h> -#include <sys/device.h> - -#include <machine/autoconf.h> -#include <machine/memconf.h> - -#include <mips64/arcbios.h> -#include <mips64/archtype.h> - -#include <uvm/uvm_extern.h> - -#ifdef TGT_ORIGIN -#include <machine/mnode.h> -#endif -#ifdef TGT_OCTANE -#include <sgi/sgi/ip30.h> -#endif -#include <sgi/xbow/xbow.h> -#include <dev/pci/pcivar.h> -#include <scsi/scsi_all.h> -#include <scsi/scsiconf.h> - -extern void dumpconf(void); - -static u_long strtoul(const char *, int, const char **); - -/* - * The following several variables are related to - * the configuration process, and are used in initializing - * the machine. - */ -int cold = 1; /* if 1, still working on cold-start */ -struct device *bootdv = NULL; -int16_t currentnasid = 0; - -char osloadpartition[256]; -char osloadoptions[129]; - -/* - * Configure all devices found that we know about. - * This is done at boot time. - */ -void -cpu_configure(void) -{ - (void)splhigh(); /* Set mask to what we intend. */ - - softintr_init(); - - if (config_rootfound("mainbus", "mainbus") == 0) { - panic("no mainbus found"); - } - - unmap_startup(); - - splinit(); /* Initialized, fire up interrupt system */ - cold = 0; -} - -void -diskconf(void) -{ - if (bootdv == NULL) - printf("boot device: '%s' unrecognized.\n", osloadpartition); - else - printf("boot device: %s\n", bootdv->dv_xname); - - setroot(bootdv, 0, RB_USERREQ); - dumpconf(); -} - -/* - * Register a memory region. - */ -int -memrange_register(uint64_t startpfn, uint64_t endpfn, uint64_t bmask) -{ - struct phys_mem_desc *cur, *m = NULL; - int i; - -#ifdef DEBUG -{ - extern int console_ok; - - if (console_ok) - printf("%s: memory from 0x%lx to 0x%lx\n", - __func__, ptoa(startpfn), ptoa(endpfn)); - else - bios_printf("%s: memory from 0x%lx to 0x%lx\n", - __func__, ptoa(startpfn), ptoa(endpfn)); -} -#endif - physmem += endpfn - startpfn; - -#ifdef TGT_OCTANE - /* - * On Octane, the second 16KB page is reserved for the NMI handler. - */ - if (sys_config.system_type == SGI_OCTANE && - startpfn < atop(IP30_MEMORY_BASE) + 2) { - startpfn = atop(IP30_MEMORY_BASE) + 2; - if (startpfn >= endpfn) - return 0; - } -#endif - - /* - * Prevent use of memory beyond what pmap can support. - * PG_FRAME is the highest supported page number. - */ - if (startpfn > atop(pfn_to_pad(PG_FRAME))) - return 0; - if (endpfn > atop(pfn_to_pad(PG_FRAME))) - endpfn = 1 + atop(pfn_to_pad(PG_FRAME)); - - for (i = 0, cur = mem_layout; i < MAXMEMSEGS; i++, cur++) { - if (cur->mem_last_page == 0) { - if (m == NULL) - m = cur; /* first free segment */ - continue; - } - /* merge contiguous areas */ - if (cur->mem_first_page == endpfn && - ((cur->mem_last_page ^ startpfn) & bmask) == 0) { - cur->mem_first_page = startpfn; - return 0; - } - if (cur->mem_last_page == startpfn && - ((cur->mem_first_page ^ endpfn) & bmask) == 0) { - cur->mem_last_page = endpfn; - return 0; - } - } - - if (m == NULL) - return ENOMEM; - - m->mem_first_page = startpfn; - m->mem_last_page = endpfn; - return 0; -} - -void (*_device_register)(struct device *, void *); - -void -device_register(struct device *dev, void *aux) -{ - if (_device_register) - (*_device_register)(dev, aux); -} - -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) || \ - defined(TGT_O2) || defined(TGT_OCTANE) - -/* - * ARCS boot path traversal - */ - -const char *bootpath_get(int *); -void bootpath_init(void); -void bootpath_next(void); - -static char bootpath_store[sizeof osloadpartition]; -static char *bootpath_curpos; -static char *bootpath_lastpos; -static int bootpath_lastunit; - -/* - * Initialize bootpath analysis. - */ -void -bootpath_init() -{ - strlcpy(bootpath_store, osloadpartition, sizeof bootpath_store); - bootpath_curpos = bootpath_store; -} - -/* - * Extract a component of the boot path, and return its name and unit - * value. - */ -const char * -bootpath_get(int *u) -{ - char *c; - int unit; - - /* - * If we don't have a value in cache, compute it. - */ - if (bootpath_lastpos == NULL) { - if (bootpath_curpos == NULL) - bootpath_init(); - - unit = 0; - c = strchr(bootpath_curpos, '('); - if (c != NULL) { - for (*c++ = '\0'; *c >= '0' && *c <= '9'; c++) - unit = 10 * unit + (*c - '0'); - while (*c != ')' && *c != '\0') - c++; - if (*c == ')') - c++; - } else { - c = bootpath_curpos + strlen(bootpath_curpos); - } - - bootpath_lastpos = bootpath_curpos; - bootpath_lastunit = unit; - bootpath_curpos = c; -#ifdef DEBUG - printf("%s: new component %s unit %d remainder %s\n", __func__, - bootpath_lastpos, bootpath_lastunit, bootpath_curpos); -#endif - } - - *u = bootpath_lastunit; - return bootpath_lastpos; -} - -/* - * Consume the current component of the bootpath, and switch to the next. - */ -void -bootpath_next() -{ - /* force bootpath_get to go forward */ - bootpath_lastpos = NULL; -#ifdef DEBUG - printf("%s\n", __func__); -#endif -} - -void -arcs_device_register(struct device *dev, void *aux) -{ - static struct device *lastparent = NULL; -#if defined(TGT_O2) || defined(TGT_OCTANE) - static struct device *pciparent = NULL; -#endif -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) - static struct device *wdscparent = NULL; -#endif - static int component_pos = 0; - - struct device *parent = dev->dv_parent; - struct cfdata *cf = dev->dv_cfdata; - struct cfdriver *cd = cf->cf_driver; - - const char *component; - int unit; - - if (parent == NULL) - return; /* one of the @root devices */ - - if (bootdv != NULL) - return; - - component = bootpath_get(&unit); - if (*component == '\0') - return; /* exhausted path */ - - /* - * The matching rules are as follows: - * xio() matches xbow. - * pci() matches any pci controller (macepcibr, xbridge), with the - * unit number being ignored on O2 and the widget number of the - * controller elsewhere. - * scsi() matches any pci scsi controller, with the unit number - * being the pci device number (minus one on the O2, grr). - * disk() and cdrom() match sd and cd, respectively, with the - * unit number being the target number. - * - * When a disk is found, we stop the parsing; rdisk() and - * partition() components are ignored. - */ - -#ifdef TGT_OCTANE - if (strcmp(component, "xio") == 0) { - struct mainbus_attach_args *maa = aux; - - if (strcmp(cd->cd_name, "xbow") == 0 && unit == maa->maa_nasid) - goto found_advance; - } -#endif - -#if defined(TGT_O2) || defined(TGT_OCTANE) - if (strcmp(component, "pci") == 0) { - /* - * We'll work in two steps. The controller itself will be - * recognized with its parent device and attachment - * arguments (if necessary). - * - * Then we'll only advance the bootpath when matching the - * pci device. - */ - if (strcmp(cd->cd_name, "pci") == 0 && - parent == lastparent) { - pciparent = dev; - goto found_advance; - } - -#ifdef TGT_O2 - if (strcmp(cd->cd_name, "macepcibr") == 0) - goto found; -#endif -#ifdef TGT_OCTANE - if (strcmp(cd->cd_name, "xbridge") == 0 && - parent == lastparent) { - struct xbow_attach_args *xaa = aux; - - if (unit == xaa->xaa_widget) - goto found; - } - if (strcmp(cd->cd_name, "xbpci") == 0 && - parent == lastparent) { - goto found; - } -#endif - } -#endif /* TGT_O2 || TGT_OCTANE */ - - if (strcmp(component, "scsi") == 0) { - /* - * We'll work in two steps. The controller itself will be - * recognized with its parent device and pci_attach_args - * need to match the scsi() unit number. - * - * Then we'll only advance the bootpath when matching the - * scsibus device. - */ - - if (strcmp(cd->cd_name, "scsibus") == 0) { - if (parent == lastparent) - goto found_advance; - - if (component_pos == 0) - switch (sys_config.system_type) { -#ifdef TGT_O2 - /* - * On O2, the pci(0) component may be omitted from - * the bootpath, in which case we fake the missing - * pci(0) component. - */ - case SGI_O2: - if (parent->dv_parent != NULL && - strcmp(parent->dv_parent->dv_cfdata->cf_driver->cd_name, - "pci") == 0) { - pciparent = parent->dv_parent; - goto found_advance; - } - break; -#endif -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) - /* - * On Ind{igo,y,igo^2} systems, the bootpath - * starts at scsi(). - */ - case SGI_IP20: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - if (strcmp(parent->dv_cfdata->cf_driver->cd_name, - "wdsc") == 0 && - parent->dv_parent != NULL && - strcmp(parent->dv_parent->dv_cfdata->cf_driver->cd_name, - "hpc") == 0) { - wdscparent = parent; - goto found_advance; - } - break; -#endif - default: - break; - } - } - - if (parent == lastparent) { -#if defined(TGT_O2) || defined(TGT_OCTANE) - if (parent == pciparent) { - struct pci_attach_args *paa = aux; - - if (unit == paa->pa_device - - (sys_config.system_type == SGI_O2 ? 1 : 0)) - goto found; - } else -#endif -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) - if (parent == wdscparent) { - /* XXX is there any better information to use - XXX than the attachment number? */ - if (unit == parent->dv_unit) - goto found; - } else -#endif - { - /* - * in case scsi() can follow something else then - * pci(), write code to handle this here... - */ - } - } - } - - if ((strcmp(component, "disk") == 0 && - strcmp(cd->cd_name, "sd") == 0) || - (strcmp(component, "cdrom") == 0 && - strcmp(cd->cd_name, "cd") == 0)) { - if (parent == lastparent) { - struct scsi_attach_args *saa = aux; - - if (unit == saa->sa_sc_link->target) { - /* - * We found our boot device. - * Now get the partition number. - */ - bootdv = dev; -#ifdef DEBUG - printf("%s: boot device is %s\n", - __func__, dev->dv_xname); -#endif - return; - } - } - } - - if (strcmp(component, "bootp") == 0 && cd->cd_class == DV_IFNET) { -#ifdef TGT_OCTANE - if (strcmp(cd->cd_name, "iec") == 0) - bootdv = dev; -#endif -#ifdef TGT_O2 - if (strcmp(cd->cd_name, "mec") == 0) - bootdv = dev; -#endif -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) - if (strcmp(cd->cd_name, "sq") == 0) - bootdv = dev; -#endif -#ifdef DEBUG - if (bootdv != NULL) - printf("%s: boot device is %s\n", - __func__, dev->dv_xname); -#endif - return; - } - - return; - -found_advance: - bootpath_next(); - component_pos++; -found: - lastparent = dev; -} - -#endif /* IP20/22/24/26/28/30/32 */ - -#ifdef TGT_ORIGIN - -/* - * Origin (dksc) boot path analysis - */ - -void dksc_init(void); -int dksc_scan_board(lboard_t *, void *); -int dksc_scan_cmp(klinfo_t *, void *); - -static struct sgi_device_location dksc_device; -static int dksc_ctrl, dksc_unit; -static const char *dksc_devname; - -void -dksc_init() -{ - int val[3], idx; - char *c = NULL; - - if (strncmp(osloadpartition, "dksc(", 5) == 0) { - c = osloadpartition + 5; - dksc_devname = "sd"; - } else if (strncmp(osloadpartition, "cdrom(", 6) == 0) { - c = osloadpartition + 6; - dksc_devname = "cd"; - } - - if (c == NULL) - return; - - val[0] = val[1] = val[2] = 0; - idx = 0; - - for (; *c != '\0'; c++) { - if (*c == ')') - break; - else if (*c == ',') { - if (++idx == 3) - break; - } else if (*c >= '0' && *c <= '9') - val[idx] = 10 * val[idx] + (*c - '0'); - } - - dksc_ctrl = val[0]; - dksc_unit = val[1]; - - /* - * Walk kl configuration and try to match the boot controller - * with a component. - */ - kl_scan_all_nodes(KLBRD_ANY, dksc_scan_board, NULL); -} - -int -dksc_scan_board(lboard_t *brd, void *arg) -{ - kl_scan_board(brd, KLSTRUCT_ANY, dksc_scan_cmp, arg); - return 0; -} - -int -dksc_scan_cmp(klinfo_t *cmp, void *arg) -{ - klscctl_t *scsi2comp; - klscsi_t *scsicomp; - int i; - - /* bail out quickly if no controller number */ - if (cmp->virtid < 0) - return 0; - - switch (cmp->struct_type) { - case KLSTRUCT_SCSI: - case KLSTRUCT_FIBERCHANNEL: - case KLSTRUCT_QLFIBRE: - case KLSTRUCT_FIREWIRE: -#if 0 /* should not get controller numbers anyway */ - case KLSTRUCT_IDE: - case KLSTRUCT_IOC4_ATA: -#endif - if (cmp->virtid == dksc_ctrl) { - kl_get_location(cmp, &dksc_device); - return 1; - } - break; - case KLSTRUCT_SCSI2: - /* - * Figure out whether one of the two ports matches our - * controller number. - */ - scsi2comp = (klscctl_t *)cmp; - for (i = 0; i < scsi2comp->scsi_buscnt; i++) { - scsicomp = (klscsi_t *)scsi2comp->scsi_bus[i]; - if (scsicomp == NULL) - continue; - if (scsicomp->scsi_info.virtid == dksc_ctrl) { - kl_get_location(cmp, &dksc_device); - dksc_device.specific = i; /* port # */ - return 1; - } - } - break; - } - - return 0; -} - -void -dksc_device_register(struct device *dev, void *aux) -{ - static int dksc_state = 0; - static struct device *controller = NULL; - static struct device *scsibus = NULL; - - struct device *parent = dev->dv_parent; - struct cfdata *cf = dev->dv_cfdata; - struct cfdriver *cd = cf->cf_driver; - - struct sgi_device_location dl; - - if (dksc_state == 0) { - dksc_state = 1; - dksc_init(); - } - - if (parent == NULL) - return; /* one of the @root devices */ - - if (bootdv != NULL) - return; - - /* - * If we already know our bus, try to match the correct device. - */ - if (scsibus != NULL) { - if (strcmp(cd->cd_name, dksc_devname) == 0) { - struct scsi_attach_args *saa = aux; - if (dksc_unit == saa->sa_sc_link->target) - bootdv = dev; - } - return; - } - - /* - * If we already know our controller driver, try to match the - * correct scsibus. - */ - if (controller != NULL) { - if (parent == controller && - strcmp(cd->cd_name, "scsibus") == 0) { - /* only match on the required bus */ - if (dksc_device.specific == 0) - scsibus = dev; - else - dksc_device.specific--; - } - return; - } - - /* - * If we are investigating a PCI bus, check whether the current - * device may be the controller we are looking for. - */ - - if (strcmp(parent->dv_cfdata->cf_driver->cd_name, "pci") == 0) { - struct pci_attach_args *paa = aux; - if (pci_get_device_location(paa->pa_pc, paa->pa_tag, &dl) && - location_match(&dksc_device, &dl)) - controller = dev; - return; - } -} - -#endif /* IP27/35 */ - -struct nam2blk nam2blk[] = { - { "sd", 0 }, - { "vnd", 2 }, - { "cd", 3 }, - { "wd", 4 }, - { "rd", 8 }, - { NULL, -1 } -}; - -/* - * Convert "xx:xx:xx:xx:xx:xx" string to Ethernet hardware address. - */ -void -enaddr_aton(const char *s, u_int8_t *a) -{ - int i; - - if (s != NULL) { - for (i = 0; i < 6; i++) { - a[i] = strtoul(s, 16, &s); - if (*s == ':') - s++; - } - } -} - -/* - * Get a numeric environment variable - */ -u_long -bios_getenvint(const char *name) -{ - const char *envvar; - u_long value; - - envvar = Bios_GetEnvironmentVariable(name); - if (envvar != NULL) { - value = strtoul(envvar, 10, &envvar); - if (*envvar != '\0') - value = 0; - } else - value = 0; - - return value; -} - -/* - * Convert an ASCII string into an integer. - */ -static u_long -strtoul(const char *s, int b, const char **o) -{ - int c; - unsigned base = b, d; - int neg = 0; - u_long val = 0; - - if (s == NULL || *s == 0) { - if (o != NULL) - *o = s; - return 0; - } - - /* Skip spaces if any. */ - do { - c = *s++; - } while (c == ' ' || c == '\t'); - - /* Parse sign, allow more than one (compat). */ - while (c == '-') { - neg = !neg; - c = *s++; - } - - /* Parse base specification, if any. */ - if (base == 0 && c == '0') { - c = *s++; - switch (c) { - case 'X': - case 'x': - base = 16; - c = *s++; - break; - case 'B': - case 'b': - base = 2; - c = *s++; - break; - default: - base = 8; - } - } - - /* Parse number proper. */ - for (;;) { - if (c >= '0' && c <= '9') - d = c - '0'; - else if (c >= 'a' && c <= 'z') - d = c - 'a' + 10; - else if (c >= 'A' && c <= 'Z') - d = c - 'A' + 10; - else - break; - if (d >= base) - break; - val *= base; - val += d; - c = *s++; - } - if (neg) - val = -val; - if (o != NULL) - *o = s - 1; - return val; -} - -/* - * Relaxed comparison of two devices' physical location. - */ -int -location_match(struct sgi_device_location *l1, struct sgi_device_location *l2) -{ - /* must be on the same widget */ - if (l1->nasid != l2->nasid || l1->widget != l2->widget) - return 0; - - /* must be on the same PCI bus, if applicable */ - if (l1->bus == -1 || l2->bus == -1) - return 1; - if (l1->bus != l2->bus) - return 0; - - /* must be the same PCI device, if applicable */ - if (l1->device == -1 || l2->device == -1) - return 1; - if (l1->device != l2->device) - return 0; - - /* must be the same PCI function, if applicable */ - if (l1->fn == -1 || l2->fn == -1) - return 1; - if (l1->fn != l2->fn) - return 0; - - return 1; -} diff --git a/sys/arch/sgi/sgi/bus_dma.c b/sys/arch/sgi/sgi/bus_dma.c deleted file mode 100644 index e1dd64859a8..00000000000 --- a/sys/arch/sgi/sgi/bus_dma.c +++ /dev/null @@ -1,757 +0,0 @@ -/* $OpenBSD: bus_dma.c,v 1.43 2019/12/20 13:34:41 visa Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ -/*- - * Copyright (c) 1996, 1997, 1998 The NetBSD Foundation, Inc. - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility, - * NASA Ames Research Center. - * - * 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. - */ -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/proc.h> -#include <sys/malloc.h> -#include <sys/mbuf.h> - -#include <uvm/uvm_extern.h> - -#include <mips64/cache.h> -#include <machine/cpu.h> - -#include <machine/bus.h> - -#if defined(TGT_INDY) || defined(TGT_INDIGO2) -#include <sgi/sgi/ip22.h> -#endif - -/* - * Common function for DMA map creation. May be called by bus-specific - * DMA map creation functions. - */ -int -_dmamap_create(bus_dma_tag_t t, bus_size_t size, int nsegments, - bus_size_t maxsegsz, bus_size_t boundary, int flags, bus_dmamap_t *dmamp) -{ - struct machine_bus_dmamap *map; - void *mapstore; - size_t mapsize; - - /* - * Allocate and initialize the DMA map. The end of the map - * is a variable-sized array of segments, so we allocate enough - * room for them in one shot. - * - * Note we don't preserve the WAITOK or NOWAIT flags. Preservation - * of ALLOCNOW notifies others that we've reserved these resources, - * and they are not to be freed. - * - * The bus_dmamap_t includes one bus_dma_segment_t, hence - * the (nsegments - 1). - */ - mapsize = sizeof(struct machine_bus_dmamap) + - (sizeof(bus_dma_segment_t) * (nsegments - 1)); - if ((mapstore = malloc(mapsize, M_DEVBUF, (flags & BUS_DMA_NOWAIT) ? - (M_NOWAIT | M_ZERO) : (M_WAITOK | M_ZERO))) == NULL) - return (ENOMEM); - - map = (struct machine_bus_dmamap *)mapstore; - map->_dm_size = size; - map->_dm_segcnt = nsegments; - map->_dm_maxsegsz = maxsegsz; - map->_dm_boundary = boundary; - map->_dm_flags = flags & ~(BUS_DMA_WAITOK|BUS_DMA_NOWAIT); - - *dmamp = map; - return (0); -} - -/* - * Common function for DMA map destruction. May be called by bus-specific - * DMA map destruction functions. - */ -void -_dmamap_destroy(bus_dma_tag_t t, bus_dmamap_t map) -{ - size_t mapsize; - - mapsize = sizeof(struct machine_bus_dmamap) + - (sizeof(bus_dma_segment_t) * (map->_dm_segcnt - 1)); - free(map, M_DEVBUF, mapsize); -} - -/* - * Common function for loading a DMA map with a linear buffer. May - * be called by bus-specific DMA map load functions. - */ -int -_dmamap_load(bus_dma_tag_t t, bus_dmamap_t map, void *buf, bus_size_t buflen, - struct proc *p, int flags) -{ - paddr_t lastaddr; - int seg, error; - - /* - * Make sure that on error condition we return "no valid mappings". - */ - map->dm_nsegs = 0; - map->dm_mapsize = 0; - - if (buflen > map->_dm_size) - return (EINVAL); - - seg = 0; - error = (*t->_dmamap_load_buffer)(t, map, buf, buflen, p, flags, - &lastaddr, &seg, 1); - if (error == 0) { - map->dm_nsegs = seg + 1; - map->dm_mapsize = buflen; - } - - return (error); -} - -/* - * Like _bus_dmamap_load(), but for mbufs. - */ -int -_dmamap_load_mbuf(bus_dma_tag_t t, bus_dmamap_t map, struct mbuf *m0, int flags) -{ - paddr_t lastaddr; - int seg, error, first; - struct mbuf *m; - - /* - * Make sure that on error condition we return "no valid mappings". - */ - map->dm_nsegs = 0; - map->dm_mapsize = 0; - -#ifdef DIAGNOSTIC - if ((m0->m_flags & M_PKTHDR) == 0) - panic("_dmamap_load_mbuf: no packet header"); -#endif - - if (m0->m_pkthdr.len > map->_dm_size) - return (EINVAL); - - first = 1; - seg = 0; - error = 0; - for (m = m0; m != NULL && error == 0; m = m->m_next) { - if (m->m_len == 0) - continue; - error = (*t->_dmamap_load_buffer)(t, map, m->m_data, m->m_len, - NULL, flags, &lastaddr, &seg, first); - first = 0; - } - if (error == 0) { - map->dm_nsegs = seg + 1; - map->dm_mapsize = m0->m_pkthdr.len; - } - - return (error); -} - -/* - * Like _dmamap_load(), but for uios. - */ -int -_dmamap_load_uio(bus_dma_tag_t t, bus_dmamap_t map, struct uio *uio, int flags) -{ - paddr_t lastaddr; - int seg, i, error, first; - bus_size_t minlen, resid; - struct proc *p = NULL; - struct iovec *iov; - void *addr; - - /* - * Make sure that on error condition we return "no valid mappings". - */ - map->dm_nsegs = 0; - map->dm_mapsize = 0; - - resid = uio->uio_resid; - iov = uio->uio_iov; - - if (uio->uio_segflg == UIO_USERSPACE) { - p = uio->uio_procp; -#ifdef DIAGNOSTIC - if (p == NULL) - panic("_dmamap_load_uio: USERSPACE but no proc"); -#endif - } - - first = 1; - seg = 0; - error = 0; - for (i = 0; i < uio->uio_iovcnt && resid != 0 && error == 0; i++) { - /* - * Now at the first iovec to load. Load each iovec - * until we have exhausted the residual count. - */ - minlen = resid < iov[i].iov_len ? resid : iov[i].iov_len; - addr = (void *)iov[i].iov_base; - - error = (*t->_dmamap_load_buffer)(t, map, addr, minlen, - p, flags, &lastaddr, &seg, first); - first = 0; - - resid -= minlen; - } - if (error == 0) { - map->dm_nsegs = seg + 1; - map->dm_mapsize = uio->uio_resid; - } - - return (error); -} - -/* - * Like _dmamap_load(), but for raw memory allocated with - * bus_dmamem_alloc(). - */ -int -_dmamap_load_raw(bus_dma_tag_t t, bus_dmamap_t map, bus_dma_segment_t *segs, - int nsegs, bus_size_t size, int flags) -{ - if (nsegs > map->_dm_segcnt || size > map->_dm_size) - return (EINVAL); - - /* - * Make sure we don't cross any boundaries. - */ - if (map->_dm_boundary) { - bus_addr_t bmask = ~(map->_dm_boundary - 1); - int i; - - if (t->_dma_mask != 0) - bmask &= t->_dma_mask; - for (i = 0; i < nsegs; i++) { - if (segs[i].ds_len > map->_dm_maxsegsz) - return (EINVAL); - if ((segs[i].ds_addr & bmask) != - ((segs[i].ds_addr + segs[i].ds_len - 1) & bmask)) - return (EINVAL); - } - } - - bcopy(segs, map->dm_segs, nsegs * sizeof(*segs)); - map->dm_nsegs = nsegs; - map->dm_mapsize = size; - return (0); -} - -/* - * Common function for unloading a DMA map. May be called by - * bus-specific DMA map unload functions. - */ -void -_dmamap_unload(bus_dma_tag_t t, bus_dmamap_t map) -{ - /* - * No resources to free; just mark the mappings as - * invalid. - */ - map->dm_nsegs = 0; - map->dm_mapsize = 0; -} - -/* - * Common function for DMA map synchronization. May be called - * by bus-specific DMA map synchronization functions. - */ -void -_dmamap_sync(bus_dma_tag_t t, bus_dmamap_t map, bus_addr_t addr, - bus_size_t size, int op) -{ - int nsegs; - int curseg; - int how; - struct cpu_info *ci; - -#ifdef TGT_COHERENT - /* we only need to writeback here */ - if ((op & BUS_DMASYNC_PREWRITE) == 0) - return; - else - how = CACHE_SYNC_W; -#else - /* - * If only PREWRITE is requested, writeback. - * PREWRITE with PREREAD writebacks and invalidates (since noncoherent) - * *all* cache levels. - * Otherwise, just invalidate (since noncoherent). - */ - if (op & BUS_DMASYNC_PREWRITE) { - if (op & BUS_DMASYNC_PREREAD) - how = CACHE_SYNC_X; - else - how = CACHE_SYNC_W; - } else { - if (op & (BUS_DMASYNC_PREREAD | BUS_DMASYNC_POSTREAD)) - how = CACHE_SYNC_R; - else - return; - } -#endif - - ci = curcpu(); - nsegs = map->dm_nsegs; - curseg = 0; - - while (size && nsegs) { - paddr_t paddr; - vaddr_t vaddr; - bus_size_t ssize; - - ssize = map->dm_segs[curseg].ds_len; - paddr = map->dm_segs[curseg]._ds_paddr; - vaddr = map->dm_segs[curseg]._ds_vaddr; - - if (addr != 0) { - if (addr >= ssize) { - addr -= ssize; - ssize = 0; - } else { - vaddr += addr; - paddr += addr; - ssize -= addr; - addr = 0; - } - } - if (ssize > size) - ssize = size; - -#ifndef TGT_COHERENT - if (IS_XKPHYS(vaddr) && XKPHYS_TO_CCA(vaddr) == CCA_NC) { - size -= ssize; - ssize = 0; - } -#endif - - if (ssize != 0) { - Mips_IOSyncDCache(ci, vaddr, ssize, how); -#if defined(TGT_INDY) || defined(TGT_INDIGO2) - /* - * Also flush external L2 if available - this could - * (and used to) be done in Mips_IOSyncDCache, but - * as the external L2 is physically addressed, this - * would require the physical address to be - * recomputed, although we know it here. - */ - if (ip22_extsync != NULL) - (*ip22_extsync)(ci, paddr, ssize, how); -#endif - size -= ssize; - } - curseg++; - nsegs--; - } - -#ifdef DIAGNOSTIC - if (size != 0) - panic("_dmamap_sync: ran off map!"); -#endif -} - -/* - * Common function for DMA-safe memory allocation. May be called - * by bus-specific DMA memory allocation functions. - */ -int -_dmamem_alloc(bus_dma_tag_t t, bus_size_t size, bus_size_t alignment, - bus_size_t boundary, bus_dma_segment_t *segs, int nsegs, int *rsegs, - int flags) -{ - return _dmamem_alloc_range(t, size, alignment, boundary, - segs, nsegs, rsegs, flags, - dma_constraint.ucr_low, dma_constraint.ucr_high); -} - -/* - * Common function for freeing DMA-safe memory. May be called by - * bus-specific DMA memory free functions. - */ -void -_dmamem_free(bus_dma_tag_t t, bus_dma_segment_t *segs, int nsegs) -{ - vm_page_t m; - paddr_t pa; - struct pglist mlist; - int curseg; - - /* - * Build a list of pages to free back to the VM system. - */ - TAILQ_INIT(&mlist); - for (curseg = 0; curseg < nsegs; curseg++) { - for (pa = segs[curseg]._ds_paddr; - pa < (segs[curseg]._ds_paddr + segs[curseg].ds_len); - pa += PAGE_SIZE) { - m = PHYS_TO_VM_PAGE(pa); - TAILQ_INSERT_TAIL(&mlist, m, pageq); - } - } - - uvm_pglistfree(&mlist); -} - -/* - * Common function for mapping DMA-safe memory. May be called by - * bus-specific DMA memory map functions. - */ -int -_dmamem_map(bus_dma_tag_t t, bus_dma_segment_t *segs, int nsegs, size_t size, - caddr_t *kvap, int flags) -{ - vaddr_t va, sva; - size_t ssize; - paddr_t pa; - int curseg, error, pmap_flags; - const struct kmem_dyn_mode *kd; - -#if defined(TGT_INDIGO2) - /* - * On ECC MC systems, which do not allow uncached writes to memory - * during regular operation, fail requests for uncached (coherent) - * memory. - */ - if ((flags & (BUS_DMA_COHERENT | BUS_DMA_NOCACHE)) && ip22_ecc) - return EINVAL; -#endif - -#ifdef TGT_COHERENT - /* coherent mappings do not need to be uncached on these platforms */ - flags &= ~BUS_DMA_COHERENT; -#endif - - if (nsegs == 1) { - pa = segs[0]._ds_paddr; - if (flags & (BUS_DMA_COHERENT | BUS_DMA_NOCACHE)) - *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_NC); - else - *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_CACHED); - return (0); - } - - size = round_page(size); - kd = flags & BUS_DMA_NOWAIT ? &kd_trylock : &kd_waitok; - va = (vaddr_t)km_alloc(size, &kv_any, &kp_none, kd); - if (va == 0) - return (ENOMEM); - - *kvap = (caddr_t)va; - - sva = va; - ssize = size; - pmap_flags = PMAP_WIRED | PMAP_CANFAIL; - if (flags & (BUS_DMA_COHERENT | BUS_DMA_NOCACHE)) - pmap_flags |= PMAP_NOCACHE; - for (curseg = 0; curseg < nsegs; curseg++) { - for (pa = segs[curseg]._ds_paddr; - pa < (segs[curseg]._ds_paddr + segs[curseg].ds_len); - pa += PAGE_SIZE, va += PAGE_SIZE, size -= PAGE_SIZE) { -#ifdef DIAGNOSTIC - if (size == 0) - panic("_dmamem_map: size botch"); -#endif - error = pmap_enter(pmap_kernel(), va, pa, - PROT_READ | PROT_WRITE, - PROT_READ | PROT_WRITE | pmap_flags); - if (error) { - pmap_update(pmap_kernel()); - km_free((void *)sva, ssize, &kv_any, &kp_none); - return (error); - } - - /* - * This is redundant with what pmap_enter() did - * above, but will take care of forcing other - * mappings of the same page (if any) to be - * uncached. - * If there are no multiple mappings of that - * page, this amounts to a noop. - */ - if (flags & (BUS_DMA_COHERENT | BUS_DMA_NOCACHE)) - pmap_page_cache(PHYS_TO_VM_PAGE(pa), - PGF_UNCACHED); - } - pmap_update(pmap_kernel()); - } - - return (0); -} - -/* - * Common function for unmapping DMA-safe memory. May be called by - * bus-specific DMA memory unmapping functions. - */ -void -_dmamem_unmap(bus_dma_tag_t t, caddr_t kva, size_t size) -{ - if (IS_XKPHYS((vaddr_t)kva)) - return; - - km_free(kva, round_page(size), &kv_any, &kp_none); -} - -/* - * Common function for mmap(2)'ing DMA-safe memory. May be called by - * bus-specific DMA mmap(2)'ing functions. - */ -paddr_t -_dmamem_mmap(bus_dma_tag_t t, bus_dma_segment_t *segs, int nsegs, off_t off, - int prot, int flags) -{ - int i; - - for (i = 0; i < nsegs; i++) { -#ifdef DIAGNOSTIC - if (off & PAGE_MASK) - panic("_dmamem_mmap: offset unaligned"); - if (segs[i].ds_addr & PAGE_MASK) - panic("_dmamem_mmap: segment unaligned"); - if (segs[i].ds_len & PAGE_MASK) - panic("_dmamem_mmap: segment size not multiple" - " of page size"); -#endif - if (off >= segs[i].ds_len) { - off -= segs[i].ds_len; - continue; - } - - return segs[i]._ds_paddr + off; - } - - /* Page not found. */ - return (-1); -} - -/********************************************************************** - * DMA utility functions - **********************************************************************/ - -/* - * Utility function to load a linear buffer. lastaddrp holds state - * between invocations (for multiple-buffer loads). segp contains - * the starting segment on entrance, and the ending segment on exit. - * first indicates if this is the first invocation of this function. - */ -int -_dmamap_load_buffer(bus_dma_tag_t t, bus_dmamap_t map, void *buf, - bus_size_t buflen, struct proc *p, int flags, paddr_t *lastaddrp, - int *segp, int first) -{ - bus_size_t sgsize; - bus_addr_t lastaddr, baddr, bmask; - paddr_t curaddr; - vaddr_t vaddr = (vaddr_t)buf; - int seg; - pmap_t pmap; - - if (p != NULL) - pmap = p->p_vmspace->vm_map.pmap; - else - pmap = pmap_kernel(); - - lastaddr = *lastaddrp; - bmask = ~(map->_dm_boundary - 1); - if (t->_dma_mask != 0) - bmask &= t->_dma_mask; - - for (seg = *segp; buflen > 0; ) { - /* - * Get the physical address for this segment. - */ - if (pmap_extract(pmap, vaddr, &curaddr) == 0) - panic("_dmapmap_load_buffer: pmap_extract(%p, %p) failed!", - pmap, (void *)vaddr); - -#ifdef DIAGNOSTIC - if (curaddr > dma_constraint.ucr_high || - curaddr < dma_constraint.ucr_low) - panic("Non DMA-reachable buffer at addr %p (raw)", - (void *)curaddr); -#endif - - /* - * Compute the segment size, and adjust counts. - */ - sgsize = NBPG - ((u_long)vaddr & PGOFSET); - if (buflen < sgsize) - sgsize = buflen; - - /* - * Make sure we don't cross any boundaries. - */ - if (map->_dm_boundary > 0) { - baddr = ((bus_addr_t)curaddr + map->_dm_boundary) & - bmask; - if (sgsize > (baddr - (bus_addr_t)curaddr)) - sgsize = (baddr - (bus_addr_t)curaddr); - } - - /* - * Insert chunk into a segment, coalescing with - * previous segment if possible. - */ - if (first) { - map->dm_segs[seg].ds_addr = - (*t->_pa_to_device)(curaddr, map->_dm_flags); - map->dm_segs[seg].ds_len = sgsize; - map->dm_segs[seg]._ds_paddr = curaddr; - map->dm_segs[seg]._ds_vaddr = vaddr; - first = 0; - } else { - if ((bus_addr_t)curaddr == lastaddr + 1 && - (map->dm_segs[seg].ds_len + sgsize) <= - map->_dm_maxsegsz && - (map->_dm_boundary == 0 || - (map->dm_segs[seg].ds_addr & bmask) == - ((bus_addr_t)curaddr & bmask))) - map->dm_segs[seg].ds_len += sgsize; - else { - if (++seg >= map->_dm_segcnt) - break; - map->dm_segs[seg].ds_addr = - (*t->_pa_to_device)(curaddr, - map->_dm_flags); - map->dm_segs[seg].ds_len = sgsize; - map->dm_segs[seg]._ds_paddr = curaddr; - map->dm_segs[seg]._ds_vaddr = vaddr; - } - } - - lastaddr = (bus_addr_t)curaddr + sgsize - 1; - vaddr += sgsize; - buflen -= sgsize; - } - - *segp = seg; - *lastaddrp = lastaddr; - - /* - * Did we fit? - */ - if (buflen != 0) - return (EFBIG); /* XXX better return value here? */ - - return (0); -} - -/* - * Allocate physical memory from the given physical address range. - * Called by DMA-safe memory allocation methods. - */ -int -_dmamem_alloc_range(bus_dma_tag_t t, bus_size_t size, bus_size_t alignment, - bus_size_t boundary, bus_dma_segment_t *segs, int nsegs, int *rsegs, - int flags, paddr_t low, paddr_t high) -{ - paddr_t curaddr, lastaddr; - vm_page_t m; - struct pglist mlist; - int curseg, error, plaflag; - - /* Always round the size. */ - size = round_page(size); - - /* - * Allocate pages from the VM system. - */ - plaflag = flags & BUS_DMA_NOWAIT ? UVM_PLA_NOWAIT : UVM_PLA_WAITOK; - if (flags & BUS_DMA_ZERO) - plaflag |= UVM_PLA_ZERO; - - TAILQ_INIT(&mlist); - error = uvm_pglistalloc(size, low, high, alignment, boundary, - &mlist, nsegs, plaflag); - if (error) - return (error); - - /* - * Compute the location, size, and number of segments actually - * returned by the VM code. - */ - m = TAILQ_FIRST(&mlist); - curseg = 0; - segs[curseg]._ds_paddr = VM_PAGE_TO_PHYS(m); - lastaddr = segs[curseg].ds_addr = - (*t->_pa_to_device)(segs[curseg]._ds_paddr, flags); - segs[curseg].ds_len = PAGE_SIZE; - m = TAILQ_NEXT(m, pageq); - - for (; m != NULL; m = TAILQ_NEXT(m, pageq)) { - paddr_t pa = VM_PAGE_TO_PHYS(m); -#ifdef DIAGNOSTIC - if (pa < low || pa >= high) { - printf("vm_page_alloc_memory returned non-sensical" - " address 0x%lx\n", pa); - panic("_dmamem_alloc_range"); - } -#endif - curaddr = (*t->_pa_to_device)(pa, flags); - if (curaddr == (lastaddr + PAGE_SIZE)) - segs[curseg].ds_len += PAGE_SIZE; - else { - curseg++; - segs[curseg]._ds_paddr = pa; - segs[curseg].ds_addr = curaddr; - segs[curseg].ds_len = PAGE_SIZE; - } - lastaddr = curaddr; - } - - *rsegs = curseg + 1; - - return (0); -} diff --git a/sys/arch/sgi/sgi/conf.c b/sys/arch/sgi/sgi/conf.c deleted file mode 100644 index b6ee44c1688..00000000000 --- a/sys/arch/sgi/sgi/conf.c +++ /dev/null @@ -1,313 +0,0 @@ -/* $OpenBSD: conf.c,v 1.44 2021/01/23 05:08:36 thfr Exp $ */ - -/* - * Copyright (c) 1992, 1993 - * The Regents of the University of California. All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * Ralph Campbell. - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Berkeley and its contributors. - * 4. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/buf.h> -#include <sys/ioctl.h> -#include <sys/proc.h> -#include <sys/vnode.h> -#include <sys/tty.h> - -#include <machine/conf.h> - -/* - * Block devices. - */ - -#include "vnd.h" -#include "sd.h" -#include "cd.h" -#include "st.h" -#include "wd.h" -bdev_decl(wd); -#include "rd.h" -#include "hotplug.h" - -struct bdevsw bdevsw[] = -{ - bdev_disk_init(NSD,sd), /* 0: SCSI disk */ - bdev_swap_init(1,sw), /* 1: should be here swap pseudo-dev */ - bdev_disk_init(NVND,vnd), /* 2: vnode disk driver */ - bdev_disk_init(NCD,cd), /* 3: SCSI CD-ROM */ - bdev_disk_init(NWD,wd), /* 4: ST506/ESDI/IDE disk */ - bdev_notdef(), /* 5: */ - bdev_notdef(), /* 6: was: concatenated disk driver */ - bdev_notdef(), /* 7: */ - bdev_disk_init(NRD,rd), /* 8: RAM disk (for install) */ - bdev_notdef(), /* 9: */ - bdev_notdef(), /* 10: was: SCSI tape */ - bdev_notdef(), /* 11: */ - bdev_notdef(), /* 12: */ - bdev_notdef(), /* 13: */ - bdev_notdef(), /* 14: */ - bdev_notdef(), /* 15: */ -}; - -int nblkdev = nitems(bdevsw); - -/* - * Character devices. - */ - -#define mmread mmrw -#define mmwrite mmrw -dev_type_read(mmrw); -cdev_decl(mm); -#include "bio.h" -#include "pty.h" -cdev_decl(fd); -#include "st.h" -#include "bpfilter.h" -#include "tun.h" -#include "com.h" -cdev_decl(com); -#include "zs.h" -cdev_decl(zs); -#include "lpt.h" -cdev_decl(lpt); -#include "ch.h" -#include "uk.h" -cdev_decl(wd); -#include "audio.h" -#include "video.h" -#include "ksyms.h" -#include "kstat.h" - -#include "wsdisplay.h" -#include "wskbd.h" -#include "wsmouse.h" -#include "wsmux.h" -#include "pci.h" -cdev_decl(pci); - -#include "dt.h" -#include "pf.h" - -#include "usb.h" -#include "uhid.h" -#include "fido.h" -#include "ujoy.h" -#include "ugen.h" -#include "ulpt.h" -#include "ucom.h" - -#include "vscsi.h" -#include "pppx.h" -#include "fuse.h" -#include "switch.h" - -struct cdevsw cdevsw[] = -{ - cdev_cn_init(1,cn), /* 0: virtual console */ - cdev_notdef(), /* 1 was /dev/drum */ - cdev_ctty_init(1,ctty), /* 2: controlling terminal */ - cdev_mm_init(1,mm), /* 3: /dev/{null,mem,kmem,...} */ - cdev_tty_init(NPTY,pts), /* 4: pseudo-tty slave */ - cdev_ptc_init(NPTY,ptc), /* 5: pseudo-tty master */ - cdev_log_init(1,log), /* 6: /dev/klog */ - cdev_fd_init(1,filedesc), /* 7: file descriptor pseudo-dev */ - cdev_disk_init(NCD,cd), /* 8: SCSI CD */ - cdev_disk_init(NSD,sd), /* 9: SCSI disk */ - cdev_tape_init(NST,st), /* 10: SCSI tape */ - cdev_disk_init(NVND,vnd), /* 11: vnode disk */ - cdev_bpf_init(NBPFILTER,bpf), /* 12: berkeley packet filter */ - cdev_tun_init(NTUN,tun), /* 13: network tunnel */ - cdev_notdef(), /* 14 */ - cdev_notdef(), /* 15: */ - cdev_lpt_init(NLPT,lpt), /* 16: Parallel printer interface */ - cdev_tty_init(NCOM,com), /* 17: 16C450 serial interface */ - cdev_disk_init(NWD,wd), /* 18: ST506/ESDI/IDE disk */ - cdev_tty_init(NZS,zs), /* 19: Z8530 serial interface */ - cdev_notdef(), /* 20: */ - cdev_notdef(), /* 21: */ - cdev_disk_init(NRD,rd), /* 22: ramdisk device */ - cdev_notdef(), /* 23: was: concatenated disk driver */ - cdev_notdef(), /* 24: */ - cdev_wsdisplay_init(NWSDISPLAY, wsdisplay), /* 25: */ - cdev_mouse_init(NWSKBD, wskbd), /* 26: */ - cdev_mouse_init(NWSMOUSE, wsmouse), /* 27: */ - cdev_mouse_init(NWSMUX, wsmux), /* 28: */ -#ifdef USER_PCICONF - cdev_pci_init(NPCI,pci), /* 29: PCI user */ -#else - cdev_notdef(), /* 29 */ -#endif - cdev_dt_init(NDT,dt), /* 30: dynamic tracer */ - cdev_pf_init(NPF,pf), /* 31: packet filter */ - cdev_uk_init(NUK,uk), /* 32: unknown SCSI */ - cdev_random_init(1,random), /* 33: random data source */ - cdev_notdef(), /* 34: */ - cdev_ksyms_init(NKSYMS,ksyms), /* 35: Kernel symbols device */ - cdev_ch_init(NCH,ch), /* 36: SCSI autochanger */ - cdev_notdef(), /* 37: */ - cdev_notdef(), /* 38: */ - cdev_notdef(), /* 39: */ - cdev_notdef(), /* 40: */ - cdev_notdef(), /* 41: */ - cdev_notdef(), /* 42: */ - cdev_notdef(), /* 33: */ - cdev_audio_init(NAUDIO,audio), /* 44: /dev/audio */ - cdev_video_init(NVIDEO,video), /* 45: generic video I/O */ - cdev_notdef(), /* 46: */ - cdev_notdef(), /* 47: was: /dev/crypto */ - cdev_notdef(), /* 48: */ - cdev_bio_init(NBIO,bio), /* 49: ioctl tunnel */ - cdev_notdef(), /* 50: */ - cdev_kstat_init(NKSTAT,kstat), /* 51: kernel statistics */ - cdev_ptm_init(NPTY,ptm), /* 52: pseudo-tty ptm device */ - cdev_notdef(), /* 53: */ - cdev_notdef(), /* 54: */ - cdev_notdef(), /* 55: */ - cdev_notdef(), /* 56: */ - cdev_notdef(), /* 57: */ - cdev_notdef(), /* 58: */ - cdev_notdef(), /* 59: */ - cdev_notdef(), /* 60: */ - cdev_usb_init(NUSB,usb), /* 61: USB controller */ - cdev_usbdev_init(NUHID,uhid), /* 62: USB generic HID */ - cdev_usbdev_init(NUGEN,ugen), /* 63: USB generic driver */ - cdev_ulpt_init(NULPT,ulpt), /* 64: USB printers */ - cdev_notdef(), /* 65: was urio */ - cdev_tty_init(NUCOM,ucom), /* 66: USB tty */ - cdev_hotplug_init(NHOTPLUG,hotplug), /* 67: devices hotplugging */ - cdev_vscsi_init(NVSCSI,vscsi), /* 68: vscsi */ - cdev_disk_init(1,diskmap), /* 69: disk mapper */ - cdev_pppx_init(NPPPX,pppx), /* 70: pppx */ - cdev_notdef(), /* 71: */ - cdev_notdef(), /* 72: was USB scanners */ - cdev_fuse_init(NFUSE,fuse), /* 73: fuse */ - cdev_tun_init(NTUN,tap), /* 74: Ethernet network tunnel */ - cdev_switch_init(NSWITCH,switch), /* 75: switch(4) control interface */ - cdev_fido_init(NFIDO,fido), /* 76: FIDO/U2F security key */ - cdev_pppx_init(NPPPX,pppac), /* 77: PPP Access Concentrator */ - cdev_ujoy_init(NUJOY,ujoy), /* 78: USB joystick/gamecontroller */ -}; - -int nchrdev = nitems(cdevsw); - -/* - * Swapdev is a fake device implemented - * in sw.c used only internally to get to swstrategy. - * It cannot be provided to the users, because the - * swstrategy routine munches the b_dev and b_blkno entries - * before calling the appropriate driver. This would horribly - * confuse, e.g. the hashing routines. Instead, /dev/drum is - * provided as a character (raw) device. - */ -dev_t swapdev = makedev(1, 0); - -/* - * Routine that identifies /dev/mem and /dev/kmem. - * - * A minimal stub routine can always return 0. - */ -int -iskmemdev(dev) - dev_t dev; -{ - - if (major(dev) == 3 && (minor(dev) == 0 || minor(dev) == 1)) - return (1); - return (0); -} - -/* - * Returns true if def is /dev/zero - */ -int -iszerodev(dev) - dev_t dev; -{ - return (major(dev) == 3 && minor(dev) == 12); -} - -dev_t -getnulldev() -{ - return(makedev(3, 2)); -} - - -int chrtoblktbl[] = { - /* VCHR VBLK */ - /* 0 */ NODEV, - /* 1 */ NODEV, - /* 2 */ NODEV, - /* 3 */ NODEV, - /* 4 */ NODEV, - /* 5 */ NODEV, - /* 6 */ NODEV, - /* 7 */ NODEV, - /* 8 */ 3, /* cd */ - /* 9 */ 0, /* sd */ - /* 10 */ NODEV, - /* 11 */ 2, /* vnd */ - /* 12 */ NODEV, - /* 13 */ NODEV, - /* 14 */ NODEV, - /* 15 */ NODEV, - /* 16 */ NODEV, - /* 17 */ NODEV, - /* 18 */ 4, /* wd */ - /* 19 */ NODEV, - /* 20 */ NODEV, - /* 21 */ NODEV, - /* 22 */ 8 /* rd */ -}; - -int nchrtoblktbl = nitems(chrtoblktbl); - -#include <dev/cons.h> - -cons_decl(com); -cons_decl(ws); -cons_decl(zs); - -struct consdev constab[] = { -#if NWSDISPLAY > 0 - cons_init(ws), -#endif -#if NCOM > 0 - cons_init(com), -#endif -#if NZS > 0 - cons_init(zs), -#endif - { 0 }, -}; diff --git a/sys/arch/sgi/sgi/disksubr.c b/sys/arch/sgi/sgi/disksubr.c deleted file mode 100644 index c430ad44d8e..00000000000 --- a/sys/arch/sgi/sgi/disksubr.c +++ /dev/null @@ -1,241 +0,0 @@ -/* $OpenBSD: disksubr.c,v 1.33 2017/02/28 10:49:37 natano Exp $ */ - -/* - * Copyright (c) 1999 Michael Shalayeff - * Copyright (c) 1997 Niklas Hallqvist - * Copyright (c) 1996 Theo de Raadt - * Copyright (c) 1982, 1986, 1988 Regents of the University of California. - * 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. - * 3. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/buf.h> -#include <sys/device.h> -#include <sys/disklabel.h> -#include <sys/syslog.h> -#include <sys/disk.h> - -int readsgilabel(struct buf *, void (*)(struct buf *), - struct disklabel *, daddr_t *, int); - -/* - * Attempt to read a disk label from a device - * using the indicated strategy routine. - * The label must be partly set up before this: - * secpercyl, secsize and anything required for a block i/o read - * operation in the driver's strategy/start routines - * must be filled in before calling us. - */ -int -readdisklabel(dev_t dev, void (*strat)(struct buf *), - struct disklabel *lp, int spoofonly) -{ - struct buf *bp = NULL; - int error; - - if ((error = initdisklabel(lp))) - goto done; - lp->d_flags |= D_VENDOR; - - /* get a buffer and initialize it */ - bp = geteblk(lp->d_secsize); - bp->b_dev = dev; - - error = readsgilabel(bp, strat, lp, NULL, spoofonly); - if (error == 0) - goto done; - - error = readdoslabel(bp, strat, lp, NULL, spoofonly); - if (error == 0) - goto done; - -#if defined(CD9660) - error = iso_disklabelspoof(dev, strat, lp); - if (error == 0) - goto done; -#endif -#if defined(UDF) - error = udf_disklabelspoof(dev, strat, lp); - if (error == 0) - goto done; -#endif - -done: - if (bp) { - bp->b_flags |= B_INVAL; - brelse(bp); - } - disk_change = 1; - return (error); -} - -static struct { - int m; - int b; -} maptab[] = { - { 0, FS_BSDFFS}, { 1, FS_SWAP}, { 10, FS_BSDFFS}, - { 3, FS_BSDFFS}, { 4, FS_BSDFFS}, { 5, FS_BSDFFS}, - { 6, FS_BSDFFS}, { 7, FS_BSDFFS}, { 15, FS_OTHER}, - { 9, FS_BSDFFS}, { 2, FS_UNUSED}, { 11, FS_BSDFFS}, - { 12, FS_BSDFFS}, { 13, FS_BSDFFS}, { 14, FS_BSDFFS}, - { 8, FS_BSDFFS} -}; - -int -readsgilabel(struct buf *bp, void (*strat)(struct buf *), - struct disklabel *lp, daddr_t *partoffp, int spoofonly) -{ - struct sgilabel *dlp; - int i, *p, cs = 0; - daddr_t fsoffs, fsend; - int error, offset; - - /* if successful, locate disk label within block and validate */ - error = readdisksector(bp, strat, lp, 0); - if (error) - return (error); - - fsoffs = DL_SECTOBLK(lp, DL_GETBSTART(lp)); - fsend = DL_SECTOBLK(lp, DL_GETBEND(lp)); - - dlp = (struct sgilabel *)(bp->b_data + LABELOFFSET); - if (dlp->magic != htobe32(SGILABEL_MAGIC)) - goto finished; - - if (dlp->partitions[0].blocks == 0) - return (EINVAL); - fsoffs = (long long)dlp->partitions[0].first; - fsend = fsoffs + dlp->partitions[0].blocks; - - /* Only came here to find the offset... */ - if (partoffp) { - *partoffp = fsoffs; - goto finished; - } - - p = (int *)dlp; - i = sizeof(struct sgilabel) / sizeof(int); - while (i--) - cs += *p++; - if (cs != 0) - return (EINVAL); /* sgilabel checksum error */ - - /* Spoof info from sgi label, in case there is no OpenBSD label. */ - lp->d_npartitions = MAXPARTITIONS; - - for (i = 0; i < 16; i++) { - int bsd = maptab[i].m; - int type = maptab[i].b; - - if (spoofonly && type != FS_UNUSED && type != FS_OTHER) - continue; - - DL_SETPOFFSET(&lp->d_partitions[bsd], - dlp->partitions[i].first); - DL_SETPSIZE(&lp->d_partitions[bsd], - dlp->partitions[i].blocks); - lp->d_partitions[bsd].p_fstype = type; - if (type == FS_BSDFFS) { - lp->d_partitions[bsd].p_fragblock = - DISKLABELV1_FFS_FRAGBLOCK(1024, 8); - lp->d_partitions[bsd].p_cpg = 16; - } - } - - DL_SETBSTART(lp, DL_BLKTOSEC(lp, fsoffs)); - DL_SETBEND(lp, DL_BLKTOSEC(lp, fsend)); - lp->d_version = 1; - lp->d_flags = D_VENDOR; - lp->d_checksum = 0; - lp->d_checksum = dkcksum(lp); - -finished: - /* record the OpenBSD partition's placement for the caller */ - if (partoffp) - *partoffp = fsoffs; - else { - DL_SETBSTART(lp, DL_BLKTOSEC(lp, fsoffs)); - DL_SETBEND(lp, DL_BLKTOSEC(lp, fsend)); - } - - /* don't read the on-disk label if we are in spoofed-only mode */ - if (spoofonly) - return (0); - - error = readdisksector(bp, strat, lp, DL_BLKTOSEC(lp, fsoffs + - LABELSECTOR)); - if (error) - return (error); - offset = DL_BLKOFFSET(lp, fsoffs + LABELSECTOR) + LABELOFFSET; - - error = checkdisklabel(bp->b_data + offset, lp, fsoffs, fsend); - return (error); -} - -/* - * Write disk label back to device after modification. - */ -int -writedisklabel(dev_t dev, void (*strat)(struct buf *), struct disklabel *lp) -{ - daddr_t partoff = -1; - int error = EIO; - int offset; - struct buf *bp = NULL; - struct disklabel *dlp; - - /* get a buffer and initialize it */ - bp = geteblk(lp->d_secsize); - bp->b_dev = dev; - - if (readsgilabel(bp, strat, lp, &partoff, 1) != 0 && - readdoslabel(bp, strat, lp, &partoff, 1) != 0) - goto done; - - /* Read it in, slap the new label in, and write it back out */ - error = readdisksector(bp, strat, lp, DL_BLKTOSEC(lp, partoff + - DOS_LABELSECTOR)); - if (error) - goto done; - offset = DL_BLKOFFSET(lp, partoff + DOS_LABELSECTOR); - - dlp = (struct disklabel *)(bp->b_data + offset); - *dlp = *lp; - CLR(bp->b_flags, B_READ | B_WRITE | B_DONE); - SET(bp->b_flags, B_BUSY | B_WRITE | B_RAW); - (*strat)(bp); - error = biowait(bp); - -done: - if (bp) { - bp->b_flags |= B_INVAL; - brelse(bp); - } - disk_change = 1; - return (error); -} diff --git a/sys/arch/sgi/sgi/eisa_machdep.c b/sys/arch/sgi/sgi/eisa_machdep.c deleted file mode 100644 index 0a99007e3a9..00000000000 --- a/sys/arch/sgi/sgi/eisa_machdep.c +++ /dev/null @@ -1,294 +0,0 @@ -/* $OpenBSD: eisa_machdep.c,v 1.4 2015/09/08 10:21:50 deraadt Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/errno.h> -#include <sys/malloc.h> -#include <sys/queue.h> - -#include <machine/bus.h> -#include <sgi/localbus/intreg.h> -#include <sgi/localbus/intvar.h> - -#include <dev/ic/i8259reg.h> -#include <dev/isa/isareg.h> -#include <dev/eisa/eisavar.h> - -#define IO_EXTNMI 0x0461 -#define IO_ELCR0 0x04d0 -#define IO_ELCR1 0x04d1 - -#define IRQ_CASCADE 2 - -int eisa_intr(void *); - -/* - * Magic registers (from IRIX IP22.h). They appear in EISA I/O space. - */ - -#define EIU_MODE_REG 0x0001ffc0 -#define EIU_STAT_REG 0x0001ffc4 -#define EIU_PREMPT_REG 0x0001ffc8 -#define EIU_QUIET_REG 0x0001ffcc -#define EIU_INTRPT_ACK 0x00010004 - -#define eiu_read(o) \ - *(volatile uint32_t *)PHYS_TO_XKPHYS(EISA_IO_BASE | (o), CCA_NC) -#define eiu_write(o,v) \ - *(volatile uint32_t *)PHYS_TO_XKPHYS(EISA_IO_BASE | (o), CCA_NC) = (v) - -#define eisa_io_read(o) \ - *(volatile uint8_t *)PHYS_TO_XKPHYS(EISA_IO_BASE | (o), CCA_NC) -#define eisa_io_write(o,v) \ - *(volatile uint8_t *)PHYS_TO_XKPHYS(EISA_IO_BASE | (o), CCA_NC) = (v) - -#define EISA_INT2_IRQNO INT2_MAP1_INTR(INT2_MAP_EISA) - -/* - * EISA interrupt handlers. - */ - -#define EISA_NINTS 16 - -struct eisa_intrhand { - SLIST_ENTRY(eisa_intrhand) ei_list; - int (*ei_fn)(void *); - void *ei_arg; - int ei_type; - - int ei_intr; - struct evcount ei_evcnt; -}; - -SLIST_HEAD(, eisa_intrhand) eisa_ih[EISA_NINTS]; - -int -eisa_intr_map(eisa_chipset_tag_t ec, u_int irq, eisa_intr_handle_t *ihp) -{ - *ihp = -1; - - if (irq >= EISA_NINTS) - return 1; - - if (irq == IRQ_CASCADE) /* cascade */ - irq = 9; - - *ihp = irq; - return 0; -} - -const char * -eisa_intr_string(eisa_chipset_tag_t ec, eisa_intr_handle_t ih) -{ - static char irqstr[32]; - - snprintf(irqstr, sizeof irqstr, "eisa irq %d", ih); - return irqstr; -} - -void * -eisa_intr_establish(eisa_chipset_tag_t ec, eisa_intr_handle_t ih, int type, - int level, int (*func)(void *), void *arg, char *what) -{ - struct eisa_intrhand *first = NULL, *eih; - - if (ih >= EISA_NINTS || ih == IRQ_CASCADE) - return NULL; - - if (!SLIST_EMPTY(&eisa_ih[ih])) { - first = SLIST_FIRST(&eisa_ih[ih]); - /* can't share edge and level interrupts */ - if (first->ei_type != type) - return NULL; - } - - eih = malloc(sizeof(*eih), M_DEVBUF, M_NOWAIT); - if (eih == NULL) - return NULL; - - eih->ei_fn = func; - eih->ei_arg = arg; - eih->ei_type = type; - eih->ei_intr = ih; - evcount_attach(&eih->ei_evcnt, what, &eih->ei_intr); - - if (first == NULL) { - /* Update ELCR */ - if (type == IST_LEVEL) { - if (ih >= 8) - eisa_io_write(IO_ELCR1, - eisa_io_read(IO_ELCR1) | (1 << (ih & 7))); - else - eisa_io_write(IO_ELCR0, - eisa_io_read(IO_ELCR0) | (1 << ih)); - } - /* Update OCW */ - if (ih >= 8) - eisa_io_write(IO_ICU2 + PIC_OCW1, - eisa_io_read(IO_ICU2 + PIC_OCW1) & ~(1 << (ih & 7))); - else - eisa_io_write(IO_ICU1 + PIC_OCW1, - eisa_io_read(IO_ICU1 + PIC_OCW1) & ~(1 << ih)); - } - - SLIST_INSERT_HEAD(&eisa_ih[ih], eih, ei_list); - - return eih; -} - -void -eisa_intr_disestablish(eisa_chipset_tag_t ec, void *cookie) -{ - struct eisa_intrhand *eih = (struct eisa_intrhand *)cookie; - unsigned int ih = (unsigned int)eih->ei_intr; - -#ifdef DIAGNOSTIC - if (ih >= EISA_NINTS || ih == IRQ_CASCADE) - return; -#endif - - SLIST_REMOVE(&eisa_ih[ih], eih, eisa_intrhand, ei_list); - - if (SLIST_EMPTY(&eisa_ih[ih])) { - /* Reset ELCR */ - if (ih >= 8) - eisa_io_write(IO_ELCR1, - eisa_io_read(IO_ELCR1) & ~(1 << (ih & 7))); - else - eisa_io_write(IO_ELCR0, - eisa_io_read(IO_ELCR0) & ~(1 << ih)); - /* Update OCW */ - if (ih >= 8) - eisa_io_write(IO_ICU2 + PIC_OCW1, - eisa_io_read(IO_ICU2 + PIC_OCW1) | (1 << (ih & 7))); - else - eisa_io_write(IO_ICU1 + PIC_OCW1, - eisa_io_read(IO_ICU1 + PIC_OCW1) | (1 << ih)); - } - - evcount_detach(&eih->ei_evcnt); - free(eih, M_DEVBUF, sizeof *eih); -} - -int -eisa_intr(void *arg) -{ - struct device *dv = (struct device *)arg; - struct eisa_intrhand *eih; - uint irq; - int rc, handled; - - irq = eisa_io_read(EIU_INTRPT_ACK); - if (irq >= EISA_NINTS) { - /* anything better to do? */ - panic("%s: unexpected irq value %08x", dv->dv_xname, irq); - return -1; - } - - handled = 0; - SLIST_FOREACH(eih, &eisa_ih[irq], ei_list) { - rc = (*eih->ei_fn)(eih->ei_arg); - if (rc != 0) { - handled = 1; - eih->ei_evcnt.ec_count++; - if (rc > 0) - break; - } - } - if (handled == 0) - printf("%s: spurious irq %d\n", dv->dv_xname, irq); - - if (irq >= 8) - eisa_io_write(IO_ICU2 + PIC_OCW2, OCW2_EOI); - eisa_io_write(IO_ICU1 + PIC_OCW2, OCW2_EOI); - - return handled; -} - -void -eisa_attach_hook(struct device *parent, struct device *self, - struct eisabus_attach_args *eba) -{ - unsigned int irq; - - /* - * Unlock the bus. Magic sequence taken from Linux. - */ - - eiu_write(EIU_PREMPT_REG, 0x0000ffff); - eiu_write(EIU_QUIET_REG, 1); - eiu_write(EIU_MODE_REG, 0x40f3c07f); - - /* - * Reset the bus. - */ - - eisa_io_write(IO_EXTNMI, 0x01); - delay(10000); - eisa_io_write(IO_EXTNMI, 0x00); - /* some boards need enough time to reset, or they won't probe */ - delay(250000); - - /* - * Setup i8259... - */ - - /* Program PIC1. */ - eisa_io_write(IO_ICU1 + PIC_ICW1, ICW1_SELECT | ICW1_IC4); - eisa_io_write(IO_ICU1 + PIC_ICW2, ICW2_VECTOR(0)); - eisa_io_write(IO_ICU1 + PIC_ICW3, ICW3_CASCADE(IRQ_CASCADE)); - eisa_io_write(IO_ICU1 + PIC_ICW4, ICW4_8086); - eisa_io_write(IO_ICU1 + PIC_OCW1, 0xff); - - /* Program PIC2. */ - eisa_io_write(IO_ICU2 + PIC_ICW1, ICW1_SELECT | ICW1_IC4); - eisa_io_write(IO_ICU2 + PIC_ICW2, ICW2_VECTOR(8)); - eisa_io_write(IO_ICU2 + PIC_ICW3, ICW3_SIC(IRQ_CASCADE)); - eisa_io_write(IO_ICU2 + PIC_ICW4, ICW4_8086); - eisa_io_write(IO_ICU2 + PIC_OCW1, 0xff); - - /* Interrupts are edge-triggered by default. */ - eisa_io_write(IO_ELCR0, 0x00); - eisa_io_write(IO_ELCR1, 0x00); - - /* Unmask the cascade interrupt */ - eisa_io_write(IO_ICU1 + PIC_OCW1, 0xff ^ (1 << IRQ_CASCADE)); - - /* - * Setup interrupt handling. - */ - - for (irq = 0; irq < EISA_NINTS; irq++) - SLIST_INIT(&eisa_ih[irq]); - - int2_intr_establish(EISA_INT2_IRQNO, IPL_TTY, eisa_intr, self, - self->dv_xname); - printf(" irq %d", EISA_INT2_IRQNO); -} - -int -eisa_maxslots(eisa_chipset_tag_t ec) -{ - /* - * Indigo2 systems can only have up to four slots (and only three - * for Impact models), but slot numbering starts at 1 (#0 being - * the host). - */ - return 1 + 4; -} diff --git a/sys/arch/sgi/sgi/genassym.cf b/sys/arch/sgi/sgi/genassym.cf deleted file mode 100644 index b15a8532fc8..00000000000 --- a/sys/arch/sgi/sgi/genassym.cf +++ /dev/null @@ -1 +0,0 @@ -# $OpenBSD: genassym.cf,v 1.21 2010/01/03 14:17:27 miod Exp $ diff --git a/sys/arch/sgi/sgi/intr_template.c b/sys/arch/sgi/sgi/intr_template.c deleted file mode 100644 index 80aa04772cf..00000000000 --- a/sys/arch/sgi/sgi/intr_template.c +++ /dev/null @@ -1,223 +0,0 @@ -/* $OpenBSD: intr_template.c,v 1.19 2018/02/24 11:42:31 visa Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Common interrupt dispatcher bowels. - * - * This file is not a standalone file; to use it, define the following - * macros and #include <sgi/sgi/intr_template.c>: - * - * INTR_FUNCTIONNAME interrupt handler function name - * MASK_FUNCTIONNAME interrupt mask computation function name - * INTR_GETMASKS logic to get `imr', `isr', and initialize `bit' - * INTR_HANDLER(bit) logic to access intrhand array head for `bit' - * INTR_IMASK(ipl) logic to access imask array for `ipl' - * INTR_LOCAL_DECLS local declarations (may be empty) - * MASK_LOCAL_DECLS local declarations (may be empty) - * INTR_MASKPENDING logic to mask `isr' - * INTR_MASKRESTORE logic to reset `imr' - * INTR_MASKSIZE size of interrupt mask in bits - * INTR_SPURIOUS(bit) print a spurious interrupt message for `bit' - * - * The following macros are optional: - * INTR_HANDLER_SKIP(ih) nonzero to skip intrhand invocation - * INTR_IPI_HOOK(ipl) special case logic for IPIs - */ - -/* - * Recompute interrupt masks. - */ -void -MASK_FUNCTIONNAME() -{ - int irq, level; - struct intrhand *q; - uint intrlevel[INTR_MASKSIZE]; - - MASK_LOCAL_DECLS - - /* First, figure out which levels each IRQ uses. */ - for (irq = 0; irq < INTR_MASKSIZE; irq++) { - uint levels = 0; - for (q = INTR_HANDLER(irq); q != NULL; q = q->ih_next) - levels |= 1 << q->ih_level; - intrlevel[irq] = levels; - } - - /* - * Then figure out which IRQs use each level. - * Note that we make sure never to overwrite imask[IPL_HIGH], in - * case an interrupt occurs during intr_disestablish() and causes - * an unfortunate splx() while we are here recomputing the masks. - */ - for (level = IPL_NONE; level < NIPLS; level++) { - uint64_t irqs = 0; - for (irq = 0; irq < INTR_MASKSIZE; irq++) - if (intrlevel[irq] & (1 << level)) - irqs |= 1UL << irq; - INTR_IMASK(level) = irqs; - } - - /* - * There are tty, network and disk drivers that use free() at interrupt - * time, so vm > (tty | net | bio). - * - * Enforce a hierarchy that gives slow devices a better chance at not - * dropping data. - */ - INTR_IMASK(IPL_NET) |= INTR_IMASK(IPL_BIO); - INTR_IMASK(IPL_TTY) |= INTR_IMASK(IPL_NET); - INTR_IMASK(IPL_VM) |= INTR_IMASK(IPL_TTY); - INTR_IMASK(IPL_CLOCK) |= INTR_IMASK(IPL_VM); - INTR_IMASK(IPL_HIGH) |= INTR_IMASK(IPL_CLOCK); - INTR_IMASK(IPL_IPI) |= INTR_IMASK(IPL_HIGH); - - /* - * These are pseudo-levels. - */ - INTR_IMASK(IPL_NONE) = 0; -} - -/* - * Interrupt dispatcher. - */ -uint32_t -INTR_FUNCTIONNAME(uint32_t hwpend, struct trapframe *frame) -{ - struct cpu_info *ci = curcpu(); - uint64_t imr, isr, mask; - int ipl; - int bit; - struct intrhand *ih; - int rc, ret; - INTR_LOCAL_DECLS - - INTR_GETMASKS; - - isr &= imr; - if (isr == 0) - return 0; /* not for us */ - -#ifdef INTR_IPI_HOOK - INTR_IPI_HOOK(frame->ipl); -#endif - - /* - * Mask all pending interrupts. - */ - INTR_MASKPENDING; - - /* - * If interrupts are spl-masked, mask them and wait for splx() - * to reenable them when necessary. - */ - if ((mask = isr & INTR_IMASK(frame->ipl)) != 0) { - isr &= ~mask; - imr &= ~mask; - } - - /* - * Now process allowed interrupts. - */ - if (isr != 0) { - int lvl, bitno; - uint64_t tmpisr; - - ipl = ci->ci_ipl; - - /* Service higher level interrupts first */ - for (lvl = NIPLS - 1; lvl != IPL_NONE; lvl--) { - tmpisr = isr & (INTR_IMASK(lvl) ^ INTR_IMASK(lvl - 1)); - if (tmpisr == 0) - continue; - for (bitno = bit, mask = 1UL << bitno; mask != 0; - bitno--, mask >>= 1) { - if ((tmpisr & mask) == 0) - continue; - - rc = 0; - for (ih = INTR_HANDLER(bitno); ih != NULL; - ih = ih->ih_next) { -#ifdef MULTIPROCESSOR - register_t sr; - int need_lock; -#endif -#if defined(INTR_HANDLER_SKIP) - if (INTR_HANDLER_SKIP(ih) != 0) - continue; -#endif - splraise(ih->ih_level); -#ifdef MULTIPROCESSOR - if (ih->ih_level < IPL_IPI) { - sr = getsr(); - ENABLEIPI(); - } - if (ih->ih_flags & IH_MPSAFE) - need_lock = 0; - else - need_lock = - ih->ih_level < IPL_CLOCK; - if (need_lock) - __mp_lock(&kernel_lock); -#endif - ret = (*ih->ih_fun)(ih->ih_arg); - if (ret != 0) { - rc = 1; - atomic_inc_long((unsigned long *) - &ih->ih_count.ec_count); - } -#ifdef MULTIPROCESSOR - if (need_lock) - __mp_unlock(&kernel_lock); - if (ih->ih_level < IPL_IPI) - setsr(sr); -#endif - ci->ci_ipl = ipl; - if (ret == 1) - break; - } - if (rc == 0) - INTR_SPURIOUS(bitno); - - isr ^= mask; - if ((tmpisr ^= mask) == 0) - break; - } - } - - /* - * Reenable interrupts which have been serviced. - */ - INTR_MASKRESTORE; - } - - return hwpend; -} - -#undef INTR_FUNCTIONNAME -#undef MASK_FUNCTIONNAME -#undef INTR_GETMASKS -#undef INTR_HANDLER -#undef INTR_HANDLER_SKIP -#undef INTR_IMASK -#undef INTR_LOCAL_DECLS -#undef MASK_LOCAL_DECLS -#undef INTR_MASKPENDING -#undef INTR_MASKRESTORE -#undef INTR_SPURIOUS -#undef INTR_IPI_HOOK diff --git a/sys/arch/sgi/sgi/ip22.h b/sys/arch/sgi/sgi/ip22.h deleted file mode 100644 index 054dfe465c6..00000000000 --- a/sys/arch/sgi/sgi/ip22.h +++ /dev/null @@ -1,45 +0,0 @@ -/* $OpenBSD: ip22.h,v 1.11 2015/09/23 21:22:26 miod Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * IP20/IP22/IP24 definitions - */ - -/* IP22/IP24 system types */ - -#define IP22_INDY 0 /* IP24 Indy */ -#define IP22_CHALLS 1 /* IP24 Challenge S */ -#define IP22_INDIGO2 2 /* IP22 Indigo 2, Challenge M */ - -/* Interrupt handling priority */ - -#ifdef CPU_R8000 -#define INTPRI_BUSERR_TCC (INTPRI_CLOCK + 1) -#define INTPRI_BUSERR (INTPRI_BUSERR_TCC + 1) -#else -#define INTPRI_BUSERR (INTPRI_CLOCK + 1) -#endif -#define INTPRI_L1 (INTPRI_BUSERR + 1) -#define INTPRI_L0 (INTPRI_L1 + 1) - -extern int hpc_old; /* nonzero if at least one HPC 1.x device found */ -extern int bios_year; -extern int ip22_ecc; /* nonzero if running with an ECC memory system */ - -void ip22_ConfigCache(struct cpu_info *); -extern void (*ip22_extsync)(struct cpu_info *, paddr_t, size_t, int); diff --git a/sys/arch/sgi/sgi/ip22_machdep.c b/sys/arch/sgi/sgi/ip22_machdep.c deleted file mode 100644 index fa51790df42..00000000000 --- a/sys/arch/sgi/sgi/ip22_machdep.c +++ /dev/null @@ -1,830 +0,0 @@ -/* $OpenBSD: ip22_machdep.c,v 1.23 2020/08/26 03:29:06 visa Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Specific routines for IP20/22/24/26/28 systems. Yet another case of a - * file which name no longer matches its original purpose. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/buf.h> -#include <sys/mount.h> - -#include <uvm/uvm_extern.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <machine/memconf.h> - -#include <mips64/arcbios.h> -#include <mips64/archtype.h> - -#include <sgi/sgi/ip22.h> -#include <sgi/localbus/imcreg.h> -#include <sgi/localbus/imcvar.h> -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/iocreg.h> - -#include "gio.h" -#include "tcc.h" - -#if NGIO > 0 -#include <sgi/gio/gioreg.h> -#include <sgi/gio/giovar.h> -#include <sgi/gio/lightreg.h> -#endif -#if NTCC > 0 -#include <sgi/localbus/tccreg.h> -#include <sgi/localbus/tccvar.h> -#endif - -int hpc_old = 0; -int bios_year; -int ip22_ecc = 0; - -void (*ip22_extsync)(struct cpu_info *, paddr_t, size_t, int); - -void ip22_arcbios_walk(void); -int ip22_arcbios_walk_component(arc_config_t *); -void ip22_cache_halt(int); -void ip22_cache_sync(struct cpu_info *, paddr_t, size_t, int); -void ip22_ecc_halt(int); -void ip22_ecc_init(int); -void ip22_fast_mode(void); -void ip22_memory_setup(void); -void ip22_slow_mode(void); -void ip22_video_setup(void); - -/* - * Walk the ARCBios component tree to get hardware information we can't - * obtain by other means. - */ - -#define IP22_HAS_L2 0x01 -#define IP22_HAS_AUDIO 0x02 -#define IP22_HAS_ENOUGH_FB 0x04 -static int ip22_arcwalk_results = 0; - -#if NGIO > 0 -static char ip22_fb_names[GIO_MAX_FB][64]; -#endif - -int -ip22_arcbios_walk_component(arc_config_t *cf) -{ - struct cpu_info *ci = curcpu(); - arc_config_t *child; - arc_config64_t *cf64 = (arc_config64_t *)cf; -#if NGIO > 0 - static int fbidx = 0; -#endif - - /* - * Split secondary caches are not supported. - * No IP22 processor module uses them anyway. - */ - if (cf->class == arc_CacheClass && cf->type == arc_SecondaryCache) { - uint64_t key; - - if (bios_is_32bit) - key = cf->key; - else - key = cf64->key >> 32; - - /* - * Secondary cache information is encoded as WWLLSSSS, where - * WW is the number of ways - * (should be 01) - * LL is Log2(line size) - * (should be 04 or 05 for IP20/IP22/IP24, 07 for IP26) - * SS is Log2(cache size in 4KB units) - * (should be between 0007 and 0009) - */ - ci->ci_l2.size = (1 << 12) << (key & 0x0000ffff); - ci->ci_l2.linesize = 1 << ((key >> 16) & 0xff); - ci->ci_l2.sets = (key >> 24) & 0xff; - ci->ci_l2.setsize = ci->ci_l2.size / ci->ci_l2.sets; - - ip22_arcwalk_results |= IP22_HAS_L2; - } - - if (cf->class == arc_ControllerClass && - cf->type == arc_AudioController) { - ip22_arcwalk_results |= IP22_HAS_AUDIO; - } - -#if NGIO > 0 - if (cf->class == arc_ControllerClass && - cf->type == arc_DisplayController) { - if (fbidx >= GIO_MAX_FB) { - /* - * Not worth printing a message. If the system is - * configured for glass console, it will get - * overwritten anyway. - */ - ip22_arcwalk_results |= IP22_HAS_ENOUGH_FB; - } else { - const char *id; - size_t idlen; - - if (bios_is_32bit) { - idlen = cf->id_len; - id = (const char *)(vaddr_t)cf->id; - } else { - idlen = cf64->id_len; - id = (const char *)cf64->id; - } - if (idlen != 0) { - /* skip leading spaces */ - while (idlen > 0 && id[0] == ' ') { - id++; - idlen--; - } - /* skip SGI- prefix */ - if (idlen >= 4 && strncmp(id, "SGI-", 4) == 0) { - id += 4; - idlen -= 4; - } - if (idlen >= sizeof(ip22_fb_names[0])) - idlen = sizeof(ip22_fb_names[0]) - 1; - bcopy(id, ip22_fb_names[fbidx], idlen); - } - giofb_names[fbidx] = ip22_fb_names[fbidx]; - fbidx++; - } - } -#endif - - if (ip22_arcwalk_results == - (IP22_HAS_L2 | IP22_HAS_AUDIO | IP22_HAS_ENOUGH_FB)) - return 0; /* abort walk */ - - for (child = (arc_config_t *)Bios_GetChild(cf); child != NULL; - child = (arc_config_t *)Bios_GetPeer(child)) { - if (ip22_arcbios_walk_component(child) == 0) - return 0; - } - - return 1; /* continue walk */ -} - -void -ip22_arcbios_walk() -{ -#if NGIO == 0 - ip22_arcwalk_results |= IP22_HAS_ENOUGH_FB; -#endif - (void)ip22_arcbios_walk_component((arc_config_t *)Bios_GetChild(NULL)); -} - -/* - * Parse memory controller settings. - */ - -#define IMC_NREGION 3 - -void -ip22_memory_setup() -{ - uint i, bank, shift; - uint32_t memc0, memc1; - uint32_t memc; - paddr_t base[IMC_NREGION], size[IMC_NREGION], limit; - paddr_t start0, end0, start1, end1; - struct phys_mem_desc *mem; - - /* - * Figure out the top of memory, as reported by ARCBios. - */ - - limit = 0; - for (i = 0, mem = mem_layout; i < MAXMEMSEGS; i++, mem++) { - if (mem->mem_last_page > limit) - limit = mem->mem_last_page; - } - limit = ptoa(limit); - - /* - * Figure out where the memory controller has put memory. - */ - - memc0 = imc_read(IMC_MEMCFG0); - memc1 = imc_read(IMC_MEMCFG1); - - /* Revision D onwards uses larger units, to allow for more memory */ - if ((imc_read(IMC_SYSID) & IMC_SYSID_REVMASK) >= 5) - shift = IMC_MEMC_LSHIFT_HUGE; - else - shift = IMC_MEMC_LSHIFT; - - for (bank = 0; bank < IMC_NREGION; bank++) { - memc = (bank & 2) ? memc1 : memc0; - if ((bank & 1) == 0) - memc >>= IMC_MEMC_BANK_SHIFT; - memc &= IMC_MEMC_BANK_MASK; - - if ((memc & IMC_MEMC_VALID) == 0) { - base[bank] = size[bank] = 0; - continue; - } - - base[bank] = (memc & IMC_MEMC_ADDR_MASK) >> IMC_MEMC_ADDR_SHIFT; - base[bank] <<= shift; - - size[bank] = (memc & IMC_MEMC_SIZE_MASK) >> IMC_MEMC_SIZE_SHIFT; - size[bank]++; - size[bank] <<= shift; - } - - /* - * Perform sanity checks on the above data.. - */ - - /* memory should not start below 128MB */ - for (bank = 0; bank < IMC_NREGION; bank++) - if (size[bank] != 0 && base[bank] < (1ULL << 27)) - goto dopanic; - - /* banks should not overlap */ - for (bank = 1; bank < IMC_NREGION; bank++) { - if (size[bank] == 0) - continue; - start0 = base[bank]; - end0 = base[bank] + size[bank]; - for (i = 0; i < bank; i++) { - if (size[i] == 0) - continue; - start1 = base[i]; - end1 = base[i] + size[i]; - if (end0 > start1 && start0 < end1) - goto dopanic; - } - } - - /* - * Now register all the memory beyond what ARCBios stopped at. - */ - - for (bank = 0; bank < IMC_NREGION; bank++) { - if (size[bank] == 0) - continue; - - start0 = base[bank]; - end0 = base[bank] + size[bank]; - if (end0 <= limit) - continue; - - if (start0 < limit) - start0 = limit; - - memrange_register(atop(start0), atop(end0), 0); - } - - return; - -dopanic: - bios_printf("** UNEXPECTED MEMORY CONFIGURATION **\n"); - bios_printf("MEMC0 %08x MEMC1 %08x\n", memc0, memc1); - bios_printf("Please contact <sgi@openbsd.org>\n" - "Halting system.\n"); - Bios_Halt(); - for (;;) - continue; - /* NOTREACHED */ -} - -void -ip22_video_setup() -{ -#if NGIO > 0 - /* - * According to Linux, the base address of the console device, - * if there is a glass console, can be obtained by invoking the - * 8th function pointer of the vendor-specific vector table. - * - * This function returns a pointer to a list of addresses (or - * whatever struct it is), which second field is the address we - * are looking for. - * - * However, the address does not point to the base address of the - * slot the frame buffer, but to some registers in it. While this - * might help identifying the actual frame buffer type, at the - * moment we are only interested in the base address. - */ - - long (*get_gfxinfo)(void); - vaddr_t fbaddr; - paddr_t fbphys; - - if (bios_is_32bit) { - int32_t *vec, *addr; - - vec = (int32_t *)(int64_t)(int32_t)ArcBiosBase32->vendor_vect; - get_gfxinfo = (long (*)(void))(int64_t)vec[8]; - addr = (int32_t *)(int64_t)(*get_gfxinfo)(); - fbaddr = addr[1]; - } else { - int64_t *vec, *addr; - - vec = (int64_t *)ArcBiosBase64->vendor_vect; - get_gfxinfo = (long (*)(void))vec[8]; - addr = (int64_t *)(*get_gfxinfo)(); - fbaddr = addr[1]; - } - - if (fbaddr >= CKSEG1_BASE && fbaddr < CKSSEG_BASE) - fbphys = CKSEG1_TO_PHYS(fbaddr); - else if (IS_XKPHYS(fbaddr)) - fbphys = XKPHYS_TO_PHYS(fbaddr); - else - return; - - if (!IS_GIO_ADDRESS(fbphys)) - return; - - /* - * Try to convert the address to a slot base or, for light(4) - * frame buffers, a frame buffer base. - * - * Verified addresses: - * grtwo slot + 0x00000000 - * impact slot + 0x00000000 - * light slot + 0x003f0000 (LIGHT_ADDR_0) - * newport slot + 0x000f0000 (NEWPORT_REX3_OFFSET) - */ - - /* light(4) only exists on IP20 */ - if (sys_config.system_type == SGI_IP20) { - paddr_t tmp = fbphys & ~((paddr_t)LIGHT_SIZE - 1); - if (tmp == LIGHT_ADDR_0 || tmp == LIGHT_ADDR_1) { - giofb_consaddr = tmp; - return; - } - } - - if (fbphys < GIO_ADDR_EXP0) - giofb_consaddr = GIO_ADDR_GFX; - else if (fbphys < GIO_ADDR_EXP1) - giofb_consaddr = GIO_ADDR_EXP0; - else - giofb_consaddr = GIO_ADDR_EXP1; -#endif -} - -void -ip22_setup() -{ - u_long cpuspeed; - uint8_t ip22_sysid; - - /* - * Get CPU information. - */ - bootcpu_hwinfo.c0prid = cp0_get_prid(); - bootcpu_hwinfo.c1prid = cp1_get_prid(); - cpuspeed = bios_getenvint("cpufreq"); - if (sys_config.system_type == SGI_IP20) - cpuspeed <<= 1; - switch (sys_config.system_type) { - default: - if (cpuspeed < 100) - cpuspeed = 100; /* reasonable default */ - break; - case SGI_IP26: - if (cpuspeed < 70) - cpuspeed = 75; /* reasonable default */ - break; - } - bootcpu_hwinfo.clock = cpuspeed * 1000000; - bootcpu_hwinfo.type = (bootcpu_hwinfo.c0prid >> 8) & 0xff; - - switch (sys_config.system_type) { - case SGI_IP20: - ip22_sysid = 0; - break; - default: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - ip22_sysid = (uint8_t)*(volatile uint32_t *) - PHYS_TO_XKPHYS(HPC_BASE_ADDRESS_0 + IOC_BASE + IOC_SYSID, - CCA_NC); - break; - } - - /* - * Scan ARCBios component list for useful information (L2 cache - * configuration, audio device availability) - */ - ip22_arcbios_walk(); - - /* - * Figure out what critter we are running on. - */ - switch (sys_config.system_type) { - case SGI_IP20: - if (ip22_arcwalk_results & IP22_HAS_AUDIO) - hw_prod = "Indigo"; - else - hw_prod = "VME Indigo"; - break; - case SGI_IP22: - if (ip22_sysid & 0x01) { - sys_config.system_subtype = IP22_INDIGO2; - hw_prod = "Indigo2"; - } else { - if (ip22_arcwalk_results & IP22_HAS_AUDIO) { - sys_config.system_subtype = IP22_INDY; - hw_prod = "Indy"; - } else { - sys_config.system_subtype = IP22_CHALLS; - hw_prod = "Challenge S"; - } - } - break; - case SGI_IP26: - sys_config.system_subtype = IP22_INDIGO2; - hw_prod = "POWER Indigo2 R8000"; - break; - case SGI_IP28: - sys_config.system_subtype = IP22_INDIGO2; - hw_prod = "POWER Indigo2 R10000"; - break; - } - - /* - * Figure out whether we are running on an Indigo2 system with the - * ECC board. - */ - - switch (sys_config.system_type) { - default: - break; - case SGI_IP26: - /* - * According to IRIX <sys/IP22.h>, earlier IP26 systems - * have an incomplete ECC board, and thus run in parity - * mode. - */ - if (((ip22_sysid & IOC_SYSID_BOARDREV) >> - IOC_SYSID_BOARDREV_SHIFT) >= - (0x18 >> IOC_SYSID_BOARDREV_SHIFT)) - ip22_ecc = 1; - break; - case SGI_IP28: - /* All IP28 systems use the ECC board */ - ip22_ecc = 1; - break; - } - - if (ip22_ecc) { - ip22_ecc_init(sys_config.system_type); - md_halt = ip22_ecc_halt; - } - - /* - * Figure out how many TLB entries are available. - */ - switch (bootcpu_hwinfo.type) { - default: -#if defined(CPU_R4000) || defined(CPU_R4600) || defined(CPU_R5000) - case MIPS_R4000: - case MIPS_R4600: - case MIPS_R5000: - bootcpu_hwinfo.tlbsize = 48; - break; -#endif -#ifdef CPU_R8000 - case MIPS_R8000: - bootcpu_hwinfo.tlbsize = 128 * 3; - break; -#endif -#ifdef CPU_R10000 - case MIPS_R10000: - bootcpu_hwinfo.tlbsize = 64; - break; -#endif - } - - /* - * Compute memory layout. ARCBios may not report all memory (on - * Indigo, it seems to only report up to 128MB, and on Indigo2, - * up to 256MB). - */ - ip22_memory_setup(); - - /* - * Get glass console information, if necessary. - */ - ip22_video_setup(); - - /* - * Register DMA-reachable memory constraints. - * hpc(4) revision 1 and 1.5 only use 28-bit address pointers, thus - * only 256MB are addressable; unfortunately, since physical memory - * starts at 128MB, this enforces a 128MB limit. - * - * The following logic is pessimistic, as IP24 (Indy) systems have - * a revision 3 hpc(4) onboard, but will accept older revisions in - * expansion boards. - */ - switch (sys_config.system_type) { - default: -#if defined(TGT_INDY) || defined(TGT_INDIGO2) - dma_constraint.ucr_low = 0; - dma_constraint.ucr_high = (1UL << 32) - 1; - if (sys_config.system_subtype == IP22_INDIGO2) - break; - /* FALLTHROUGH */ -#endif - case SGI_IP20: - dma_constraint.ucr_low = 0; - dma_constraint.ucr_high = (1UL << 28) - 1; - break; - } - - /* - * Get ARCBios' current time. - */ - bios_year = Bios_GetTime()->Year; - - _device_register = arcs_device_register; -} - -void -ip22_post_autoconf() -{ - /* - * Clear any pending bus error caused by the device probes. - */ -#if NTCC > 0 - if (sys_config.system_type == SGI_IP26) - tcc_bus_reset(); -#endif - imc_bus_reset(); - - /* - * Relax DMA-reachable memory constraints if no 28-bit hpc(4) - * device has attached. - */ - if (hpc_old == 0) { - uint64_t dmapages_before, dmapages; - - dmapages_before = uvm_pagecount(&dma_constraint); - dma_constraint.ucr_high = (1UL << 32) - 1; - dmapages = uvm_pagecount(&dma_constraint); - if (dmapages_before != dmapages) { - bufadjust(bufcachepercent * dmapages / 100); - bufhighpages = bufpages; - } - } - - if (ip22_ecc) { - ip22_fast_mode(); - } -} - -/* - * ECC board specific routines - */ - -#define ecc_write(o,v) \ - *(volatile uint64_t *)PHYS_TO_XKPHYS(ECC_BASE + (o), CCA_NC) = (v) - -static __inline__ uint32_t ip22_ecc_map(void); -static __inline__ void ip22_ecc_unmap(uint32_t); - -static int ip22_ecc_mode; /* 0 if slow mode, 1 if fast mode */ - -static __inline__ uint32_t -ip22_ecc_map() -{ - register uint32_t omemc1, nmemc1; - - omemc1 = imc_read(IMC_MEMCFG1); - nmemc1 = omemc1 & ~IMC_MEMC_BANK_MASK; - nmemc1 |= IMC_MEMC_VALID | (ECC_BASE >> IMC_MEMC_LSHIFT_HUGE); - imc_write(IMC_MEMCFG1, nmemc1); - (void)imc_read(IMC_MEMCFG1); - mips_sync(); - - return omemc1; -} - -static __inline__ void -ip22_ecc_unmap(uint32_t omemc1) -{ - imc_write(IMC_MEMCFG1, omemc1); - (void)imc_read(IMC_MEMCFG1); - mips_sync(); -} - -void -ip22_fast_mode() -{ - register uint32_t memc1; - - if (ip22_ecc_mode == 0) { - memc1 = ip22_ecc_map(); - ecc_write(ECC_CTRL, ECC_CTRL_ENABLE); - mips_sync(); - (void)imc_read(IMC_MEMCFG1); - imc_write(IMC_CPU_MEMACC, imc_read(IMC_CPU_MEMACC) & ~2); - ip22_ecc_unmap(memc1); - ip22_ecc_mode = 1; -#if NTCC > 0 - /* if (sys_config.system_type == SGI_IP26) */ - tcc_prefetch_enable(); -#endif - } -} - -void -ip22_slow_mode() -{ - register uint32_t memc1; - - if (ip22_ecc_mode != 0) { -#if NTCC > 0 - /* if (sys_config.system_type == SGI_IP26) */ - tcc_prefetch_disable(); -#endif - memc1 = ip22_ecc_map(); - imc_write(IMC_CPU_MEMACC, imc_read(IMC_CPU_MEMACC) | 2); - ecc_write(ECC_CTRL, ECC_CTRL_DISABLE); - mips_sync(); - (void)imc_read(IMC_MEMCFG1); - ip22_ecc_unmap(memc1); - ip22_ecc_mode = 0; - } -} - -void -ip22_ecc_init(int system_type) -{ - uint32_t memc1; - - /* setup slow mode */ - memc1 = ip22_ecc_map(); - imc_write(IMC_CPU_MEMACC, imc_read(IMC_CPU_MEMACC) | 2); - ecc_write(ECC_CTRL, ECC_CTRL_DISABLE); - mips_sync(); - (void)imc_read(IMC_MEMCFG1); - /* clear pending errors, if any */ - ecc_write(ECC_CTRL, ECC_CTRL_INT_CLR); - mips_sync(); - (void)imc_read(IMC_MEMCFG1); - - if (system_type == SGI_IP28) { - ecc_write(ECC_CTRL, ECC_CTRL_CHK_DISABLE); /* XXX for now */ - mips_sync(); - (void)imc_read(IMC_MEMCFG1); - } - - ip22_ecc_unmap(memc1); - ip22_ecc_mode = 0; -} - -void -ip22_ecc_halt(int howto) -{ - ip22_slow_mode(); - arcbios_halt(howto); -} - -#if (defined(TGT_INDY) || defined(TGT_INDIGO2)) && \ - (defined(CPU_R4600) || defined(CPU_R5000)) - -/* - * Cache routines for the secondary cache found on R4600SC and R5000SC - * systems. - */ - -#include <mips64/cache.h> -CACHE_PROTOS(ip22) - -#define IP22_L2_LINE 32UL -#define IP22_CACHE_TAG_ADDRESS 0x80000000UL - -static inline void ip22_l2_disable(void) -{ - /* halfword write: disable entire cache */ - *(volatile uint16_t *)(PHYS_TO_XKPHYS(IP22_CACHE_TAG_ADDRESS, CCA_NC)) = - 0; -} -static inline void ip22_l2_enable(void) -{ - /* byte write: enable entire cache */ - *(volatile uint8_t *)(PHYS_TO_XKPHYS(IP22_CACHE_TAG_ADDRESS, CCA_NC)) = - 0; -} - -void -ip22_cache_halt(int howto) -{ - ip22_l2_disable(); - arcbios_halt(howto); -} - -void -ip22_ConfigCache(struct cpu_info *ci) -{ - struct cache_info l2; - - /* - * Note that we are relying upon machdep.c only invoking us if we - * are running on an R4600 or R5000 system. - */ - if ((ip22_arcwalk_results & IP22_HAS_L2) == 0) { - Mips5k_ConfigCache(ci); - return; - } - - l2 = ci->ci_l2; - - Mips5k_ConfigCache(ci); - - if (l2.linesize != IP22_L2_LINE || l2.sets != 1) { - /* - * This should not happen. Better not try and tame an - * unknown beast. - */ - return; - } - - ci->ci_l2 = l2; - - ci->ci_SyncCache = ip22_SyncCache; - ip22_extsync = ip22_cache_sync; - - md_halt = ip22_cache_halt; - ip22_l2_enable(); -} - -void -ip22_SyncCache(struct cpu_info *ci) -{ - vaddr_t sva, eva; - - Mips5k_SyncCache(ci); - - sva = PHYS_TO_XKPHYS(IP22_CACHE_TAG_ADDRESS, CCA_NC); - eva = sva + ci->ci_l2.size; - - while (sva < eva) { - *(volatile uint32_t *)sva = 0; - sva += IP22_L2_LINE; - } -} - -void -ip22_cache_sync(struct cpu_info *ci, paddr_t _pa, size_t _sz, int how) -{ - size_t sz; - paddr_t pa, tagbase; - - switch (how) { - default: - case CACHE_SYNC_W: - break; - case CACHE_SYNC_X: - case CACHE_SYNC_R: - /* extend the range to integral cache lines */ - pa = _pa & ~(IP22_L2_LINE - 1); - sz = ((_pa + _sz + IP22_L2_LINE - 1) & ~(IP22_L2_LINE - 1)) - - pa; - - pa &= ci->ci_l2.size - 1; - tagbase = PHYS_TO_XKPHYS(IP22_CACHE_TAG_ADDRESS, CCA_NC); - - while (sz != 0) { - /* word write: invalidate line */ - *(volatile uint32_t *)(tagbase | pa) = 0; - - pa += IP22_L2_LINE; - pa &= ci->ci_l2.size - 1; - sz -= IP22_L2_LINE; - } - break; - } -} - -#endif diff --git a/sys/arch/sgi/sgi/ip27.h b/sys/arch/sgi/sgi/ip27.h deleted file mode 100644 index 9504e2756e0..00000000000 --- a/sys/arch/sgi/sgi/ip27.h +++ /dev/null @@ -1,97 +0,0 @@ -/* $OpenBSD: ip27.h,v 1.6 2015/12/25 09:02:57 visa Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Non-XBow related IP27 and IP35 definitions - */ - -/* NMI register save areas */ - -#define IP27_NMI_KREGS_BASE 0x11400 -#define IP27_NMI_KREGS_SIZE 0x200 /* per CPU */ -#define IP27_NMI_EFRAME_BASE 0x11800 - -#define IP35_NMI_KREGS_BASE 0x9000 -#define IP35_NMI_KREGS_SIZE 0x400 /* per CPU */ -#define IP35_NMI_EFRAME_BASE 0xa000 - -/* IP27 system types */ - -#define IP27_SN0 0x00 -#define IP27_SN00 0x01 -#define IP27_O200 IP27_SN00 -#define IP27_O2K IP27_SN0 -#define IP27_UNKNOWN 0x02 - -/* IP35 Brick types */ - -#define IP35_CBRICK 0x00 -#define IP35_O350 0x02 -#define IP35_FUEL 0x04 -#define IP35_O300 0x08 - -/* - * Specific device assignment - */ - -#define IP27_O200_BRIDGE_WIDGET 8 -#define IP27_O2K_BRIDGE_WIDGET 15 - -#define IP27_IOC_SLOTNO 2 -#define IP27_IOC2_SLOTNO 6 - -/* PROM entry points */ - -#define IP27_PROM_LAUNCH_SLAVE 0x1fc00038 - -#define ip27_prom_launch_slave (*(void (*)(int nasid, int cpu, \ - void (*func)(uint64_t), uint64_t param, uint64_t sp, \ - uint64_t gp))PHYS_TO_CKSEG1(IP27_PROM_LAUNCH_SLAVE)) - -/* - * IP27 configuration structure. Used to tell Origin 200 and Origin 2000 - * apart. - */ - -#define IP27_CONFIG_OFFSET 0x60 /* relative to LBOOTBASE */ -#define IP27_CONFIG_MAGIC 0x69703237636f6e66LL /* "ip27conf" */ - -struct ip27_config { - volatile uint32_t time_const; - volatile uint32_t r10k_sysad; - volatile uint64_t magic; - volatile uint64_t cpu_hz; - volatile uint64_t hub_hz; - volatile uint64_t rtc_hz; - volatile uint32_t ecc_enable; - volatile uint32_t fprom_cyc; - volatile uint32_t ip27_subtype; - volatile uint32_t cksum; - volatile uint32_t flash_count; - volatile uint32_t fprom_wr; - volatile uint32_t prom_ver; - volatile uint32_t prom_rev; - volatile uint32_t config_specific; -}; - -/* - * CPU identification - */ - -#define IP27_SLICE_LCPU(x) ((x) & 1) -#define IP27_SLICE_SUBNODE(x) (((x) & 2) >> 1) diff --git a/sys/arch/sgi/sgi/ip27_machdep.c b/sys/arch/sgi/sgi/ip27_machdep.c deleted file mode 100644 index def643d0e9d..00000000000 --- a/sys/arch/sgi/sgi/ip27_machdep.c +++ /dev/null @@ -1,1248 +0,0 @@ -/* $OpenBSD: ip27_machdep.c,v 1.82 2020/08/26 03:29:06 visa Exp $ */ - -/* - * Copyright (c) 2008, 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Origin 200 / Origin 2000 / Onyx 2 (IP27), as well as - * Origin 300 / Onyx 300 / Origin 350 / Onyx 350 / Onyx 4 / Origin 3000 / - * Fuel / Tezro (IP35) specific code. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/atomic.h> -#include <sys/device.h> -#include <sys/malloc.h> -#include <sys/proc.h> -#include <sys/reboot.h> -#include <sys/timetc.h> -#include <sys/tty.h> - -#include <mips64/arcbios.h> -#include <mips64/archtype.h> -#include <mips64/cache.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/memconf.h> -#include <machine/mnode.h> - -#include <uvm/uvm_extern.h> - -#include <sgi/sgi/ip27.h> -#include <sgi/sgi/l1.h> -#include <sgi/xbow/hub.h> -#include <sgi/xbow/widget.h> -#include <sgi/xbow/xbow.h> - -#include <sgi/pci/iofreg.h> -#include <dev/ic/comvar.h> - -#include <dev/cons.h> - -extern void (*md_halt)(int); - -paddr_t ip27_widget_short(int16_t, u_int); -paddr_t ip27_widget_long(int16_t, u_int); -paddr_t ip27_widget_map(int16_t, u_int,bus_addr_t *, bus_size_t *); -int ip27_widget_id(int16_t, u_int, uint32_t *); -int ip27_widget_id_early(int16_t, u_int, uint32_t *); - -void ip27_halt(int); - -unsigned int xbow_long_shift = 29; - -static paddr_t io_base; -static int ip35 = 0; -uint maxnodes; -gda_t *gda; - -int ip27_hub_intr_register(int, int, int *); -int ip27_hub_intr_establish(int (*)(void *), void *, int, int, - const char *, struct intrhand *); -void ip27_hub_intr_disestablish(int); -void ip27_hub_intr_clear(int); -void ip27_hub_intr_set(int); -uint32_t hubpi_intr0(uint32_t, struct trapframe *); -uint32_t hubpi_intr1(uint32_t, struct trapframe *); -void ip27_hub_intr_makemasks0(void); -void ip27_hub_intr_makemasks1(void); -void ip27_hub_setintrmask(int); -void ip27_hub_splx(int); - -void ip27_attach_node(struct device *, int16_t); -int ip27_print(void *, const char *); -void ip27_nmi(void *); - -#ifdef MULTIPROCESSOR - -#define IP27_SLICE_IPI(slice) ((slice) + HUBPI_ISR0_IPI_A) - -unsigned int ip27_ncpus; - -int ip27_kl_launch_cpu(klinfo_t *, void *); -int ip27_kl_launch_cpu_board(lboard_t *, void *); -int ip27_kl_attach_cpu(klinfo_t *, void *); -int ip27_kl_attach_cpu_board(lboard_t *, void *); - -uint ip27_hub_get_timecount(struct timecounter *); - -struct timecounter ip27_hub_timecounter = { - .tc_get_timecount = ip27_hub_get_timecount, - .tc_poll_pps = NULL, - .tc_counter_mask = 0xffffffff, /* truncated to 32 bits. */ - .tc_frequency = 1250000, - .tc_name = "hubrt", - .tc_quality = 100, - .tc_priv = 0, - .tc_user = 0, -}; - -volatile uint64_t ip27_spinup_a0; -volatile uint64_t ip27_spinup_sp; -volatile uint32_t ip27_spinup_turn = ~0; - -#define SPINUP_TICKET(nasid, slice) (((nasid) << 8) | (slice)) - -void ip27_cpu_spinup_trampoline(uint64_t); - -#endif /* MULTIPROCESSOR */ - -/* - * IP27 interrupt handling declarations: 128 hw sources, plus timers and - * hub error sources; 5 levels. - */ - -struct intrhand *hubpi_intrhand0[HUBPI_NINTS]; -struct intrhand *hubpi_intrhand1[HUBPI_NINTS]; - -#ifdef notyet -#define INTPRI_XBOW_HUB (INTPRI_CLOCK + 1) /* HUB errors */ -#define INTPRI_XBOW_TIMER (INTPRI_XBOW_HUB + 1) /* prof timer */ -#define INTPRI_XBOW_CLOCK (INTPRI_XBOW_TIMER + 1) /* RTC */ -#define INTPRI_XBOW_HW1 (INTPRI_XBOW_CLOCK + 1) /* HW level 1 */ -#else -#define INTPRI_XBOW_HW1 (INTPRI_CLOCK + 1) /* HW level 1 */ -#endif -#define INTPRI_XBOW_HW0 (INTPRI_XBOW_HW1 + 1) /* HW level 0 */ - -struct { - uint64_t hw[2]; -} hubpi_intem[MAXCPUS], hubpi_imask[MAXCPUS][NIPLS]; - -void -ip27_setup() -{ - struct cpu_info *ci = curcpu(); - struct ip27_config *ip27_config; - uint64_t synergy0_0; - console_t *cons; - nmi_t *nmi; - static char unknown_model[20]; - - ci->ci_nasid = masternasid; - ci->ci_slice = IP27_LHUB_L(HUBPI_CPU_NUMBER); - - io_base = PHYS_TO_XKPHYS_UNCACHED(0, SP_IO); - - ip35 = sys_config.system_type == SGI_IP35; - - if (ip35) { - /* - * Get brick model type. - * We need to access the Synergy registers through the remote - * HUB interface, local access is protected on some models. - * Synergy0 register #0 is a 16 bits identification register. - */ - synergy0_0 = IP27_RHSPEC_L(0, HSPEC_SYNERGY(0, 0)); - sys_config.system_subtype = (synergy0_0 & 0xf000) >> 12; - switch (sys_config.system_subtype) { - case IP35_O350: /* Chimera */ - hw_prod = "Origin 350"; - break; - case IP35_FUEL: /* Asterix */ - hw_prod = "Fuel"; - break; - case IP35_O300: /* Speedo2 */ - hw_prod = "Origin 300"; - break; - case IP35_CBRICK: - /* regular C-Brick, must be an Origin 3000 system */ - hw_prod = "Origin 3000"; - break; - default: - snprintf(unknown_model, sizeof unknown_model, - "Unknown IP35 type %x", sys_config.system_subtype); - hw_prod = unknown_model; - break; - } - } else { - ip27_config = (struct ip27_config *) - IP27_LHSPEC_ADDR(LBOOTBASE_IP27 + IP27_CONFIG_OFFSET); - if (ip27_config->magic == IP27_CONFIG_MAGIC) - sys_config.system_subtype = ip27_config->ip27_subtype; - else - sys_config.system_subtype = IP27_UNKNOWN; - switch (sys_config.system_subtype) { - case IP27_O2K: - hw_prod = "Origin 2000"; - break; - case IP27_O200: - hw_prod = "Origin 200"; - break; - default: - snprintf(unknown_model, sizeof unknown_model, - "Unknown IP27 type %x", sys_config.system_subtype); - hw_prod = unknown_model; - break; - } - } - - /* - * Register DMA-reachable memory constraints. - * The xbridge(4) is limited to a 31-bit region (its IOMMU features - * are too restricted to be of use). - */ - dma_constraint.ucr_low = 0; - dma_constraint.ucr_high = (1UL << 31) - 1; - - xbow_widget_base = ip27_widget_short; - xbow_widget_map = ip27_widget_map; - xbow_widget_id = ip27_widget_id_early; - - md_halt = ip27_halt; - - /* - * Figure out as early as possibly whether we are running in M - * or N mode. - */ - - kl_init(ip35); - if (kl_n_mode != 0) - xbow_long_shift = 28; - -#ifdef MULTIPROCESSOR - /* - * Pre-launch secondary CPUs with the help of the PROM. This has to be - * done now, before tearing down the PROM TLB and disabling interrupts - * on the secondary CPUs. The CPUs will wait in the spinup trampoline - * until the system launches them for real. - */ - ip27_ncpus = 1; - kl_scan_all_nodes(IP27_BC_NODE, ip27_kl_launch_cpu_board, NULL); -#endif - - /* - * Initialize the early console parameters. - * This assumes it is either on IOC3 or IOC4, accessible through - * a widget small window. - * - * Since IOC3 and IOC4 use different clocks, we need to tell them - * apart early. We rely on the serial port offset within the IOC - * space. - */ - - cons = kl_get_console(); - xbow_build_bus_space(&sys_config.console_io, 0, - 8 /* whatever nonzero */); - /* point to devio base */ - sys_config.console_io.bus_base = - cons->uart_base & 0xfffffffffff00000UL; - comconsaddr = cons->uart_base & 0x00000000000fffffUL; - comconsrate = cons->baud; - if (comconsrate < 50 || comconsrate > 115200) - comconsrate = 9600; - if ((comconsaddr & 0xfff) < 0x380) { - /* IOC3 */ - comconsfreq = 22000000 / 3; - } else { - /* IOC4 */ - uint32_t ioc4_mcr; - paddr_t ioc4_base; - - /* - * IOC4 clocks are derived from the PCI clock, - * so we need to figure out whether this is an 66MHz - * or a 33MHz bus. - */ - ioc4_base = sys_config.console_io.bus_base; - ioc4_mcr = *(volatile uint32_t *)(ioc4_base + IOC4_MCR); - if (ioc4_mcr & IOC4_MCR_PCI_66MHZ) - comconsfreq = 66666667; - else - comconsfreq = 33333333; - } - comconsiot = &sys_config.console_io; - - /* - * Force widget interrupts to run through us, unless a - * better interrupt master widget is found. - */ - - xbow_intr_widget_intr_register = ip27_hub_intr_register; - xbow_intr_widget_intr_establish = ip27_hub_intr_establish; - xbow_intr_widget_intr_disestablish = ip27_hub_intr_disestablish; - xbow_intr_widget_intr_clear = ip27_hub_intr_clear; - xbow_intr_widget_intr_set = ip27_hub_intr_set; - - set_intr(INTPRI_XBOW_HW1, CR_INT_1, hubpi_intr1); - set_intr(INTPRI_XBOW_HW0, CR_INT_0, hubpi_intr0); - register_splx_handler(ip27_hub_splx); - - /* - * Disable all hardware interrupts. - */ - - IP27_LHUB_S(HUBPI_CPU0_IMR0, 0); - IP27_LHUB_S(HUBPI_CPU0_IMR1, 0); - IP27_LHUB_S(HUBPI_CPU1_IMR0, 0); - IP27_LHUB_S(HUBPI_CPU1_IMR1, 0); - (void)IP27_LHUB_L(HUBPI_IR0); - (void)IP27_LHUB_L(HUBPI_IR1); - if (ip35) { - IP27_RHUB_PI_S(masternasid, 1, HUBPI_CPU0_IMR0, 0); - IP27_RHUB_PI_S(masternasid, 1, HUBPI_CPU0_IMR1, 0); - IP27_RHUB_PI_S(masternasid, 1, HUBPI_CPU1_IMR0, 0); - IP27_RHUB_PI_S(masternasid, 1, HUBPI_CPU1_IMR1, 0); - (void)IP27_RHUB_PI_L(masternasid, 1, HUBPI_IR0); - (void)IP27_RHUB_PI_L(masternasid, 1, HUBPI_IR1); - } - - /* - * Setup NMI handler. - */ - nmi = IP27_NMI(0); - nmi->magic = NMI_MAGIC; - nmi->cb = (vaddr_t)ip27_nmi; - nmi->cb_complement = ~nmi->cb; - nmi->cb_arg = 0; - - /* - * Set up Node 0's HUB. - */ - IP27_LHUB_S(HUBPI_REGION_PRESENT, 0xffffffffffffffff); - IP27_LHUB_S(HUBPI_CALIAS_SIZE, PI_CALIAS_SIZE_0); - if (ip35) { - IP27_RHUB_PI_S(masternasid, 1, - HUBPI_REGION_PRESENT, 0xffffffffffffffff); - IP27_RHUB_PI_S(masternasid, 1, - HUBPI_CALIAS_SIZE, PI_CALIAS_SIZE_0); - } - - /* - * Compute interrupt register address. - */ - xbow_intr_address = (1UL << 47) /* XIO I/O space */ | - (masternasid << (ip35 ? 39 : 38)) | - ((uint64_t)IP27_RHUB_ADDR(0, HUBPI_IR_CHANGE) - - IP27_NODE_IO_BASE(0)) /* HUB register offset */; - - _device_register = dksc_device_register; - -#ifdef MULTIPROCESSOR - tc_init(&ip27_hub_timecounter); -#endif -} - -/* - * Autoconf enumeration - */ - -void -ip27_autoconf(struct device *parent) -{ - union { - struct mainbus_attach_args maa; - struct cpu_attach_args caa; - } u; - uint node; - - xbow_widget_id = ip27_widget_id; - - /* - * Attach the CPU we are running on early; other processors, - * if any, will get attached as they are discovered. - */ - - bzero(&u, sizeof u); - u.maa.maa_name = "cpu"; - u.maa.maa_nasid = currentnasid = masternasid; - u.maa.maa_physid = IP27_LHUB_L(HUBPI_CPU_NUMBER); - u.caa.caa_hw = &bootcpu_hwinfo; - config_found(parent, &u, ip27_print); - u.maa.maa_name = "clock"; - config_found(parent, &u, ip27_print); - - /* - * Now attach all nodes' I/O devices. - */ - -#ifdef MULTIPROCESSOR - ip27_ncpus = 1; -#endif - ip27_attach_node(parent, masternasid); - for (node = 0; node < maxnodes; node++) { - if (gda->nasid[node] < 0) - continue; - if (gda->nasid[node] == masternasid) - continue; - ip27_attach_node(parent, gda->nasid[node]); - } -} - -void -ip27_attach_node(struct device *parent, int16_t nasid) -{ - union { - struct mainbus_attach_args maa; - struct spdmem_attach_args saa; - } u; - uint dimm; - void *match; - - currentnasid = nasid; - bzero(&u, sizeof u); - - /* - * IRIX performs this extra initialization on Origin 200 systems. - * This seems to properly initialize on-board devices on the - * second node. - */ - if (sys_config.system_type == SGI_IP27 && - sys_config.system_subtype == IP27_O200) { - IP27_RHUB_S(nasid, HUBMDBASE_IP27 | HUBMD_LED0, - nasid == masternasid ? 1 : 9); - IP27_RHUB_S(nasid, HUBMDBASE_IP27 | HUBMD_LED0, - nasid == masternasid ? 1 : 9); - } - -#ifdef MULTIPROCESSOR - kl_scan_node(nasid, IP27_BC_NODE, ip27_kl_attach_cpu_board, parent); -#endif - - if (ip35) { - l1_display(nasid, 1, "OpenBSD/sgi"); - - u.maa.maa_name = "spdmem"; - u.maa.maa_nasid = nasid; - for (dimm = 0; dimm < L1_SPD_DIMM_MAX; dimm++) { - u.saa.dimm = dimm; - /* - * inline config_found_sm() without printing a message - * if match() fails, to avoid getting - * ``spdmem not configured'' for empty memory slots. - */ - if ((match = config_search(NULL, parent, &u)) != NULL) - config_attach(parent, match, &u, ip27_print); - } - } - u.maa.maa_name = "xbow"; - u.maa.maa_nasid = nasid; - config_found(parent, &u, ip27_print); -} - -int -ip27_print(void *aux, const char *pnp) -{ - struct mainbus_attach_args *maa = aux; - - if (pnp != NULL) - printf("%s at %s", maa->maa_name, pnp); - printf(" nasid %d", maa->maa_nasid); - - return UNCONF; -} - -/* - * Widget mapping. - */ - -paddr_t -ip27_widget_short(int16_t nasid, u_int widget) -{ - /* - * A hardware bug on the PI side of the Hub chip (at least in - * earlier versions) causes accesses to the short window #0 - * to be unreliable. - * The PROM implements a workaround by remapping it to - * big window #6 (the last programmable big window). - */ - if (widget == 0) - return ip27_widget_long(nasid, IOTTE_SWIN0); - - return ((uint64_t)(widget) << 24) | - ((uint64_t)(nasid) << kl_n_shift) | io_base; -} - -paddr_t -ip27_widget_long(int16_t nasid, u_int window) -{ - return ((uint64_t)(window + 1) << xbow_long_shift) | - ((uint64_t)(nasid) << kl_n_shift) | io_base; -} - -paddr_t -ip27_widget_map(int16_t nasid, u_int widget, bus_addr_t *offs, bus_size_t *len) -{ - uint tte, avail_tte; - uint64_t iotte; - paddr_t delta, start, end; - int s; - - /* - * On Origin systems, we can only have partial views of the widget - * address space, due to the addressing scheme limiting each node's - * address space to 31 to 33 bits. - * - * The largest window is 256MB or 512MB large, depending on the - * mode the system is in (M/N). - */ - - /* - * Round the requested range to a large window boundary. - */ - - start = *offs; - end = start + *len; - - start = (start >> xbow_long_shift); - end = (end + (1 << xbow_long_shift) - 1) >> xbow_long_shift; - - /* - * See if an existing IOTTE covers part of the mapping we are asking - * for. If so, reuse it and truncate the caller's range. - */ - - s = splhigh(); /* XXX or disable interrupts completely? */ - - avail_tte = IOTTE_MAX; - for (tte = 0; tte < IOTTE_MAX; tte++) { - if (tte == IOTTE_SWIN0) - continue; - - iotte = IP27_RHUB_L(nasid, HUBIOBASE + HUBIO_IOTTE(tte)); - if (IOTTE_WIDGET(iotte) == 0) { - if (avail_tte == IOTTE_MAX) - avail_tte = tte; - continue; - } - if (IOTTE_WIDGET(iotte) != widget) - continue; - - if (IOTTE_OFFSET(iotte) < start || - (IOTTE_OFFSET(iotte) + 1) >= end) - continue; - - /* - * We found a matching IOTTE (an exact match if we asked for - * less than the large window size, a partial match otherwise). - * Reuse it (since we never unmap IOTTE at this point, there - * is no need to maintain a reference count). - */ - break; - } - - /* - * If we found an unused IOTTE while searching above, program it - * to map the beginning of the requested range. - */ - - if (tte == IOTTE_MAX && avail_tte != IOTTE_MAX) { - tte = avail_tte; - - /* XXX I don't understand why it's not device space. */ - iotte = IOTTE(IOTTE_SPACE_MEMORY, widget, start); - IP27_RHUB_S(nasid, HUBIOBASE + HUBIO_IOTTE(tte), iotte); - (void)IP27_RHUB_L(nasid, HUBIOBASE + HUBIO_IOTTE(tte)); - } - - splx(s); - - if (tte != IOTTE_MAX) { - delta = *offs - (start << xbow_long_shift); - /* *offs unmodified */ - *len = (1 << xbow_long_shift) - delta; - - return ip27_widget_long(nasid, tte) + delta; - } - - return 0UL; -} - -/* - * Widget enumeration - */ - -int -ip27_widget_id(int16_t nasid, u_int widget, uint32_t *wid) -{ - paddr_t wpa; - uint32_t id; - - if (widget != 0) - { - if (widget < WIDGET_MIN || widget > WIDGET_MAX) - return EINVAL; - } - - wpa = ip27_widget_short(nasid, widget); - if (guarded_read_4(wpa + (WIDGET_ID | 4), &id) != 0) - return ENXIO; - - if (wid != NULL) - *wid = id; - - return 0; -} - -/* - * Same as the above, but usable before we can handle faults. - * Expects the caller to only use valid widget numbers... - */ -int -ip27_widget_id_early(int16_t nasid, u_int widget, uint32_t *wid) -{ - paddr_t wpa; - - if (widget != 0) - { - if (widget < WIDGET_MIN || widget > WIDGET_MAX) - return EINVAL; - } - - wpa = ip27_widget_short(nasid, widget); - if (wid != NULL) - *wid = *(uint32_t *)(wpa + (WIDGET_ID | 4)); - - return 0; -} - -/* - * Reboot code - */ - -void -ip27_halt(int howto) -{ - uint32_t promop; - uint node; - uint64_t nibase, action; - - /* - * Even if ARCBios TLB and exception vectors are restored, - * returning to ARCBios doesn't work. - * - * So, instead, send a reset through the network interface - * of the Hub space. Although there seems to be a way to tell - * the PROM which action we want it to take afterwards, it - * always reboots for me... - */ - - if (howto & RB_HALT) { -#if 0 - if (howto & RB_POWERDOWN) - promop = GDA_PROMOP_HALT; - else - promop = GDA_PROMOP_EIM; -#else - if (howto & RB_POWERDOWN) { - if (ip35) { - l1_exec_command(masternasid, "* pwr d"); - delay(1000000); - printf("Powerdown failed, " - "please switch off power manually.\n"); - } else { - printf("Software powerdown not supported, " - "please switch off power manually.\n"); - } - for (;;) - continue; - /* NOTREACHED */ - } else { - printf("System halted.\n" - "Press any key to restart\n"); - cngetc(); - promop = GDA_PROMOP_REBOOT; - } -#endif - } else - promop = GDA_PROMOP_REBOOT; - - promop |= GDA_PROMOP_MAGIC | GDA_PROMOP_NO_DIAGS | - GDA_PROMOP_NO_MEMINIT; - -#if 0 - /* - * That's what one would expect, based on the gda layout... - */ - gda->promop = promop; -#else - /* - * ...but the magic location is in a different castle. - * And it's not even the same between IP27 and IP35. - * Laugh, everyone! It's what SGI wants us to. - */ - if (ip35) - IP27_LHUB_S(HUBLBBASE_IP35 + 0x8010, promop); - else - IP27_LHUB_S(HUBPIBASE + 0x418, promop); -#endif - - if (ip35) { - nibase = HUBNIBASE_IP35; - action = NI_RESET_LOCAL_IP35 | NI_RESET_ACTION_IP35; - } else { - nibase = HUBNIBASE_IP27; - action = NI_RESET_LOCAL_IP27 | NI_RESET_ACTION_IP27; - } - - /* - * Reset all other nodes, if present. - */ - - for (node = 0; node < maxnodes; node++) { - if (gda->nasid[node] < 0) - continue; - if (gda->nasid[node] == masternasid) - continue; - IP27_RHUB_S(gda->nasid[node], - nibase + HUBNI_RESET_ENABLE, NI_RESET_ENABLE); - IP27_RHUB_S(gda->nasid[node], - nibase + HUBNI_RESET, action); - } - IP27_LHUB_S(nibase + HUBNI_RESET_ENABLE, NI_RESET_ENABLE); - IP27_LHUB_S(nibase + HUBNI_RESET, action); -} - -/* - * Local HUB interrupt handling routines - */ - -/* - * Find a suitable interrupt bit for the given interrupt. - */ -int -ip27_hub_intr_register(int widget, int level, int *intrbit) -{ - u_long cpuid = cpu_number(); - int bit; - - /* - * Try to allocate a bit on hardware level 0 first. - */ - for (bit = HUBPI_INTR0_WIDGET_MAX; bit >= HUBPI_INTR0_WIDGET_MIN; bit--) - if ((hubpi_intem[cpuid].hw[0] & (1UL << bit)) == 0) - goto found; - - /* - * If all level 0 sources are in use, try to allocate a bit on - * level 1. - */ - for (bit = HUBPI_INTR1_WIDGET_MAX; bit >= HUBPI_INTR1_WIDGET_MIN; bit--) - if ((hubpi_intem[cpuid].hw[1] & (1UL << bit)) == 0) { - bit += HUBPI_NINTS; - goto found; - } - - return EINVAL; - -found: - *intrbit = bit; - return 0; -} - -/* - * Register an interrupt handler for a given source, and enable it. - */ -int -ip27_hub_intr_establish(int (*func)(void *), void *arg, int intrbit, - int level, const char *name, struct intrhand *ihstore) -{ - struct intrhand *ih, **anchor; - u_long cpuid = cpu_number(); - int flags; - int s; - -#ifdef DIAGNOSTIC - if (intrbit < 0 || intrbit >= HUBPI_NINTS + HUBPI_NINTS) - return EINVAL; -#endif - - flags = (level & IPL_MPSAFE) ? IH_MPSAFE : 0; - level &= ~IPL_MPSAFE; - - /* - * Widget interrupts are not supposed to be shared - the interrupt - * mask is supposedly large enough for all interrupt sources. - * - * XXX On systems with many widgets and/or nodes, this assumption - * XXX will no longer stand; we'll need to implement interrupt - * XXX sharing at some point. - */ - if (intrbit >= HUBPI_NINTS) - anchor = &hubpi_intrhand1[intrbit % HUBPI_NINTS]; - else - anchor = &hubpi_intrhand0[intrbit]; - if (*anchor != NULL) - return EEXIST; - - if (ihstore == NULL) { - ih = malloc(sizeof(*ih), M_DEVBUF, M_NOWAIT); - if (ih == NULL) - return ENOMEM; - flags |= IH_ALLOCATED; - } else - ih = ihstore; - - ih->ih_next = NULL; - ih->ih_fun = func; - ih->ih_arg = arg; - ih->ih_level = level; - ih->ih_irq = intrbit; - ih->ih_flags = flags; - if (name != NULL) - evcount_attach(&ih->ih_count, name, &ih->ih_level); - - s = splhigh(); - - *anchor = ih; - - hubpi_intem[cpuid].hw[intrbit / HUBPI_NINTS] |= - 1UL << (intrbit % HUBPI_NINTS); - if (intrbit / HUBPI_NINTS != 0) - ip27_hub_intr_makemasks1(); - else - ip27_hub_intr_makemasks0(); - - splx(s); /* causes hw mask update */ - - return 0; -} - -void -ip27_hub_intr_disestablish(int intrbit) -{ - struct intrhand *ih, **anchor; - u_long cpuid = cpu_number(); - int s; - -#ifdef DIAGNOSTIC - if (intrbit < 0 || intrbit >= HUBPI_NINTS + HUBPI_NINTS) - return; -#endif - - if (intrbit >= HUBPI_NINTS) - anchor = &hubpi_intrhand1[intrbit % HUBPI_NINTS]; - else - anchor = &hubpi_intrhand0[intrbit]; - - s = splhigh(); - - if ((ih = *anchor) == NULL) { - splx(s); - return; - } - - *anchor = NULL; - - hubpi_intem[cpuid].hw[intrbit / HUBPI_NINTS] &= - ~(1UL << (intrbit % HUBPI_NINTS)); - if (intrbit / HUBPI_NINTS != 0) - ip27_hub_intr_makemasks1(); - else - ip27_hub_intr_makemasks0(); - - splx(s); - - if (ISSET(ih->ih_flags, IH_ALLOCATED)) - free(ih, M_DEVBUF, sizeof *ih); -} - -void -ip27_hub_intr_clear(int intrbit) -{ - struct cpu_info *ci = curcpu(); - - IP27_RHUB_PI_S(ci->ci_nasid, IP27_SLICE_SUBNODE(ci->ci_slice), - HUBPI_IR_CHANGE, PI_IR_CLR | intrbit); - (void)IP27_RHUB_PI_L(ci->ci_nasid, IP27_SLICE_SUBNODE(ci->ci_slice), - HUBPI_IR0); -} - -void -ip27_hub_intr_set(int intrbit) -{ - struct cpu_info *ci = curcpu(); - - IP27_RHUB_PI_S(ci->ci_nasid, IP27_SLICE_SUBNODE(ci->ci_slice), - HUBPI_IR_CHANGE, PI_IR_SET | intrbit); -} - -void -ip27_hub_splx(int newipl) -{ - struct cpu_info *ci = curcpu(); - - /* Update masks to new ipl. Order highly important! */ - ci->ci_ipl = newipl; - ip27_hub_setintrmask(newipl); - - /* If we still have softints pending trigger processing. */ - if (ci->ci_softpending && newipl < IPL_SOFTINT) - setsoftintr0(); -} - -/* - * Level 0 and level 1 interrupt dispatchers. - */ - -#define INTR_FUNCTIONNAME hubpi_intr0 -#define MASK_FUNCTIONNAME ip27_hub_intr_makemasks0 -#define INTR_LOCAL_DECLS -#define MASK_LOCAL_DECLS \ - struct cpu_info *ci = curcpu(); -#define INTR_GETMASKS \ -do { \ - isr = IP27_LHUB_L(HUBPI_IR0); \ - imr = IP27_LHUB_L(IP27_SLICE_LCPU(ci->ci_slice) == 0 ? \ - HUBPI_CPU0_IMR0 : HUBPI_CPU1_IMR0); \ - bit = HUBPI_INTR0_WIDGET_MAX; \ -} while (0) -#define INTR_MASKPENDING \ -do { \ - IP27_LHUB_S(IP27_SLICE_LCPU(ci->ci_slice) == 0 ? \ - HUBPI_CPU0_IMR0 : HUBPI_CPU1_IMR0, imr & ~isr); \ - (void)IP27_LHUB_L(HUBPI_IR0); \ -} while (0) -#define INTR_IMASK(ipl) hubpi_imask[ci->ci_cpuid][ipl].hw[0] -#ifdef MULTIPROCESSOR -#define INTR_IPI_HOOK(ipl) \ -do { \ - unsigned long ipibit = IP27_SLICE_IPI(ci->ci_slice); \ - unsigned long ipimask = 1 << ipibit; \ - if ((isr & ipimask) && \ - !(hubpi_imask[ci->ci_cpuid][ipl].hw[0] & ipimask)) { \ - struct intrhand *ih = hubpi_intrhand0[ipibit]; \ - ih->ih_fun(ih->ih_arg); \ - isr &= ~ipimask; \ - } \ -} while (0) -#endif /* MULTIPROCESSOR */ -#define INTR_HANDLER(bit) hubpi_intrhand0[bit] -#define INTR_SPURIOUS(bit) \ -do { \ - printf("spurious interrupt, source %d\n", bit); \ -} while (0) -#define INTR_MASKRESTORE \ -do { \ - IP27_LHUB_S(IP27_SLICE_LCPU(ci->ci_slice) == 0 ? \ - HUBPI_CPU0_IMR0 : HUBPI_CPU1_IMR0, imr); \ - (void)IP27_LHUB_L(HUBPI_IR0); \ -} while (0) -#define INTR_MASKSIZE HUBPI_NINTS - -#include <sgi/sgi/intr_template.c> - -#define INTR_FUNCTIONNAME hubpi_intr1 -#define MASK_FUNCTIONNAME ip27_hub_intr_makemasks1 -#define INTR_LOCAL_DECLS -#define MASK_LOCAL_DECLS \ - struct cpu_info *ci = curcpu(); -#define INTR_GETMASKS \ -do { \ - isr = IP27_LHUB_L(HUBPI_IR1); \ - imr = IP27_LHUB_L(IP27_SLICE_LCPU(ci->ci_slice) == 0 ? \ - HUBPI_CPU0_IMR1 : HUBPI_CPU1_IMR1); \ - bit = HUBPI_INTR1_WIDGET_MAX; \ -} while (0) -#define INTR_MASKPENDING \ -do { \ - IP27_LHUB_S(IP27_SLICE_LCPU(ci->ci_slice) == 0 ? \ - HUBPI_CPU0_IMR1 : HUBPI_CPU1_IMR1, imr & ~isr); \ - (void)IP27_LHUB_L(HUBPI_IR1); \ -} while (0) -#define INTR_IMASK(ipl) hubpi_imask[ci->ci_cpuid][ipl].hw[1] -#define INTR_HANDLER(bit) hubpi_intrhand1[bit] -#define INTR_SPURIOUS(bit) \ -do { \ - printf("spurious interrupt, source %d\n", bit + HUBPI_NINTS); \ -} while (0) -#define INTR_MASKRESTORE \ -do { \ - IP27_LHUB_S(IP27_SLICE_LCPU(ci->ci_slice) == 0 ? \ - HUBPI_CPU0_IMR1 : HUBPI_CPU1_IMR1, imr); \ - (void)IP27_LHUB_L(HUBPI_IR1); \ -} while (0) -#define INTR_MASKSIZE HUBPI_NINTS - -#include <sgi/sgi/intr_template.c> - -void -ip27_hub_setintrmask(int level) -{ - struct cpu_info *ci = curcpu(); - u_long imr0, imr1; - - if (IP27_SLICE_LCPU(ci->ci_slice) == 0) { - imr0 = HUBPI_CPU0_IMR0; - imr1 = HUBPI_CPU0_IMR1; - } else { - imr0 = HUBPI_CPU1_IMR0; - imr1 = HUBPI_CPU1_IMR1; - } - - IP27_LHUB_S(imr0, hubpi_intem[ci->ci_cpuid].hw[0] & - ~hubpi_imask[ci->ci_cpuid][level].hw[0]); - (void)IP27_LHUB_L(HUBPI_IR0); - IP27_LHUB_S(imr1, hubpi_intem[ci->ci_cpuid].hw[1] & - ~hubpi_imask[ci->ci_cpuid][level].hw[1]); - (void)IP27_LHUB_L(HUBPI_IR1); -} - -void -ip27_nmi(void *arg) -{ - vaddr_t regs_offs; - register_t *regs, epc; - struct trapframe nmi_frame; - extern int db_ktrap(int, struct trapframe *); - - /* - * Build a ddb frame from the registers saved in the NMI KREGS - * area. - */ - - if (ip35) - regs_offs = IP35_NMI_KREGS_BASE; /* XXX assumes cpu0 */ - else - regs_offs = IP27_NMI_KREGS_BASE; /* XXX assumes cpu0 */ - regs = IP27_UNCAC_ADDR(register_t *, 0, regs_offs); - - memset(&nmi_frame, 0xff, sizeof nmi_frame); - - /* general registers */ - memcpy(&nmi_frame.zero, regs, 32 * sizeof(register_t)); - regs += 32; - nmi_frame.sr = *regs++; /* COP_0_STATUS_REG */ - nmi_frame.cause = *regs++; /* COP_0_CAUSE_REG */ - nmi_frame.pc = *regs++; - nmi_frame.badvaddr = *regs++; /* COP_0_BAD_VADDR */ - epc = *regs++; /* COP_0_EXC_PC */ - regs++; /* COP_0_CACHE_ERR */ - regs++; /* NMI COP_0_STATUS_REG */ - - setsr(getsr() & ~SR_BOOT_EXC_VEC); - printf("NMI, PC = %p RA = %p SR = %08lx EPC = %p\n", - (void *)nmi_frame.pc, (void *)nmi_frame.ra, nmi_frame.sr, - (void *)epc); -#ifdef DDB - (void)db_ktrap(-1, &nmi_frame); -#endif - panic("NMI"); - /* NOTREACHED */ -} - -#ifdef MULTIPROCESSOR - -int -ip27_kl_launch_cpu(klinfo_t *comp, void *arg) -{ - struct cpu_info *ci = curcpu(); - - /* Skip the running CPU. */ - if (comp->nasid == ci->ci_nasid && - comp->physid == ci->ci_slice) - return 0; - - /* XXX Skip CPUs on other nodes. */ - if (comp->nasid != ci->ci_nasid) - return 0; - - if (ip27_ncpus >= MAXCPUS) - return 0; - - ip27_prom_launch_slave(comp->nasid, comp->physid, - ip27_cpu_spinup_trampoline, - SPINUP_TICKET(comp->nasid, comp->physid), 0, 0); - ip27_ncpus++; - - return 0; -} - -int -ip27_kl_launch_cpu_board(lboard_t *board, void *arg) -{ - kl_scan_board(board, KLSTRUCT_CPU, ip27_kl_launch_cpu, arg); - return 0; -} - -int -ip27_kl_attach_cpu(klinfo_t *comp, void *arg) -{ - struct cpu_attach_args caa; - struct cpu_hwinfo hw; - struct cpu_info *ci = curcpu(); - struct device *parent = arg; - klcpu_t *cpucomp; - - /* Skip the running CPU. */ - if (comp->nasid == ci->ci_nasid && - comp->physid == ci->ci_slice) - return 0; - - /* XXX Skip CPUs on other nodes. */ - if (comp->nasid != ci->ci_nasid) - return 0; - - if (ip27_ncpus >= MAXCPUS) - return 0; - - cpucomp = (klcpu_t *)comp; - - hw.c0prid = cpucomp->cpu_prid; - hw.c1prid = cpucomp->cpu_prid; - hw.clock = cpucomp->cpu_speed * 1000000; - hw.tlbsize = 64; - hw.type = (cpucomp->cpu_prid >> 8) & 0xff; - - caa.caa_maa.maa_name = "cpu"; - caa.caa_maa.maa_nasid = comp->nasid; - caa.caa_maa.maa_physid = comp->physid; - caa.caa_hw = &hw; - config_found(parent, &caa, ip27_print); - ip27_ncpus++; - - return 0; -} - -int -ip27_kl_attach_cpu_board(lboard_t *board, void *arg) -{ - kl_scan_board(board, KLSTRUCT_CPU, ip27_kl_attach_cpu, arg); - return 0; -} - -uint -ip27_hub_get_timecount(struct timecounter *tc) -{ - return IP27_RHUB_L(masternasid, HUBPI_RT_COUNT); -} - -void -hw_ipi_intr_set(u_long cpuid) -{ - struct cpu_info *ci = get_cpu_info(cpuid); - int intr; - - intr = IP27_SLICE_IPI(ci->ci_slice); - IP27_RHUB_PI_S(ci->ci_nasid, IP27_SLICE_SUBNODE(ci->ci_slice), - HUBPI_IR_CHANGE, PI_IR_SET | intr); -} - -void -hw_ipi_intr_clear(u_long cpuid) -{ - struct cpu_info *ci = get_cpu_info(cpuid); - int intr; - - intr = IP27_SLICE_IPI(ci->ci_slice); - IP27_RHUB_PI_S(ci->ci_nasid, IP27_SLICE_SUBNODE(ci->ci_slice), - HUBPI_IR_CHANGE, PI_IR_CLR | intr); - (void)IP27_RHUB_PI_L(ci->ci_nasid, IP27_SLICE_SUBNODE(ci->ci_slice), - HUBPI_IR0); -} - -int -hw_ipi_intr_establish(int (*func)(void *), u_long cpuid) -{ - struct cpu_info *ci = get_cpu_info(cpuid); - int intr; - - intr = IP27_SLICE_IPI(ci->ci_slice); - return ip27_hub_intr_establish(func, (void *)cpuid, intr, - IPL_IPI | IPL_MPSAFE, NULL, NULL); -} - -void -hw_cpu_hatch(struct cpu_info *ci) -{ - int s; - - setcurcpu(ci); - - /* - * Make sure we can access the extended address space. - * Note that r10k and later do not allow XUSEG accesses - * from kernel mode unless SR_UX is set. - */ - setsr(getsr() | SR_KX | SR_UX); - - tlb_init(64); - tlb_set_pid(0); - - /* - * Turn off bootstrap exception vectors. - */ - setsr(getsr() & ~SR_BOOT_EXC_VEC); - - /* - * Clear out the I and D caches. - */ - Mips10k_ConfigCache(ci); - Mips_SyncCache(ci); - - printf("cpu%lu launched\n", cpu_number()); - - (*md_startclock)(ci); - - ncpus++; - cpuset_add(&cpus_running, ci); - - mips64_ipi_init(); - ip27_hub_setintrmask(0); - - spl0(); - (void)updateimask(0); - - SCHED_LOCK(s); - cpu_switchto(NULL, sched_chooseproc()); -} - -void -hw_cpu_boot_secondary(struct cpu_info *ci) -{ - vaddr_t kstack; - - kstack = alloc_contiguous_pages(USPACE); - if (kstack == 0) - panic("unable to allocate idle stack\n"); - - __asm__ (".set noreorder\n"); - ci->ci_curprocpaddr = (void *)kstack; - ip27_spinup_a0 = (uint64_t)ci; - ip27_spinup_sp = (uint64_t)(kstack + USPACE); - mips_sync(); - __asm__ (".set reorder\n"); - ip27_spinup_turn = SPINUP_TICKET(ci->ci_nasid, ci->ci_slice); - - while (!cpuset_isset(&cpus_running, ci)) - ; -} - -#endif /* MULTIPROCESSOR */ diff --git a/sys/arch/sgi/sgi/ip30.h b/sys/arch/sgi/sgi/ip30.h deleted file mode 100644 index 22fa1088086..00000000000 --- a/sys/arch/sgi/sgi/ip30.h +++ /dev/null @@ -1,101 +0,0 @@ -/* $OpenBSD: ip30.h,v 1.10 2012/06/17 12:34:19 miod Exp $ */ - -/* - * Copyright (c) 2008, 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Physical memory on Octane starts at 512MB. - * - * This allows the small windows of all widgets to appear under physical - * memory, and the Bridge window (#f) to sport the machine PROM at the - * physical address where the CPU expects it on reset. - */ - -#define IP30_MEMORY_BASE 0x20000000 -#define IP30_MEMORY_ARCBIOS_LIMIT 0x40000000 - -/* - * Specific widget assignment - */ - -#define IP30_HEART_WIDGET 8 -#define IP30_BRIDGE_WIDGET 15 - -#define IP30_IOC_SLOTNO 2 - -/* - * On-board IOC3 specific GPIO registers wiring - */ - -/* Light bar control: 0 to dim, 1 to lit */ -#define IP30_GPIO_WHITE_LED 0 /* actually lightbulbs */ -#define IP30_GPIO_RED_LED 1 -/* Classic Octane (1) vs Octane 2 (0), read only */ -#define IP30_GPIO_CLASSIC 2 - -/* - * Flash PROM physical address, within BRIDGE widget - */ - -#define IP30_FLASH_BASE 0xc00000 -#define IP30_FLASH_SIZE 0x200000 -#define IP30_FLASH_ALT 0xe00000 - -/* - * Multiprocessor configuration area - */ - -#define IP30_MAXCPUS 4 - -#define MPCONF_BASE 0x0000000000000600 -#define MPCONF_LEN 0x80 -#define MPCONF_SHIFT 7 /* Log2(MPCONF_LEN) */ - -#define MPCONF_MAGIC(i) ((i) * MPCONF_LEN + 0x00) -#define MPCONF_PRID(i) ((i) * MPCONF_LEN + 0x04) -#define MPCONF_PHYSID(i) ((i) * MPCONF_LEN + 0x08) -#define MPCONF_VIRTID(i) ((i) * MPCONF_LEN + 0x0c) -#define MPCONF_SCACHESZ(i) ((i) * MPCONF_LEN + 0x10) -#define MPCONF_FANLOADS(i) ((i) * MPCONF_LEN + 0x14) -#define MPCONF_LAUNCH(i) ((i) * MPCONF_LEN + 0x18) -#define MPCONF_RNDVZ(i) ((i) * MPCONF_LEN + 0x20) -#define MPCONF_STACKADDR(i) ((i) * MPCONF_LEN + 0x40) -#define MPCONF_LPARAM(i) ((i) * MPCONF_LEN + 0x48) -#define MPCONF_RPARAM(i) ((i) * MPCONF_LEN + 0x50) -#define MPCONF_IDLEFLAG(i) ((i) * MPCONF_LEN + 0x58) - -#define MPCONF_MAGIC_VAL 0xbaddeed2 - -/* - * Global data area - */ - -#define GDA_BASE 0x0000000000000400 - -#define GDA_MAGIC 0x58464552 /* XFER */ - -#if !defined(_LOCORE) -struct ip30_gda { - uint32_t magic; /* GDA_MAGIC */ - uint32_t promop; - void (*nmi_cb)(void); - uint64_t masterspid; - void *tlb_handlers[3]; - uint64_t nmi_count; -}; - -int ip30_find_video(void); -#endif diff --git a/sys/arch/sgi/sgi/ip30_machdep.c b/sys/arch/sgi/sgi/ip30_machdep.c deleted file mode 100644 index 6638d8671e1..00000000000 --- a/sys/arch/sgi/sgi/ip30_machdep.c +++ /dev/null @@ -1,605 +0,0 @@ -/* $OpenBSD: ip30_machdep.c,v 1.70 2020/08/26 03:29:06 visa Exp $ */ - -/* - * Copyright (c) 2008, 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Octane (IP30) specific code. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/proc.h> -#include <sys/device.h> -#include <sys/tty.h> - -#include <mips64/arcbios.h> -#include <mips64/cache.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/memconf.h> - -#include <uvm/uvm_extern.h> - -#include <sgi/sgi/ip30.h> -#include <sgi/xbow/widget.h> -#include <sgi/xbow/xbow.h> -#include <sgi/xbow/xbowdevs.h> -#include <sgi/xbow/xbridgereg.h> /* BRIDGE_PCI0_MEM_SPACE_BASE */ - -#include <sgi/xbow/xheartreg.h> -#include <sgi/pci/iocreg.h> - -#include <dev/ic/comvar.h> - -extern int mbprint(void *, const char *); - -#ifdef MULTIPROCESSOR -extern int xheart_intr_establish(int (*)(void *), void *, int, int, - const char *, struct intrhand *); -extern void xheart_intr_set(int); -extern void xheart_intr_clear(int); -extern void xheart_setintrmask(int); - -extern struct user *proc0paddr; -#endif - -uint32_t ip30_lights_frob(uint32_t, struct trapframe *); -paddr_t ip30_widget_short(int16_t, u_int); -paddr_t ip30_widget_long(int16_t, u_int); -paddr_t ip30_widget_map(int16_t, u_int, bus_addr_t *, bus_size_t *); -int ip30_widget_id(int16_t, u_int, uint32_t *); -static u_long ip30_get_ncpusfound(void); - -#ifdef DDB -void ip30_nmi(void); /* ip30_nmi.S */ -void ip30_nmi_handler(void); -#endif - -static paddr_t ip30_iocbase; - -static const paddr_t mpconf = - PHYS_TO_XKPHYS(MPCONF_BASE, CCA_COHERENT_EXCLWRITE); - -static int ip30_cpu_exists(int); - -void -ip30_setup() -{ - paddr_t heart; - int bank; - uint32_t memcfg; - uint64_t start, count, end; - u_long cpuspeed; -#ifdef DDB - struct ip30_gda *gda; -#endif - - /* - * Scan for memory. ARCBios reports up to 1GB of memory as available, - * and anything after is reported as reserved. - */ - heart = PHYS_TO_XKPHYS(HEART_PIU_BASE, CCA_NC); - for (bank = 0; bank < 8; bank++) { - memcfg = *(volatile uint32_t *) - (heart + HEART_MEMORY_STATUS + bank * sizeof(uint32_t)); -#ifdef DEBUG - bios_printf("memory bank %d: %08x\n", bank, memcfg); -#endif - - if (!ISSET(memcfg, HEART_MEMORY_VALID)) - continue; - - count = ((memcfg & HEART_MEMORY_SIZE_MASK) >> - HEART_MEMORY_SIZE_SHIFT) + 1; - start = (memcfg & HEART_MEMORY_ADDR_MASK) >> - HEART_MEMORY_ADDR_SHIFT; - - count <<= HEART_MEMORY_UNIT_SHIFT; - start <<= HEART_MEMORY_UNIT_SHIFT; - - /* Physical memory starts at 512MB */ - start += IP30_MEMORY_BASE; - end = start + count; -#ifdef DEBUG - bios_printf("memory from %p to %p\n", - start, end); -#endif - - /* - * Add memory not obtained through ARCBios. - */ - if (start < IP30_MEMORY_BASE + IP30_MEMORY_ARCBIOS_LIMIT) - start = IP30_MEMORY_BASE + IP30_MEMORY_ARCBIOS_LIMIT; -#if 0 - /* - * XXX Temporarily restrict memory to 1.5GB, until the bug - * XXX causing low memory corruption is found. - */ - if (end > 0x80000000UL) - end = 0x80000000UL; -#endif - if (start < end) - memrange_register(atop(start), atop(end), 0); - } - - /* - * Register DMA-reachable memory constraints. - * The xbridge(4) is limited to a 31-bit region (its IOMMU features - * are too restricted to be of use). - */ - dma_constraint.ucr_low = 0; - dma_constraint.ucr_high = (1UL << 31) - 1; - - xbow_widget_base = ip30_widget_short; - xbow_widget_map = ip30_widget_map; - xbow_widget_id = ip30_widget_id; - - bootcpu_hwinfo.c0prid = cp0_get_prid(); - bootcpu_hwinfo.c1prid = cp1_get_prid(); - cpuspeed = bios_getenvint("cpufreq"); - if (cpuspeed < 100) - cpuspeed = 175; /* reasonable default */ - bootcpu_hwinfo.clock = cpuspeed * 1000000; - bootcpu_hwinfo.tlbsize = 64; /* R10000 family */ - bootcpu_hwinfo.type = (bootcpu_hwinfo.c0prid >> 8) & 0xff; - - /* - * Initialize the early console parameters. - * On Octane, the BRIDGE is always widget 15, and IOC3 is always - * mapped in memory space at address 0x500000. - * - * Also, note that by using a direct widget bus_space, there is - * no endianness conversion done on the bus addresses. Which is - * exactly what we need, since the IOC3 doesn't need any. Some - * may consider this an evil abuse of bus_space knowledge, though. - */ - - xbow_build_bus_space(&sys_config.console_io, 0, IP30_BRIDGE_WIDGET); - sys_config.console_io.bus_base = - ip30_widget_long(0, IP30_BRIDGE_WIDGET) + - BRIDGE_PCI0_MEM_SPACE_BASE + 0x500000; - - comconsaddr = IOC3_UARTA_BASE; - comconsfreq = 22000000 / 3; - comconsiot = &sys_config.console_io; - comconsrate = bios_consrate; - -#ifdef DDB - /* - * Setup NMI handler. - */ - gda = (struct ip30_gda *)PHYS_TO_XKPHYS(GDA_BASE, CCA_CACHED); - if (gda->magic == GDA_MAGIC) - gda->nmi_cb = ip30_nmi; -#endif - - /* - * Octane and Octane2 can be told apart with a GPIO source bit - * in the onboard IOC3. - */ - ip30_iocbase = sys_config.console_io.bus_base; - if (*(volatile uint32_t *) - (ip30_iocbase + IOC3_GPPR(IP30_GPIO_CLASSIC)) != 0) - hw_prod = "Octane"; - else - hw_prod = "Octane2"; - - ncpusfound = ip30_get_ncpusfound(); - - _device_register = arcs_device_register; -} - -/* - * Autoconf enumeration - */ - -void -ip30_autoconf(struct device *parent) -{ - struct cpu_attach_args caa; -#ifdef MULTIPROCESSOR - struct cpu_hwinfo hw; - int cpuid; -#endif - - bzero(&caa, sizeof caa); - caa.caa_maa.maa_nasid = masternasid; - caa.caa_maa.maa_name = "cpu"; - caa.caa_hw = &bootcpu_hwinfo; - config_found(parent, &caa, mbprint); - -#ifdef MULTIPROCESSOR - for (cpuid = 1; cpuid < IP30_MAXCPUS; cpuid++) - if (ip30_cpu_exists(cpuid)) { - /* - * Attach other processors with the same hardware - * information as the boot processor, unless we - * can get this information from the MPCONF area; - * since Octane processors should be identical - * (model, speed and cache), this should be safe. - */ - bcopy(&bootcpu_hwinfo, &hw, sizeof(struct cpu_hwinfo)); - hw.c0prid = - *(volatile uint32_t *)(mpconf + MPCONF_PRID(cpuid)); - hw.type = (hw.c0prid >> 8) & 0xff; - hw.l2size = 1 << *(volatile uint32_t *) - (mpconf + MPCONF_SCACHESZ(cpuid)); - caa.caa_hw = &hw; - config_found(parent, &caa, mbprint); - } -#endif - - caa.caa_maa.maa_name = "clock"; - config_found(parent, &caa.caa_maa, mbprint); - caa.caa_maa.maa_name = "xbow"; - config_found(parent, &caa.caa_maa, mbprint); - caa.caa_maa.maa_name = "power"; - config_found(parent, &caa.caa_maa, mbprint); -} - -/* - * Widget mapping. IP30 only has one processor board node, so the nasid - * parameter is ignored. - */ - -paddr_t -ip30_widget_short(int16_t nasid, u_int widget) -{ - return PHYS_TO_XKPHYS(((uint64_t)widget << 24) | (1ULL << 28), CCA_NC); -} - -paddr_t -ip30_widget_long(int16_t nasid, u_int widget) -{ - return PHYS_TO_XKPHYS((uint64_t)(widget) << 36, CCA_NC); -} - -paddr_t -ip30_widget_map(int16_t nasid, u_int widget, bus_addr_t *offs, bus_size_t *len) -{ - paddr_t base; - - /* - * On Octane, the whole widget space is always accessible. - */ - - base = ip30_widget_long(nasid, widget); - *len = (1ULL << 36) - *offs; - - return base + *offs; -} - -/* - * Widget enumeration - */ - -int -ip30_widget_id(int16_t nasid, u_int widget, uint32_t *wid) -{ - paddr_t linkpa, wpa; - - if (widget != 0) { - if (widget < WIDGET_MIN || widget > WIDGET_MAX) - return EINVAL; - - linkpa = ip30_widget_short(nasid, 0) + XBOW_WIDGET_LINK(widget); - if (!ISSET(*(uint32_t *)(linkpa + (WIDGET_LINK_STATUS | 4)), - WIDGET_STATUS_ALIVE)) - return ENXIO; /* not connected */ - } - - wpa = ip30_widget_short(nasid, widget); - if (wid != NULL) - *wid = *(uint32_t *)(wpa + (WIDGET_ID | 4)); - - return 0; -} - -/* - * Figure out which video widget to use. - * - * If we are running with glass console, ConsoleOut will be `video(#)' with - * the optional number being the number of the video device in the ARCBios - * component tree. - * - * Unfortunately, we do not know how to match an ARCBios component to a - * given widget (the PROM can... it's just not sharing this with us). - * - * So simply walk the available widget space and count video devices. - */ - -int -ip30_find_video() -{ - uint widid, head; - uint32_t id, vendor, product; - char *p; - - if (strncmp(bios_console, "video", 5) != 0) - return 0; /* not graphics console */ - - p = bios_console + 5; - switch (*p) { - case '(': - /* 8 widgets max -> single digit */ - p++; - if (*p == ')') - head = 0; - else { - if (*p < '0' || *p > '9') - return 0; - head = *p++ - '0'; - if (*p != ')') - return 0; - } - break; - case '\0': - head = 0; - break; - default: - return 0; - } - - for (widid = WIDGET_MAX; widid >= WIDGET_MIN; widid--) { - if (ip30_widget_id(0, widid, &id) != 0) - continue; - - vendor = WIDGET_ID_VENDOR(id); - product = WIDGET_ID_PRODUCT(id); - - if ((vendor == XBOW_VENDOR_SGI2 && - product == XBOW_PRODUCT_SGI2_ODYSSEY) || - (vendor == XBOW_VENDOR_SGI5 && - product == XBOW_PRODUCT_SGI5_IMPACT) || - (vendor == XBOW_VENDOR_SGI5 && - product == XBOW_PRODUCT_SGI5_KONA)) { - /* found a video device */ - if (head == 0) - return widid; - head--; - } - } - - return 0; -} - -/* - * Fun with the lightbar - */ -uint32_t -ip30_lights_frob(uint32_t hwpend, struct trapframe *cf) -{ - uint32_t gpioold, gpio; - - /* Light bar status: idle - white, user - red, system - both */ - - gpio = gpioold = *(volatile uint32_t *)(ip30_iocbase + IOC3_GPDR); - gpio &= ~((1 << IP30_GPIO_WHITE_LED) | (1 << IP30_GPIO_RED_LED)); - - if (cf->sr & SR_KSU_USER) - gpio |= (1 << IP30_GPIO_RED_LED); - else { - gpio |= (1 << IP30_GPIO_WHITE_LED); - - /* XXX SMP check other CPU is unidle */ - if (curproc != curcpu()->ci_schedstate.spc_idleproc) - gpio |= (1 << IP30_GPIO_RED_LED); - } - - if (gpio != gpioold) - *(volatile uint32_t *)(ip30_iocbase + IOC3_GPDR) = gpio; - - return 0; /* Real clock int handler will claim the interrupt. */ -} - -static int -ip30_cpu_exists(int cpuid) -{ - uint32_t magic = - *(volatile uint32_t *)(mpconf + MPCONF_MAGIC(cpuid)); - return magic == MPCONF_MAGIC_VAL; -} - -u_long -ip30_get_ncpusfound(void) -{ - int i; - int ncpus = 0; - - for (i = 0; i < IP30_MAXCPUS; i++) - if (ip30_cpu_exists(i)) - ncpus++; - - return ncpus; -} - -#ifdef DDB -void -ip30_nmi_handler() -{ - extern int db_ktrap(int, struct trapframe *); - extern void stacktrace(struct trapframe *); - struct trapframe *fr0; - int s; -#ifdef MULTIPROCESSOR - struct trapframe *fr1; - struct cpu_info *ci = curcpu(); -#endif - - setsr(getsr() & ~SR_BOOT_EXC_VEC); - - s = splhigh(); -#ifdef MULTIPROCESSOR - ENABLEIPI(); - - if (!CPU_IS_PRIMARY(ci)) { - for (;;) - continue; - /* NOTREACHED */ - } -#endif - - printf("NMI\n"); - - fr0 = (struct trapframe *)PHYS_TO_XKPHYS(IP30_MEMORY_BASE + 0x4000, - CCA_CACHED); -#ifdef MULTIPROCESSOR - fr1 = (struct trapframe *)PHYS_TO_XKPHYS(IP30_MEMORY_BASE + 0x6000, - CCA_CACHED); -#endif - -#ifdef MULTIPROCESSOR - printf("cpu #0 traceback\n"); -#endif - stacktrace(fr0); -#ifdef MULTIPROCESSOR - printf("cpu #1 traceback\n"); - stacktrace(fr1); -#endif - - db_ktrap(-1, fr0); - - splx(s); - panic("NMI"); - /* NOTREACHED */ -} -#endif - -#ifdef MULTIPROCESSOR -void -hw_cpu_boot_secondary(struct cpu_info *ci) -{ - int cpuid = ci->ci_cpuid; - vaddr_t kstack; - -#ifdef DEBUG - uint64_t stackaddr = - *(volatile uint64_t *)(mpconf + MPCONF_STACKADDR(cpuid)); - uint64_t lparam = - *(volatile uint64_t *)(mpconf + MPCONF_LPARAM(cpuid)); - uint64_t launch = - *(volatile uint64_t *)(mpconf + MPCONF_LAUNCH(cpuid)); - uint32_t magic = - *(volatile uint32_t *)(mpconf + MPCONF_MAGIC(cpuid)); - uint32_t prid = - *(volatile uint32_t *)(mpconf + MPCONF_PRID(cpuid)); - uint32_t physid = - *(volatile uint32_t *)(mpconf + MPCONF_PHYSID(cpuid)); - uint32_t virtid = - *(volatile uint32_t *)(mpconf + MPCONF_VIRTID(cpuid)); - uint32_t scachesz = - *(volatile uint32_t *)(mpconf + MPCONF_SCACHESZ(cpuid)); - uint16_t fanloads = - *(volatile uint16_t *)(mpconf + MPCONF_FANLOADS(cpuid)); - uint64_t rndvz = - *(volatile uint64_t *)(mpconf + MPCONF_RNDVZ(cpuid)); - uint64_t rparam = - *(volatile uint64_t *)(mpconf + MPCONF_RPARAM(cpuid)); - uint32_t idleflag = - *(volatile uint32_t *)(mpconf + MPCONF_IDLEFLAG(cpuid)); - - printf("ci:%p cpuid:%d magic:%x prid:%x physid:%x virtid:%x\n" - "scachesz:%u fanloads:%x launch:%llx rndvz:%llx\n" - "stackaddr:%llx lparam:%llx rparam:%llx idleflag:%x\n", - ci, cpuid, magic, prid, physid, virtid, - scachesz, fanloads, launch, rndvz, - stackaddr, lparam, rparam, idleflag); -#endif - kstack = alloc_contiguous_pages(USPACE); - if (kstack == 0) - panic("unable to allocate idle stack"); - ci->ci_curprocpaddr = (void *)kstack; - - *(volatile uint64_t *)(mpconf + MPCONF_STACKADDR(cpuid)) = - (uint64_t)(kstack + USPACE); - *(volatile uint64_t *)(mpconf + MPCONF_LPARAM(cpuid)) = - (uint64_t)ci; - *(volatile uint64_t *)(mpconf + MPCONF_LAUNCH(cpuid)) = - (uint64_t)hw_cpu_spinup_trampoline; - - while (!cpuset_isset(&cpus_running, ci)) - ; -} - -void -hw_cpu_hatch(struct cpu_info *ci) -{ - int s; - - /* - * Set curcpu address on this processor. - */ - setcurcpu(ci); - - /* - * Make sure we can access the extended address space. - * Note that r10k and later do not allow XUSEG accesses - * from kernel mode unless SR_UX is set. - */ - setsr(getsr() | SR_KX | SR_UX); - - tlb_init(64); - tlb_set_pid(0); - - /* - * Turn off bootstrap exception vectors. - */ - setsr(getsr() & ~SR_BOOT_EXC_VEC); - - /* - * Clear out the I and D caches. - */ - Mips10k_ConfigCache(ci); - Mips_SyncCache(ci); - - (*md_startclock)(ci); - - ncpus++; - cpuset_add(&cpus_running, ci); - - mips64_ipi_init(); - xheart_setintrmask(0); - - spl0(); - (void)updateimask(0); - - SCHED_LOCK(s); - cpu_switchto(NULL, sched_chooseproc()); -} - -int -hw_ipi_intr_establish(int (*func)(void *), u_long cpuid) -{ - return xheart_intr_establish(func, (void *)cpuid, HEART_ISR_IPI(cpuid), - IPL_IPI | IPL_MPSAFE, NULL, NULL); -}; - -void -hw_ipi_intr_set(u_long cpuid) -{ - xheart_intr_set(HEART_ISR_IPI(cpuid)); -} - -void -hw_ipi_intr_clear(u_long cpuid) -{ - xheart_intr_clear(HEART_ISR_IPI(cpuid)); -} -#endif diff --git a/sys/arch/sgi/sgi/ip30_nmi.S b/sys/arch/sgi/sgi/ip30_nmi.S deleted file mode 100644 index f13c50f2b3a..00000000000 --- a/sys/arch/sgi/sgi/ip30_nmi.S +++ /dev/null @@ -1,90 +0,0 @@ -/* $OpenBSD: ip30_nmi.S,v 1.7 2021/02/11 14:44:14 visa Exp $ */ - -/* - * Copyright (c) 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include <machine/asm.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/regnum.h> -#include <machine/cpustate.h> - -#define HW_CPU_NUMBER_REG 0x900000000ff50000 /* HEART_PRID */ - -#include "assym.h" - - .set mips3 - -/* - * The NMI handler routine is shared accross all processors. - * - * When the NMI is triggered, we might be in the middle of an exception - * handler, and relying upon k0 and k1. - * - * Unfortunately, since there is no way to know whether our stack is valid, - * we will need these registers. Therefore NMI are fatal if they occur in - * kernel mode... but we don't even try to resume from them, yet. - */ - .globl ip30_nmi -ip30_nmi: - .set noat - sync - - LOAD_XKPHYS(k0, CCA_CACHED) - LA k1, IP30_MEMORY_BASE + 0x4000 - PTR_ADDU k0, k0, k1 - - /* - * We use part of the low memory as stack and save area. - * This is safe since we reserved this area early. - * We give ourselves 8KB, minus the size of the frame, of stack. - */ - - LA k1, HW_CPU_NUMBER_REG - PTR_L k1, 0(k1) - beqz k1, 1f - nop - - /* CPU #1 */ - PTR_ADDU k0, k0, 0x2000 -1: - /* - * Save state. - * k0 = frame base, k1 = cpu number - */ - - SAVE_CPU(k0, 0) - SAVE_CPU_SREG(k0, 0) - .set at - - PTR_ADDU sp, k0, 0x2000 - - /* - * Interrupts should be disabled. Just in case they aren't, - * enforce this (a1 still contains the value of cop0 SR). - */ - - and a1, a1, ~SR_INT_ENAB - mtc0 a1, COP_0_STATUS_REG - MTC0_SR_IE_HAZARD - - jal ip30_nmi_handler /* ip30_machdep.c */ - nop - -9: - sync - b 9b - nop diff --git a/sys/arch/sgi/sgi/ip32_machdep.c b/sys/arch/sgi/sgi/ip32_machdep.c deleted file mode 100644 index e81ecef122a..00000000000 --- a/sys/arch/sgi/sgi/ip32_machdep.c +++ /dev/null @@ -1,234 +0,0 @@ -/* $OpenBSD: ip32_machdep.c,v 1.24 2020/08/26 03:29:06 visa Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/proc.h> -#include <sys/device.h> -#include <sys/extent.h> -#include <sys/tty.h> - -#include <uvm/uvm_extern.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/memconf.h> - -#include <mips64/arcbios.h> - -#include <sgi/localbus/crimebus.h> -#include <sgi/localbus/macebus.h> -#include <sgi/localbus/macebusvar.h> - -#include <dev/ic/comvar.h> - -extern int tlb_set_wired_get_random(int); /* tlbhandler.S */ - -void crime_configure_memory(void); - -void -crime_configure_memory(void) -{ - volatile u_int64_t *bank_ctrl; - paddr_t addr; - psize_t size; - u_int64_t ctrl0, ctrl; - u_int64_t first_page, last_page; - int bank; -#ifdef DEBUG - int i; -#endif - - bank_ctrl = - (void *)PHYS_TO_CKSEG1(CRIMEBUS_BASE + CRIME_MEM_BANK0_CONTROL); - for (bank = 0; bank < CRIME_MAX_BANKS; bank++) { - ctrl = bank_ctrl[bank]; - addr = (ctrl & CRIME_MEM_BANK_ADDR) << 25; - size = (ctrl & CRIME_MEM_BANK_128MB) ? 128 : 32; - - /* - * Empty banks are reported as duplicates of bank #0. - */ - if (bank == 0) - ctrl0 = ctrl; - else if (ctrl == ctrl0) - continue; - -#ifdef DEBUG - bios_printf("crime: bank %d contains %ld MB at %p\n", - bank, size, addr); -#endif - - /* - * Do not report memory regions below 256MB, since ARCBIOS - * will do. - */ - if (addr < 256 * 1024 * 1024) - continue; - - addr += CRIME_MEMORY_OFFSET; - size *= 1024 * 1024; - first_page = atop(addr); - last_page = atop(addr + size); - - memrange_register(first_page, last_page, 0); - } - -#ifdef DEBUG - for (i = 0; i < MAXMEMSEGS; i++) - if (mem_layout[i].mem_last_page != 0) - bios_printf("MEM %d, %p to %p\n", i, - ptoa(mem_layout[i].mem_first_page), - ptoa(mem_layout[i].mem_last_page)); -#endif -} - -void -ip32_setup() -{ - u_long cpuspeed; - - /* - * IP32 PROM version 4.18: - * PROM Monitor (BE) - * Tue Oct 22 10:58:00 PDT 2002 - * VERSION 4.18 - * O2 R5K/R7K/R10K/R12K - * IRIX 6.5.x IP32prom IP32PROM-v4 - * has incorrect function pointers for all ARCBios calls running in - * CKSEG1 (all the reboot/restart routines). - * - * We attempt to detect this and fix the function pointers here. - * - * XXX 4.16 and 4.17 might need similar fixes. 4.15 is sane. - */ - - if ((vaddr_t)bios_halt == RESET_EXC_VEC + 0x161c && - (vaddr_t)bios_powerdown == RESET_EXC_VEC + 0x1648 && - (vaddr_t)bios_restart == RESET_EXC_VEC + 0x1674 && - (vaddr_t)bios_reboot == RESET_EXC_VEC + 0x16a0 && - (vaddr_t)bios_eim == RESET_EXC_VEC + 0x15f0 && - *(uint32_t *)bios_halt == 0xafbf0014 && - *(uint32_t *)bios_powerdown == 0xafbf0014 && - *(uint32_t *)bios_restart == 0xafb1001c && - *(uint32_t *)bios_eim == 0xafbf0014) { - bios_halt = (void (*)(void))(RESET_EXC_VEC + 0x15bc); - bios_powerdown = (void (*)(void))(RESET_EXC_VEC + 0x15e8); - bios_restart = (void (*)(void))(RESET_EXC_VEC + 0x1614); - bios_reboot = (void (*)(void))(RESET_EXC_VEC + 0x1640); - bios_eim = (void (*)(void))(RESET_EXC_VEC + 0x1590); - } - - crime_configure_memory(); - - /* R12K O2s must run with DSD on. */ - switch ((cp0_get_prid() >> 8) & 0xff) { - case MIPS_R12000: - setsr(getsr() | SR_DSD); - protosr |= SR_DSD; - break; - } - - bootcpu_hwinfo.c0prid = cp0_get_prid(); - bootcpu_hwinfo.c1prid = cp1_get_prid(); - cpuspeed = bios_getenvint("cpufreq"); - if (cpuspeed < 100) - cpuspeed = 180; /* reasonable default */ - bootcpu_hwinfo.clock = cpuspeed * 1000000; - bootcpu_hwinfo.type = (bootcpu_hwinfo.c0prid >> 8) & 0xff; - - /* - * Figure out how many TLB are available. - */ - switch (bootcpu_hwinfo.type) { -#ifdef CPU_RM7000 - case MIPS_RM7000: - /* - * Rev A (version >= 2) CPU's have 64 TLB entries. - * - * However, the last 16 are only enabled if one - * particular configuration bit (mode bit #24) - * is set on cpu reset, so check whether the - * extra TLB are really usable. - * - * If they are disabled, they are nevertheless - * writable, but random TLB insert operations - * will never use any of them. This can be - * checked by writing to the wired register, which - * sets the random register to the number of available - * TLB entries. - * As its value decreases with every instruction - * executed, we use a combined write-then-read routine - * which will return a number close enough to the - * number of entries, so that any value larger than 48 - * means that there are 64 entries available - * (in the current state of that code, the value will - * be the number of entries, minus 2). - */ - bootcpu_hwinfo.tlbsize = 48; - if ((bootcpu_hwinfo.c0prid & 0xf0) >= 0x20) { - /* - * The whole 64 entries exist, although the last - * 16 may not be used by the random placement - * operations, as we are about to check; but we - * need to make them invalid anyway. - */ - tlb_set_wired(48); - tlb_flush(64); - if (tlb_set_wired_get_random(0) > 48) - bootcpu_hwinfo.tlbsize = 64; - } - break; -#endif -#ifdef CPU_R10000 - case MIPS_R10000: - case MIPS_R12000: - case MIPS_R14000: - bootcpu_hwinfo.tlbsize = 64; - break; -#endif - default: /* R5000, RM52xx */ - bootcpu_hwinfo.tlbsize = 48; - break; - } - - /* Setup serial console if ARCS is telling us not to use video. */ - if (strncmp(bios_console, "video", 5) != 0) { - comconsaddr = MACE_ISA_SER1_OFFS; - comconsfreq = 1843200; - comconsiot = &macebus_tag; - comconsrate = bios_consrate; - } - - /* not sure if there is a way to tell O2 and O2+ apart */ - hw_prod = "O2"; - - _device_register = arcs_device_register; -} diff --git a/sys/arch/sgi/sgi/l1.c b/sys/arch/sgi/sgi/l1.c deleted file mode 100644 index b5e39cc3a0b..00000000000 --- a/sys/arch/sgi/sgi/l1.c +++ /dev/null @@ -1,1258 +0,0 @@ -/* $OpenBSD: l1.c,v 1.11 2015/09/19 21:07:04 semarie Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Communication with the L1 controller, on IP35 systems. - * We use a direct 57600 bps serial link from each processor to the L1 chip. - * Information is sent as ppp-encoded packets. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/malloc.h> - -#include <machine/autoconf.h> -#include <machine/mnode.h> -#include <sgi/xbow/hub.h> - -#include <dev/ic/ns16550reg.h> -#include <dev/ic/comreg.h> - -#include <net/ppp_defs.h> - -#include <sgi/sgi/ip27.h> -#include <sgi/sgi/l1.h> - -/* - * L1 communication defines - */ - -/* packet types */ -#define L1PKT_REQUEST 0x00 -#define L1PKT_RESPONSE 0x20 -#define L1PKT_EVENT 0x40 - -/* packet subchannels */ -#define L1CH_CPU0 0x00 /* exclusive channel for cpu 0 */ -#define L1CH_CPU1 0x01 /* exclusive channel for cpu 1 */ -#define L1CH_CPU2 0x02 /* exclusive channel for cpu 2 */ -#define L1CH_CPU3 0x03 /* exclusive channel for cpu 3 */ -#define L1CH_CONSOLE 0x04 /* L1 console */ -/* 05..0f reserved */ -/* 10..1f available for operating system */ -#define L1CH_MISC 0x10 - -/* argument encoding */ -#define L1_ARG_INT 0x00 /* followed by 32 bit BE value */ -#define L1_ARG_ASCII 0x01 /* followed by NUL terminated string */ -#define L1_ARG_BINARY 0x80 /* length in low 7 bits */ - -int l1_serial_getc(int16_t); -int l1_serial_putc(int16_t, u_char); -int l1_serial_ppp_write(int16_t, uint16_t *, u_char, int); -int l1_serial_ppp_read(int16_t, int); -int l1_packet_put(int16_t, u_char *, size_t); -int l1_packet_get(int16_t, u_char *, size_t); -static inline -void l1_packet_put_be32(u_char *, uint32_t); -static inline -void l1_packet_put_be16(u_char *, uint16_t); -static inline -uint32_t l1_packet_get_be32(u_char *); -int l1_packet_get_int(u_char **, size_t *, uint32_t *); -int l1_packet_get_ascii(u_char **, size_t *, char **); -int l1_packet_get_binary(u_char **, size_t *, u_char **, size_t *); -size_t l1_command_build(u_char *, size_t, uint32_t, uint16_t, int, ...); -int l1_receive_response(int16_t, u_char *, size_t *); -int l1_response_to_errno(uint32_t); -int l1_read_board_ia(int16_t, int, u_char **, size_t *); - -static inline -size_t ia_skip(u_char *, size_t, size_t); - -/* l1_packet_get() return values */ -#define L1PG_TIMEOUT -1 -#define L1PG_BADCRC -2 -#define L1PG_SHORTPACKET -3 - -/* - * Basic serial routines (polled) - */ - -#define L1_UART_ADDRESS(nasid, r) \ - IP27_RHSPEC_ADDR(nasid, HSPEC_L1_UART(r)) - -int -l1_serial_getc(int16_t nasid) -{ - uint64_t lsr; - int n; - - for (n = 1000000; n != 0; n--) { - lsr = *(volatile uint64_t *)L1_UART_ADDRESS(nasid, com_lsr); - if ((lsr & LSR_RXRDY) != 0) - break; - } - - if (n == 0) { -#ifdef L1_DEBUG - printf("%s: RX timeout, lsr %02llx\n", __func__, lsr); -#endif - return -1; - } - - return *(volatile uint64_t *)L1_UART_ADDRESS(nasid, com_data) & 0xff; - -} - -int -l1_serial_putc(int16_t nasid, u_char val) -{ - uint64_t lsr; - int n; - - for (n = 1000000; n != 0; n--) { - lsr = *(volatile uint64_t *)L1_UART_ADDRESS(nasid, com_lsr); - if ((lsr & LSR_TXRDY) != 0) - break; - } - - if (n == 0) { -#ifdef L1_DEBUG - printf("%s: TX timeout, lsr %02llx\n", __func__, lsr); -#endif - return EWOULDBLOCK; - } - - *(volatile uint64_t *)L1_UART_ADDRESS(nasid, com_data) = (uint64_t)val; - return 0; -} - -/* - * Single character routines, with optional ppp frame escaping, and optional - * ppp crc update. - */ - -/* - * FCS lookup table as calculated by genfcstab. - * Straight from <net/ppp_tty.c>, only 512 bytes long; probably not worth - * trying to share with outsmart config(8) machinery... - */ -static const u_int16_t fcstab[256] = { - 0x0000, 0x1189, 0x2312, 0x329b, 0x4624, 0x57ad, 0x6536, 0x74bf, - 0x8c48, 0x9dc1, 0xaf5a, 0xbed3, 0xca6c, 0xdbe5, 0xe97e, 0xf8f7, - 0x1081, 0x0108, 0x3393, 0x221a, 0x56a5, 0x472c, 0x75b7, 0x643e, - 0x9cc9, 0x8d40, 0xbfdb, 0xae52, 0xdaed, 0xcb64, 0xf9ff, 0xe876, - 0x2102, 0x308b, 0x0210, 0x1399, 0x6726, 0x76af, 0x4434, 0x55bd, - 0xad4a, 0xbcc3, 0x8e58, 0x9fd1, 0xeb6e, 0xfae7, 0xc87c, 0xd9f5, - 0x3183, 0x200a, 0x1291, 0x0318, 0x77a7, 0x662e, 0x54b5, 0x453c, - 0xbdcb, 0xac42, 0x9ed9, 0x8f50, 0xfbef, 0xea66, 0xd8fd, 0xc974, - 0x4204, 0x538d, 0x6116, 0x709f, 0x0420, 0x15a9, 0x2732, 0x36bb, - 0xce4c, 0xdfc5, 0xed5e, 0xfcd7, 0x8868, 0x99e1, 0xab7a, 0xbaf3, - 0x5285, 0x430c, 0x7197, 0x601e, 0x14a1, 0x0528, 0x37b3, 0x263a, - 0xdecd, 0xcf44, 0xfddf, 0xec56, 0x98e9, 0x8960, 0xbbfb, 0xaa72, - 0x6306, 0x728f, 0x4014, 0x519d, 0x2522, 0x34ab, 0x0630, 0x17b9, - 0xef4e, 0xfec7, 0xcc5c, 0xddd5, 0xa96a, 0xb8e3, 0x8a78, 0x9bf1, - 0x7387, 0x620e, 0x5095, 0x411c, 0x35a3, 0x242a, 0x16b1, 0x0738, - 0xffcf, 0xee46, 0xdcdd, 0xcd54, 0xb9eb, 0xa862, 0x9af9, 0x8b70, - 0x8408, 0x9581, 0xa71a, 0xb693, 0xc22c, 0xd3a5, 0xe13e, 0xf0b7, - 0x0840, 0x19c9, 0x2b52, 0x3adb, 0x4e64, 0x5fed, 0x6d76, 0x7cff, - 0x9489, 0x8500, 0xb79b, 0xa612, 0xd2ad, 0xc324, 0xf1bf, 0xe036, - 0x18c1, 0x0948, 0x3bd3, 0x2a5a, 0x5ee5, 0x4f6c, 0x7df7, 0x6c7e, - 0xa50a, 0xb483, 0x8618, 0x9791, 0xe32e, 0xf2a7, 0xc03c, 0xd1b5, - 0x2942, 0x38cb, 0x0a50, 0x1bd9, 0x6f66, 0x7eef, 0x4c74, 0x5dfd, - 0xb58b, 0xa402, 0x9699, 0x8710, 0xf3af, 0xe226, 0xd0bd, 0xc134, - 0x39c3, 0x284a, 0x1ad1, 0x0b58, 0x7fe7, 0x6e6e, 0x5cf5, 0x4d7c, - 0xc60c, 0xd785, 0xe51e, 0xf497, 0x8028, 0x91a1, 0xa33a, 0xb2b3, - 0x4a44, 0x5bcd, 0x6956, 0x78df, 0x0c60, 0x1de9, 0x2f72, 0x3efb, - 0xd68d, 0xc704, 0xf59f, 0xe416, 0x90a9, 0x8120, 0xb3bb, 0xa232, - 0x5ac5, 0x4b4c, 0x79d7, 0x685e, 0x1ce1, 0x0d68, 0x3ff3, 0x2e7a, - 0xe70e, 0xf687, 0xc41c, 0xd595, 0xa12a, 0xb0a3, 0x8238, 0x93b1, - 0x6b46, 0x7acf, 0x4854, 0x59dd, 0x2d62, 0x3ceb, 0x0e70, 0x1ff9, - 0xf78f, 0xe606, 0xd49d, 0xc514, 0xb1ab, 0xa022, 0x92b9, 0x8330, - 0x7bc7, 0x6a4e, 0x58d5, 0x495c, 0x3de3, 0x2c6a, 0x1ef1, 0x0f78 -}; - -int -l1_serial_ppp_write(int16_t nasid, uint16_t *crc, u_char data, int escape) -{ - /* update crc if necessary */ - if (crc != NULL) - *crc = PPP_FCS(*crc, data); - - /* escape data if necessary */ - if (escape && (data == PPP_FLAG || data == PPP_ESCAPE)) { - if (l1_serial_putc(nasid, PPP_ESCAPE) != 0) - return EWOULDBLOCK; - data ^= PPP_TRANS; - } - - return l1_serial_putc(nasid, data); -} - -int -l1_serial_ppp_read(int16_t nasid, int unescape) -{ - int data; - - if ((data = l1_serial_getc(nasid)) < 0) - return data; - - /* unescape data if necessary */ - if (unescape && data == PPP_ESCAPE) { - if ((data = l1_serial_getc(nasid)) < 0) - return data; - data ^= PPP_TRANS; - } - - return data; -} - -/* - * Complete ppp packet emission and reception. - */ - -int -l1_packet_put(int16_t nasid, u_char *packet, size_t len) -{ - uint16_t crc = PPP_INITFCS; - - /* send incoming packet flag */ - if (l1_serial_ppp_write(nasid, NULL, PPP_FLAG, 0) != 0) - return EWOULDBLOCK; - - /* send packet data */ - while (len-- != 0) - if (l1_serial_ppp_write(nasid, &crc, *packet++, 1) != 0) - return EWOULDBLOCK; - - /* send crc */ - crc ^= PPP_INITFCS; - if (l1_serial_ppp_write(nasid, NULL, crc & 0xff, 1) != 0) - return EWOULDBLOCK; - if (l1_serial_ppp_write(nasid, NULL, (crc >> 8) & 0xff, 1) != 0) - return EWOULDBLOCK; - - /* send final packet byte flag */ - if (l1_serial_ppp_write(nasid, NULL, PPP_FLAG, 0) != 0) - return EWOULDBLOCK; - - return 0; -} - -int -l1_packet_get(int16_t nasid, u_char *buf, size_t buflen) -{ - uint16_t crc; - size_t rcvlen; - int data; - - /* wait for incoming packet flag */ - for (;;) { - data = l1_serial_ppp_read(nasid, 0); - if (data < 0) - return L1PG_TIMEOUT; - if (data == PPP_FLAG) - break; - } - - /* read packet */ - rcvlen = 0; - crc = PPP_INITFCS; - for (;;) { - data = l1_serial_ppp_read(nasid, 1); - if (data < 0) - return L1PG_TIMEOUT; - if (data == PPP_FLAG) /* end of packet */ - break; - if (rcvlen < buflen) - buf[rcvlen] = data; - rcvlen++; - crc = PPP_FCS(crc, data); - } - - if (rcvlen < 2) { -#ifdef L1_DEBUG - printf("%s: short packet\n", __func__); -#endif - return L1PG_SHORTPACKET; - } - - /* check CRC */ - rcvlen -= 2; /* crc bytes */ - if (crc != PPP_GOODFCS) { -#ifdef L1_DEBUG - printf("%s: CRC error (%04x)\n", __func__, crc); -#endif - return L1PG_BADCRC; - } - - return rcvlen; -} - -/* - * L1 packet construction and deconstruction helpers - */ - -static inline void -l1_packet_put_be32(u_char *buf, uint32_t data) -{ - *buf++ = data >> 24; - *buf++ = data >> 16; - *buf++ = data >> 8; - *buf++ = data; -} - -static inline void -l1_packet_put_be16(u_char *buf, uint16_t data) -{ - *buf++ = data >> 8; - *buf++ = data; -} - -static inline uint32_t -l1_packet_get_be32(u_char *buf) -{ - uint32_t data; - - data = *buf++; - data <<= 8; - data |= *buf++; - data <<= 8; - data |= *buf++; - data <<= 8; - data |= *buf++; - - return data; -} - -int -l1_packet_get_int(u_char **buf, size_t *buflen, uint32_t *rval) -{ - u_char *b = *buf; - - if (*buflen < 5) - return EIO; - - if (*b++ != L1_ARG_INT) - return EINVAL; - - *rval = l1_packet_get_be32(b); - - b += 4; - *buf = b; - *buflen -= 5; - - return 0; -} - -int -l1_packet_get_ascii(u_char **buf, size_t *buflen, char **rval) -{ - u_char *b = *buf; - u_char *s, *e; - - if (*buflen < 2) - return EIO; - - if (*b != L1_ARG_ASCII) - return EINVAL; - - /* check for a terminating NUL within the given bounds */ - e = b + *buflen; - for (s = b + 1; s != e; s++) - if (*s == '\0') - break; - if (s == e) - return ENOMEM; - - *rval = (char *)b + 1; - - s++; - *buflen -= s - b; - *buf = s; - - return 0; -} - -int -l1_packet_get_binary(u_char **buf, size_t *buflen, u_char **rval, size_t *rlen) -{ - u_char *b = *buf; - size_t datalen; - - if (*buflen < 1) - return EIO; - - if ((*b & L1_ARG_BINARY) == 0) - return EINVAL; - - datalen = *b & ~L1_ARG_BINARY; - if (*buflen < 1 + datalen) - return ENOMEM; - - b++; - *rval = b; - *rlen = datalen; - *buflen -= 1 + datalen; - b += datalen; - *buf = b; - - return 0; -} - -/* - * Build a whole request packet. - */ - -size_t -l1_command_build(u_char *buf, size_t buflen, uint32_t address, uint16_t request, - int nargs, ...) -{ - va_list ap; - uint32_t data; - size_t len = 0; - int argtype; - const char *str; - - /* - * Setup packet header (type, channel, address, request) - */ - - if (buflen >= 1) { - *buf++ = L1PKT_REQUEST | L1CH_MISC; - buflen--; - } - len++; - - if (buflen >= 4) { - l1_packet_put_be32(buf, address); - buf += 4; - buflen -= 4; - } - len += 4; - - if (buflen >= 2) { - l1_packet_put_be16(buf, request); - buf += 2; - buflen -= 2; - } - len += 2; - - /* - * Setup command arguments - */ - - if (buflen >= 1) { - *buf++ = nargs; - buflen--; - } - len++; - - va_start(ap, nargs); - while (nargs-- != 0) { - argtype = va_arg(ap, int); - switch (argtype) { - case L1_ARG_INT: - data = va_arg(ap, uint32_t); - if (buflen >= 5) { - *buf++ = L1_ARG_INT; - l1_packet_put_be32(buf, data); - buf += 4; - buflen -= 5; - } - len += 5; - break; - case L1_ARG_ASCII: - str = va_arg(ap, const char *); - data = strlen(str); - if (buflen >= data + 2) { - *buf++ = L1_ARG_ASCII; - memcpy(buf, str, data + 1); - buf += data + 1; - buflen -= data + 2; - } - len += data + 2; - break; - case L1_ARG_BINARY: - data = (uint32_t)va_arg(ap, size_t); /* size */ - str = va_arg(ap, const char *); /* data */ - if (buflen >= 1 + data) { - *buf++ = L1_ARG_BINARY | data; - memcpy(buf, str, data); - buf += data; - buflen -= data + 1; - } - len += data + 1; - break; - } - } - va_end(ap); - - return len; -} - -/* - * Get a packet response, ignoring any other packet seen in between. - * Note that despite being the only user of L1 in the kernel, we may - * receive event packets from the console. - */ -int -l1_receive_response(int16_t nasid, u_char *pkt, size_t *pktlen) -{ - int rc; - - for (;;) { - rc = l1_packet_get(nasid, pkt, *pktlen); - if (rc == L1PG_TIMEOUT) - return EWOULDBLOCK; - - if (rc < 0) /* bad packet */ - continue; - - if (pkt[0] != (L1PKT_RESPONSE | L1CH_MISC)) { -#ifdef L1_DEBUG - printf("unexpected L1 packet: head %02x\n", pkt[0]); -#endif - continue; /* it's not our response */ - } - - *pktlen = (size_t)rc; - return 0; - } -} - -/* - * Process a response code. - */ -int -l1_response_to_errno(uint32_t response) -{ - int rc; - - switch (response) { - case L1_RESP_OK: - rc = 0; - break; - case L1_RESP_INVAL: - rc = EINVAL; - break; - case L1_RESP_NXDATA: - rc = ENXIO; - break; - default: -#ifdef L1_DEBUG - printf("unexpected L1 response code: %08x\n", response); -#endif - rc = EIO; - break; - } - - return rc; -} - -/* - * Read a board IA information record from EEPROM - */ - -#define EEPROM_CHUNK 0x40 - -int -l1_read_board_ia(int16_t nasid, int type, u_char **ria, size_t *rialen) -{ - u_char pkt[64 + EEPROM_CHUNK]; /* command and response packet buffer */ - u_char *pktbuf, *chunk, *ia = NULL; - size_t pktlen, chunklen, ialen, iapos; - uint32_t data; - int rc; - - /* - * Build a first packet, asking for 0 bytes to be read. - */ - pktlen = l1_command_build(pkt, sizeof pkt, - L1_ADDRESS(type, L1_ADDRESS_LOCAL | L1_TASK_GENERAL), - L1_REQ_EEPROM, 4, - L1_ARG_INT, (uint32_t)L1_EEP_LOGIC, - L1_ARG_INT, (uint32_t)L1_EEP_BOARD, - L1_ARG_INT, (uint32_t)0, /* offset */ - L1_ARG_INT, (uint32_t)0); /* size */ - if (pktlen > sizeof pkt) { -#ifdef DIAGNOSTIC - panic("%s: L1 command packet too large (%zu) for buffer", - __func__, pktlen); -#endif - return ENOMEM; - } - - if (l1_packet_put(nasid, pkt, pktlen) != 0) - return EWOULDBLOCK; - - pktlen = sizeof pkt; - if (l1_receive_response(nasid, pkt, &pktlen) != 0) - return EWOULDBLOCK; - - if (pktlen < 6) { -#ifdef L1_DEBUG - printf("truncated response (length %zu)\n", pktlen); -#endif - return EIO; - } - - /* - * Check the response code. - */ - - data = l1_packet_get_be32(&pkt[1]); - rc = l1_response_to_errno(data); - if (rc != 0) - return rc; - - /* - * EEPROM read commands should return either one or two values: - * the first value is the size of the remaining EEPROM data, and - * the second value is the data read itself, if we asked for a - * nonzero size in the command (that size might be shorter than - * the data we asked for). - */ - - if (pkt[5] != 1) { -#ifdef L1_DEBUG - printf("unexpected L1 response: %d values\n", pkt[5]); -#endif - return EIO; - } - - pktbuf = pkt + 6; - pktlen -= 6; - - if (l1_packet_get_int(&pktbuf, &pktlen, &data) != 0) { -#ifdef L1_DEBUG - printf("unable to parse response as integer\n"); -#endif - return EIO; - } - - /* - * Now that we know the size of the IA entry, allocate memory for it. - */ - - ialen = (size_t)data; - ia = (u_char *)malloc(ialen, M_DEVBUF, M_NOWAIT); - if (ia == NULL) - return ENOMEM; - - /* - * Read the EEPROM contents in small chunks, so as not to keep L1 - * busy for too long. - */ - - iapos = 0; - while (iapos < ialen) { - /* - * Build a command packet, this time actually reading data. - */ - pktlen = l1_command_build(pkt, sizeof pkt, - L1_ADDRESS(type, L1_ADDRESS_LOCAL | L1_TASK_GENERAL), - L1_REQ_EEPROM, 4, - L1_ARG_INT, (uint32_t)L1_EEP_LOGIC, - L1_ARG_INT, (uint32_t)L1_EEP_BOARD, - L1_ARG_INT, (uint32_t)iapos, - L1_ARG_INT, (uint32_t)EEPROM_CHUNK); - /* no need to check size again, it's the same size as earlier */ - - if (l1_packet_put(nasid, pkt, pktlen) != 0) { - rc = EWOULDBLOCK; - goto fail; - } - - pktlen = sizeof pkt; - if (l1_receive_response(nasid, pkt, &pktlen) != 0) { - rc = EWOULDBLOCK; - goto fail; - } - - if (pktlen < 6) { -#ifdef L1_DEBUG - printf("truncated response (length %zu)\n", pktlen); -#endif - rc = EIO; - goto fail; - } - - /* - * Check the response code. - */ - - data = l1_packet_get_be32(&pkt[1]); - rc = l1_response_to_errno(data); - if (rc != 0) - goto fail; - - if (pkt[5] != 2) { -#ifdef L1_DEBUG - printf("unexpected L1 response: %d values\n", pkt[5]); -#endif - rc = EIO; - goto fail; - } - - pktbuf = pkt + 6; - pktlen -= 6; - - if (l1_packet_get_int(&pktbuf, &pktlen, &data) != 0) { -#ifdef L1_DEBUG - printf("unable to parse first response as integer\n"); -#endif - rc = EIO; - goto fail; - } - - if (l1_packet_get_binary(&pktbuf, &pktlen, - &chunk, &chunklen) != 0) { -#ifdef L1_DEBUG - printf("unable to parse second response as binary\n"); -#endif - rc = EIO; - goto fail; - } - - /* should not happen, but we don't like infinite loops */ - if (chunklen == 0) { -#ifdef L1_DEBUG - printf("read command returned 0 bytes\n"); -#endif - rc = EIO; - goto fail; - } - - memcpy(ia + iapos, chunk, chunklen); - iapos += chunklen; -#ifdef L1_DEBUG - printf("got %02zx bytes of eeprom, %zx/%zx\n", - chunklen, iapos, ialen); -#endif - } - - /* - * Verify the checksum - */ - - chunk = ia; - iapos = ialen; - data = 0; - while (iapos-- != 0) - data += *chunk++; - if ((data & 0xff) != 0) { -#ifdef L1_DEBUG - printf("wrong IA checksum\n"); -#endif - rc = EINVAL; - goto fail; - } - - *ria = ia; - *rialen = ialen; - return 0; - -fail: - free(ia, M_DEVBUF, ialen); - return rc; -} - -/* - * Information Area (IA) decoding helpers - * - * The format of an Information Area is as follows: - * B format byte (00) - * B length in 8 byte units - * B language (00 = english) - * 3B manufacturing date, minutes since 1/1/1996 - * B type/length of manufacturer name string (up to 20 chars) - * #B manufacturer name - * B type/length of product name string (up to 14 chars) - * #B product name - * B type/length of serial number (up to 6 chars) - * #B serial number - * B type/length of part number (up to 10 chars) - * #B part number - * B FRU file id - * B type/length of board rev (always 0xC2) - * 2B board revision - * B type/length of eeprom size field (0x01) - * 1B size code for eeprom (02) - * B type/length of temp waiver field (0xC2) - * 2B temp waiver - * - * and then in main boards only: - * G, P and Y encryption keys, each being - * B type/length (0x04) - * 4B key - * - * and then on main boards being I-Bricks only: - * B type/length of mac address (as ascii string) - * 12B mac address - * followed by IEEE1394 configuration info, as type/length followed - * by data again. - * - * A 0xC1 byte is the EOF record, and the last byte is a checksum. - * - * Type/length encoding is done as follows: - * bits 7-6 are the type: - * 00 binary data - * 01 BCD - * 02 packed 6 bit ascii - * 03 regular 8 bit ascii - * bits 5-0 are the length. - */ - -#define IA_TYPE_SHIFT 6 -#define IA_TYPE_BINARY 0 -#define IA_TYPE_BCD 1 -#define IA_TYPE_PACKED 2 -#define IA_TYPE_ASCII 3 -#define IA_LENGTH_MASK 0x3f - -#define IA_TL(t,l) (((t) << IA_TYPE_SHIFT) | (l)) - -#define IA_EOF IA_TL(IA_TYPE_ASCII, 1) - -static inline size_t -ia_skip(u_char *ia, size_t iapos, size_t ialen) -{ - size_t npos; - - ia += iapos; - - /* don't go past EOF marker */ - if (*ia == IA_EOF) - return iapos; - - npos = iapos + 1 + (*ia & IA_LENGTH_MASK); - return npos >= ialen ? iapos : npos; -} - -int -l1_get_brick_ethernet_address(int16_t nasid, uint8_t *enaddr) -{ - u_char *ia; - size_t iapos, ialen; - char hexaddr[18], *d, *s; - int type; - int rc; - - /* - * If we are running on a C-Brick, the Ethernet address is stored - * in the matching I-Brick. - */ - if (sys_config.system_subtype == IP35_CBRICK) - type = L1_TYPE_IOBRICK; - else - type = L1_TYPE_L1; - - /* read the Board IA of this node */ - rc = l1_read_board_ia(nasid, type, &ia, &ialen); - if (rc != 0) - return rc; - - /* simple sanity checks */ - if (ia[0] != 0 || ia[1] < 2 || ia[1] * 8UL > ialen) { - rc = EINVAL; - goto out; - } - - /* skip fixed part */ - iapos = 6; - /* skip 4 records */ - iapos = ia_skip(ia, iapos, ialen); - iapos = ia_skip(ia, iapos, ialen); - iapos = ia_skip(ia, iapos, ialen); - iapos = ia_skip(ia, iapos, ialen); - /* skip FRU */ - if (iapos < ialen - 1) - iapos++; - /* skip 3 records */ - iapos = ia_skip(ia, iapos, ialen); - iapos = ia_skip(ia, iapos, ialen); - iapos = ia_skip(ia, iapos, ialen); - /* skip encryption key records if applicable */ - if (iapos < ialen && ia[iapos] == IA_TL(IA_TYPE_BINARY, 4)) { - iapos = ia_skip(ia, iapos, ialen); - iapos = ia_skip(ia, iapos, ialen); - iapos = ia_skip(ia, iapos, ialen); - } - /* check the next record looks like an Ethernet address */ - if (iapos >= ialen - 1 - 12 || ia[iapos] != IA_TL(IA_TYPE_ASCII, 12)) { - rc = EINVAL; - goto out; - } - - iapos++; - s = (char *)ia + iapos; - d = hexaddr; - *d++ = *s++; *d++ = *s++; *d++ = ':'; - *d++ = *s++; *d++ = *s++; *d++ = ':'; - *d++ = *s++; *d++ = *s++; *d++ = ':'; - *d++ = *s++; *d++ = *s++; *d++ = ':'; - *d++ = *s++; *d++ = *s++; *d++ = ':'; - *d++ = *s++; *d++ = *s++; *d++ = '\0'; - enaddr_aton(hexaddr, enaddr); - -out: - free(ia, M_DEVBUF, ialen); - return rc; -} - -/* - * Issue an arbitrary L1 command. - */ -int -l1_exec_command(int16_t nasid, const char *cmd) -{ - u_char pkt[64 + 64]; /* command and response packet buffer */ - size_t pktlen; - uint32_t data; - int rc; - - /* - * Build the command packet. - */ - pktlen = l1_command_build(pkt, sizeof pkt, - L1_ADDRESS(L1_TYPE_L1, L1_ADDRESS_LOCAL | L1_TASK_COMMAND), - L1_REQ_EXEC_CMD, 1, - L1_ARG_ASCII, cmd); - if (pktlen > sizeof pkt) { -#ifdef DIAGNOSTIC - panic("%s: L1 command packet too large (%zu) for buffer", - __func__, pktlen); -#endif - return ENOMEM; - } - - if (l1_packet_put(nasid, pkt, pktlen) != 0) - return EWOULDBLOCK; - - pktlen = sizeof pkt; - if (l1_receive_response(nasid, pkt, &pktlen) != 0) - return EWOULDBLOCK; - - if (pktlen < 6) { -#ifdef L1_DEBUG - printf("truncated response (length %zu)\n", pktlen); -#endif - return EIO; - } - - /* - * Check the response code. - */ - - data = l1_packet_get_be32(&pkt[1]); - rc = l1_response_to_errno(data); - if (rc != 0) - return rc; - - /* - * We do not expect anything in return. - */ - - if (pkt[5] != 0) { -#ifdef L1_DEBUG - printf("unexpected L1 response: %d values\n", pkt[5]); -#endif - return EIO; - } - - return 0; -} - -/* - * Get a DIMM SPD record. - */ - -int -l1_get_brick_spd_record(int16_t nasid, int dimm, u_char **rspd, size_t *rspdlen) -{ - u_char pkt[64 + EEPROM_CHUNK]; /* command and response packet buffer */ - u_char *pktbuf, *chunk, *spd = NULL; - size_t pktlen, chunklen, spdlen, spdpos; - uint32_t address, data; - int rc; - - /* - * The L1 address of SPD records differs between Fuel and Origin 350 - * systems. This is likely because the Fuel is a single-PIMM system, - * while all other IP35 are dual-PIMM, and thus carry one more PIMM - * record at a lower address (and are interleaving DIMM accesses). - * Since Fuel is also a single-node system, we can safely check for - * the system subtype to decide which address to use. - */ - switch (sys_config.system_subtype) { - case IP35_FUEL: - address = L1_EEP_DIMM_NOINTERLEAVE(dimm); - break; - case IP35_CBRICK: - address = L1_EEP_DIMM_INTERLEAVE(L1_EEP_DIMM_BASE_CBRICK, dimm); - break; - default: - address = - L1_EEP_DIMM_INTERLEAVE(L1_EEP_DIMM_BASE_CHIMERA, dimm); - break; - } - - /* - * Build a first packet, asking for 0 bytes to be read. - */ - pktlen = l1_command_build(pkt, sizeof pkt, - L1_ADDRESS(L1_TYPE_L1, L1_ADDRESS_LOCAL | L1_TASK_GENERAL), - L1_REQ_EEPROM, 4, - L1_ARG_INT, address, - L1_ARG_INT, (uint32_t)L1_EEP_SPD, - L1_ARG_INT, (uint32_t)0, /* offset */ - L1_ARG_INT, (uint32_t)0); /* size */ - if (pktlen > sizeof pkt) { -#ifdef DIAGNOSTIC - panic("%s: L1 command packet too large (%zu) for buffer", - __func__, pktlen); -#endif - return ENOMEM; - } - - if (l1_packet_put(nasid, pkt, pktlen) != 0) - return EWOULDBLOCK; - - pktlen = sizeof pkt; - if (l1_receive_response(nasid, pkt, &pktlen) != 0) - return EWOULDBLOCK; - - if (pktlen < 6) { -#ifdef L1_DEBUG - printf("truncated response (length %zu)\n", pktlen); -#endif - return EIO; - } - - /* - * Check the response code. - */ - - data = l1_packet_get_be32(&pkt[1]); - rc = l1_response_to_errno(data); - if (rc != 0) - return rc; - - /* - * EEPROM read commands should return either one or two values: - * the first value is the size of the remaining EEPROM data, and - * the second value is the data read itself, if we asked for a - * nonzero size in the command (that size might be shorter than - * the data we asked for). - */ - - if (pkt[5] != 1) { -#ifdef L1_DEBUG - printf("unexpected L1 response: %d values\n", pkt[5]); -#endif - return EIO; - } - - pktbuf = pkt + 6; - pktlen -= 6; - - if (l1_packet_get_int(&pktbuf, &pktlen, &data) != 0) { -#ifdef L1_DEBUG - printf("unable to parse response as integer\n"); -#endif - return EIO; - } - - /* - * Now that we know the size of the spd record, allocate memory for it. - */ - - spdlen = (size_t)data; - spd = (u_char *)malloc(spdlen, M_DEVBUF, M_NOWAIT); - if (spd == NULL) - return ENOMEM; - - /* - * Read the EEPROM contents in small chunks, so as not to keep L1 - * busy for too long. - */ - - spdpos = 0; - while (spdpos < spdlen) { - /* - * Build a command packet, this time actually reading data. - */ - pktlen = l1_command_build(pkt, sizeof pkt, - L1_ADDRESS(L1_TYPE_L1, L1_ADDRESS_LOCAL | L1_TASK_GENERAL), - L1_REQ_EEPROM, 4, - L1_ARG_INT, address, - L1_ARG_INT, (uint32_t)L1_EEP_SPD, - L1_ARG_INT, (uint32_t)spdpos, - L1_ARG_INT, (uint32_t)EEPROM_CHUNK); - /* no need to check size again, it's the same size as earlier */ - - if (l1_packet_put(nasid, pkt, pktlen) != 0) { - rc = EWOULDBLOCK; - goto fail; - } - - pktlen = sizeof pkt; - if (l1_receive_response(nasid, pkt, &pktlen) != 0) { - rc = EWOULDBLOCK; - goto fail; - } - - if (pktlen < 6) { -#ifdef L1_DEBUG - printf("truncated response (length %zu)\n", pktlen); -#endif - rc = EIO; - goto fail; - } - - /* - * Check the response code. - */ - - data = l1_packet_get_be32(&pkt[1]); - rc = l1_response_to_errno(data); - if (rc != 0) - goto fail; - - if (pkt[5] != 2) { -#ifdef L1_DEBUG - printf("unexpected L1 response: %d values\n", pkt[5]); -#endif - rc = EIO; - goto fail; - } - - pktbuf = pkt + 6; - pktlen -= 6; - - if (l1_packet_get_int(&pktbuf, &pktlen, &data) != 0) { -#ifdef L1_DEBUG - printf("unable to parse first response as integer\n"); -#endif - rc = EIO; - goto fail; - } - - if (l1_packet_get_binary(&pktbuf, &pktlen, - &chunk, &chunklen) != 0) { -#ifdef L1_DEBUG - printf("unable to parse second response as binary\n"); -#endif - rc = EIO; - goto fail; - } - - /* should not happen, but we don't like infinite loops */ - if (chunklen == 0) { -#ifdef L1_DEBUG - printf("read command returned 0 bytes\n"); -#endif - rc = EIO; - goto fail; - } - - memcpy(spd + spdpos, chunk, chunklen); - spdpos += chunklen; -#ifdef L1_DEBUG - printf("got %02zx bytes of eeprom, %zx/%zx\n", - chunklen, spdpos, spdlen); -#endif - } - - *rspd = spd; - *rspdlen = spdlen; - return 0; - -fail: - free(spd, M_DEVBUF, spdlen); - return rc; -} - -int -l1_display(int16_t nasid, int down, const char *message) -{ - char line[1 + 12]; - u_char pkt[64]; /* command packet buffer */ - size_t pktlen; - uint32_t data; - int rc; - - if (sys_config.system_subtype == IP35_FUEL) - return ENXIO; - - /* pad the line with spaces and truncate at 12 chars */ - (void)snprintf(line, sizeof line, "%s ", message); - - /* - * Build the command packet. - */ - pktlen = l1_command_build(pkt, sizeof pkt, - L1_ADDRESS(L1_TYPE_L1, L1_ADDRESS_LOCAL | L1_TASK_GENERAL), - down ? L1_REQ_DISP2 : L1_REQ_DISP1, 1, - L1_ARG_ASCII, line); - if (pktlen > sizeof pkt) { -#ifdef DIAGNOSTIC - panic("%s: L1 command packet too large (%zu) for buffer", - __func__, pktlen); -#endif - return ENOMEM; - } - - if (l1_packet_put(nasid, pkt, pktlen) != 0) - return EWOULDBLOCK; - - pktlen = sizeof pkt; - if (l1_receive_response(nasid, pkt, &pktlen) != 0) - return EWOULDBLOCK; - - if (pktlen < 6) { -#ifdef L1_DEBUG - printf("truncated response (length %zu)\n", pktlen); -#endif - return EIO; - } - - /* - * Check the response code. - */ - - data = l1_packet_get_be32(&pkt[1]); - rc = l1_response_to_errno(data); - if (rc != 0) - return rc; - - /* - * We do not expect anything in return. - */ - - if (pkt[5] != 0) { -#ifdef L1_DEBUG - printf("unexpected L1 response: %d values\n", pkt[5]); -#endif - return EIO; - } - - return 0; -} diff --git a/sys/arch/sgi/sgi/l1.h b/sys/arch/sgi/sgi/l1.h deleted file mode 100644 index 9d1216179dc..00000000000 --- a/sys/arch/sgi/sgi/l1.h +++ /dev/null @@ -1,98 +0,0 @@ -/* $OpenBSD: l1.h,v 1.6 2014/11/25 19:08:42 miod Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * High-level L1 communication defines - */ - -/* L1 command types and destination addresses */ -#define L1_ADDRESS(type,addr) (((type) << 28) | (addr)) - -#define L1_TYPE_L1 0x00 -#define L1_TYPE_L2 0x01 -#define L1_TYPE_L3 0x02 -#define L1_TYPE_CBRICK 0x03 -#define L1_TYPE_IOBRICK 0x04 - -#define L1_ADDRESS_RACK_MASK 0x0ffc0000 -#define L1_ADDRESS_RACK_SHIFT 18 -#define L1_ADDRESS_RACK_LOCAL 0x3ff -#define L1_ADDRESS_BAY_MASK 0x0003f000 -#define L1_ADDRESS_BAY_SHIFT 12 -#define L1_ADDRESS_BAY_LOCAL 0x3f -#define L1_ADDRESS_TASK_MASK 0x0000001f -#define L1_ADDRESS_TASK_SHIFT 0 - -#define L1_ADDRESS_LOCAL \ - ((L1_ADDRESS_RACK_LOCAL << L1_ADDRESS_RACK_SHIFT) | \ - (L1_ADDRESS_BAY_LOCAL << L1_ADDRESS_BAY_SHIFT)) - -#define L1_TASK_INVALID 0x00 -#define L1_TASK_ROUTER 0x01 -#define L1_TASK_SYSMGMT 0x02 -#define L1_TASK_COMMAND 0x03 -#define L1_TASK_ENVIRONMENT 0x04 -#define L1_TASK_BEDROCK 0x05 -#define L1_TASK_GENERAL 0x06 - -/* response codes */ -#define L1_RESP_OK ((uint32_t)0) -#define L1_RESP_NXDATA ((uint32_t)-0x68) -#define L1_RESP_INVAL ((uint32_t)-0x6b) - -/* - * Various commands (very incomplete list) - */ - -/* L1_TASK_COMMAND requests */ -#define L1_REQ_EXEC_CMD 0x0000 /* interpret plaintext command */ - -/* L1_TASK_GENERAL requests */ -#define L1_REQ_EEPROM 0x0006 /* access eeprom */ -#define L1_REQ_DISP1 0x1004 /* display text on LCD first line */ -#define L1_REQ_DISP2 0x1005 /* display text on LCD second line */ - -/* L1_REQ_EEPROM additional argument value */ -/* non C-brick component */ -#define L1_EEP_POWER 0x00 /* power board */ -#define L1_EEP_LOGIC 0x01 /* logic board */ -/* C-brick component */ -#define L1_EEP_DIMM_NOINTERLEAVE_BASE 0x04 -#define L1_EEP_DIMM_BASE_CBRICK 0x03 -#define L1_EEP_DIMM_BASE_CHIMERA 0x05 -#define L1_EEP_DIMM_NOINTERLEAVE(dimm) \ - (L1_EEP_DIMM_NOINTERLEAVE_BASE + (dimm)) -#define L1_EEP_DIMM_INTERLEAVE(base, dimm) \ - ((base) + ((dimm) >> 1) + ((dimm) & 0x01 ? 4 : 0)) -/* ia code */ -#define L1_EEP_CHASSIS 0x01 /* chassis ia */ -#define L1_EEP_BOARD 0x02 /* board ia */ -#define L1_EEP_IUSE 0x03 /* internal use ia */ -#define L1_EEP_SPD 0x04 /* spd record */ - -#define L1_SPD_DIMM_MAX 8 - -struct spdmem_attach_args { - struct mainbus_attach_args maa; - int dimm; -}; - -int l1_display(int16_t, int, const char *); -int l1_exec_command(int16_t, const char *); -int l1_get_brick_ethernet_address(int16_t, uint8_t *); -int l1_get_brick_spd_record(int16_t, int, u_char **, size_t *); diff --git a/sys/arch/sgi/sgi/locore.S b/sys/arch/sgi/sgi/locore.S deleted file mode 100644 index 39e076bc880..00000000000 --- a/sys/arch/sgi/sgi/locore.S +++ /dev/null @@ -1,144 +0,0 @@ -/* $OpenBSD: locore.S,v 1.20 2021/02/11 14:44:14 visa Exp $ */ - -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ -#include <sys/errno.h> -#include <sys/syscall.h> - -#include <machine/param.h> -#include <machine/asm.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/regnum.h> -#include <machine/cpustate.h> - -#include "assym.h" - - .set mips3 - .set noreorder # Noreorder is default style! - - .globl locore_start - .ent locore_start, 0 -locore_start: - MFC0 v0, COP_0_STATUS_REG - LI v1, ~SR_INT_ENAB - and v0, v1 - MTC0 v0, COP_0_STATUS_REG # disable all interrupts - MTC0_SR_IE_HAZARD - MTC0 zero, COP_0_CAUSE_REG # Clear soft interrupts - MTC0_HAZARD - - /* - * Initialize stack and call machine startup. - */ - LA sp, start - FRAMESZ(CF_SZ) - jal mips_init # mips_init(argc, argv, envp) - PTR_S zero, CF_RA_OFFS(sp) # Zero out old ra for debugger - - move sp, v0 # switch to new stack - jal main # main(regs) - move a0, zero - PANIC("Startup failed!") - .end locore_start - -#if defined(MULTIPROCESSOR) -LEAF(hw_cpu_spinup_trampoline, 0) - MFC0 v0, COP_0_STATUS_REG - LI v1, ~SR_INT_ENAB - and v0, v1 - ori v0, SR_KX | SR_UX - MTC0 v0, COP_0_STATUS_REG # disable all interrupts - MTC0 zero, COP_0_CAUSE_REG # Clear soft interrupts - jal hw_cpu_hatch - NOP -END(hw_cpu_spinup_trampoline) - -#if defined(TGT_OCTANE) - -LEAF(hw_getcurcpu, 0) - GET_CPU_INFO(v0, v1) - j ra - NOP -END(hw_getcurcpu) - -/* - * There does not seem to be any fast way to store the curcpu pointer on - * Octane. We used to abuse the LLAddr register, but this is a 32-bit register, - * not suitable for allocation over 2GB physical. - * Instead, we will use an unused field of the MPCONF structure. - */ -LEAF(hw_setcurcpu, 0) - HW_GET_CPU_PRID(v0, v1) # get physical processor ID - LOAD_XKPHYS(v1, CCA_COHERENT_EXCLWRITE) - PTR_SLL v0, MPCONF_SHIFT - PTR_ADD v0, MPCONF_BASE - or v1, v0 - j ra - PTR_S a0, (MPCONF_LEN - REGSZ)(v1) -END(hw_setcurcpu) - -#elif defined(TGT_ORIGIN) - -LEAF(hw_getcurcpu, 0) - GET_CPU_INFO(v0, v1) - j ra - NOP -END(hw_getcurcpu) - -LEAF(hw_setcurcpu, 0) - DMTC0 a0, COP_0_ERROR_PC - j ra - NOP -END(hw_setcurcpu) - -LEAF(ip27_cpu_spinup_trampoline, 0) - MFC0 v0, COP_0_STATUS_REG - LI v1, ~SR_INT_ENAB - and v0, v1 - MTC0 v0, COP_0_STATUS_REG # Disable all interrupts. - MTC0 zero, COP_0_CAUSE_REG # Clear soft interrupts. - - /* Wait the turn of this CPU. */ - LA v1, ip27_spinup_turn -1: ll v0, 0(v1) - bne v0, a0, 1b - not v0, zero - sc v0, 0(v1) - beqz v0, 1b - nop - - LA v0, ip27_spinup_a0 - ld a0, 0(v0) - LA v0, ip27_spinup_sp - ld sp, 0(v0) - jal hw_cpu_hatch - nop - PANIC("secondary CPU start failed") -END(ip27_cpu_spinup_trampoline) - -#endif /* TGT_ORIGIN */ - -#endif /* MULTIPROCESSOR */ diff --git a/sys/arch/sgi/sgi/locore0.S b/sys/arch/sgi/sgi/locore0.S deleted file mode 100644 index af2af43deb3..00000000000 --- a/sys/arch/sgi/sgi/locore0.S +++ /dev/null @@ -1,54 +0,0 @@ -/* $OpenBSD: locore0.S,v 1.1 2017/06/08 11:47:25 visa Exp $ */ - -/* - * Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#include <machine/param.h> -#include <machine/asm.h> - -#include "assym.h" - - .set mips3 - .set noreorder # Noreorder is default style! - - .globl kernel_text - .globl start - .ent start, 0 -kernel_text = start -start: - /* - * On at least the O2, when netbooting the bsd.rd kernel, the - * kernel image gets loaded in CKSEG1, which causes the kernel - * text to be uncached. Just to be on the safe side, jump to - * our intended execution address. - */ - LA v0, 1f - jr v0 - NOP -1: - j locore_start - NOP - .end start diff --git a/sys/arch/sgi/sgi/machdep.c b/sys/arch/sgi/sgi/machdep.c deleted file mode 100644 index ca0d9d759d2..00000000000 --- a/sys/arch/sgi/sgi/machdep.c +++ /dev/null @@ -1,1018 +0,0 @@ -/* $OpenBSD: machdep.c,v 1.164 2020/08/26 03:29:06 visa Exp $ */ - -/* - * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/proc.h> -#include <sys/buf.h> -#include <sys/reboot.h> -#include <sys/conf.h> -#include <sys/msgbuf.h> -#include <sys/user.h> -#include <sys/exec.h> -#include <sys/sysctl.h> -#include <sys/mount.h> -#include <sys/syscallargs.h> -#include <sys/exec_elf.h> -#ifdef SYSVSHM -#include <sys/shm.h> -#endif -#ifdef SYSVSEM -#include <sys/sem.h> -#endif - -#include <net/if.h> - -#include <uvm/uvm_extern.h> - -#include <machine/db_machdep.h> -#include <ddb/db_interface.h> - -#include <mips64/cache.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/frame.h> -#include <machine/autoconf.h> -#include <machine/memconf.h> -#include <machine/regnum.h> -#ifdef TGT_ORIGIN -#include <machine/mnode.h> -#endif -#if defined(TGT_INDY) || defined(TGT_INDIGO2) -CACHE_PROTOS(ip22) -#endif -#ifdef TGT_INDIGO2 -CACHE_PROTOS(tcc) -#endif - -#include <dev/cons.h> - -#include <mips64/arcbios.h> -#include <mips64/archtype.h> -#include <machine/bus.h> - -extern char kernel_text[]; -extern bus_addr_t comconsaddr; - -/* The following is used externally (sysctl_hw) */ -char machine[] = MACHINE; /* Machine "architecture" */ -char cpu_model[30]; - -/* will be updated in ipXX_machdep.c whenever necessary */ -struct uvm_constraint_range dma_constraint = { 0x0, (paddr_t)-1 }; -struct uvm_constraint_range *uvm_md_constraints[] = { - &dma_constraint, - NULL -}; - -vm_map_t exec_map; -vm_map_t phys_map; - -/* - * safepri is a safe priority for sleep to set for a spin-wait - * during autoconfiguration or after a panic. - */ -int safepri = 0; - -caddr_t msgbufbase; - -int physmem; /* Max supported memory, changes to actual. */ -int rsvdmem; /* Reserved memory not usable. */ -int ncpu = 1; /* At least one CPU in the system. */ -struct user *proc0paddr; -int console_ok; /* Set when console initialized. */ -int16_t masternasid; - -int32_t *environment; -struct sys_rec sys_config; -struct cpu_hwinfo bootcpu_hwinfo; - -/* Pointers to the start and end of the symbol table. */ -caddr_t ssym; -caddr_t esym; -caddr_t ekern; - -struct phys_mem_desc mem_layout[MAXMEMSEGS]; - -caddr_t mips_init(int, void *, caddr_t); -void dumpsys(void); -void dumpconf(void); - -static void dobootopts(int, void *); - -int is_memory_range(paddr_t, psize_t, psize_t); - -void (*md_halt)(int) = arcbios_halt; - -int sgi_cpuspeed(int *); - -/* - * Do all the stuff that locore normally does before calling main(). - * Reset mapping and set up mapping to hardware and init "wired" reg. - */ - -caddr_t -mips_init(int argc, void *argv, caddr_t boot_esym) -{ - char *cp; - int i, guessed; - u_int cpufamily; - struct cpu_info *ci; - extern char start[], edata[], end[]; -#ifndef CPU_R8000 - extern char cache_err[], exception[], e_exception[]; - vaddr_t xtlb_handler; -#endif - -#ifdef MULTIPROCESSOR - /* - * Set curcpu address on primary processor. - */ - setcurcpu(&cpu_info_primary); -#endif - - ci = curcpu(); - - /* - * Make sure we can access the extended address space. - * Note that r10k and later do not allow XUSEG accesses - * from kernel mode unless SR_UX is set. - */ - setsr(getsr() | SR_KX | SR_UX); - - /* - * Clear the compiled BSS segment in OpenBSD code. - */ - bzero(edata, end - edata); - - /* - * Reserve space for the symbol table, if it exists. - */ - ssym = (char *)*(u_int64_t *)end; - - /* Attempt to locate ELF header and symbol table after kernel. */ - if (end[0] == ELFMAG0 && end[1] == ELFMAG1 && - end[2] == ELFMAG2 && end[3] == ELFMAG3 ) { - - /* ELF header exists directly after kernel. */ - ssym = end; - esym = boot_esym; - ekern = esym; - - } else if (((long)ssym - (long)end) >= 0 && - ((long)ssym - (long)end) <= 0x1000 && - ssym[0] == ELFMAG0 && ssym[1] == ELFMAG1 && - ssym[2] == ELFMAG2 && ssym[3] == ELFMAG3 ) { - - /* Pointers exist directly after kernel. */ - esym = (char *)*((u_int64_t *)end + 1); - ekern = esym; - - } else { - - /* Pointers aren't setup either... */ - ssym = NULL; - esym = NULL; - ekern = end; - } - - /* - * Initialize the system type and set up memory layout. - * Note that some systems have a more complex memory setup. - */ - bios_ident(); - - /* - * Read and store ARCBios variables for future reference. - */ - cp = Bios_GetEnvironmentVariable("ConsoleOut"); - if (cp != NULL && *cp != '\0') - strlcpy(bios_console, cp, sizeof(bios_console)); - cp = Bios_GetEnvironmentVariable("gfx"); - if (cp != NULL && *cp != '\0') - strlcpy(bios_graphics, cp, sizeof(bios_graphics)); - cp = Bios_GetEnvironmentVariable("keybd"); - if (cp != NULL && *cp != '\0') - strlcpy(bios_keyboard, cp, sizeof(bios_keyboard)); - /* the following variables may not exist on all systems */ - cp = Bios_GetEnvironmentVariable("eaddr"); - if (cp != NULL && strlen(cp) > 0) - strlcpy(bios_enaddr, cp, sizeof bios_enaddr); - bios_consrate = bios_getenvint("dbaud"); - if (bios_consrate < 50 || bios_consrate > 115200) - bios_consrate = 9600; /* sane default */ - cp = Bios_GetEnvironmentVariable("OSLoadOptions"); - if (cp != NULL && strlen(cp) > 0) - strlcpy(osloadoptions, cp, sizeof osloadoptions); - - /* - * Determine system type and set up configuration record data. - */ - hw_vendor = "SGI"; - switch (sys_config.system_type) { -#ifdef TGT_INDIGO - case SGI_IP20: - bios_printf("Found SGI-IP20, setting up.\n"); - /* IP22 is intentional, we use the same kernel */ - strlcpy(cpu_model, "IP22", sizeof(cpu_model)); - ip22_setup(); - break; -#endif -#if defined(TGT_INDY) || defined(TGT_INDIGO2) - case SGI_IP22: - bios_printf("Found SGI-IP22, setting up.\n"); - strlcpy(cpu_model, "IP22", sizeof(cpu_model)); - ip22_setup(); - break; -#endif -#ifdef TGT_INDIGO2 - case SGI_IP26: - bios_printf("Found SGI-IP26, setting up.\n"); - strlcpy(cpu_model, "IP26", sizeof(cpu_model)); - ip22_setup(); - break; - case SGI_IP28: - bios_printf("Found SGI-IP28, setting up.\n"); - strlcpy(cpu_model, "IP28", sizeof(cpu_model)); - ip22_setup(); - break; -#endif -#ifdef TGT_O2 - case SGI_O2: - bios_printf("Found SGI-IP32, setting up.\n"); - strlcpy(cpu_model, "IP32", sizeof(cpu_model)); - ip32_setup(); - break; -#endif -#ifdef TGT_ORIGIN - case SGI_IP27: - bios_printf("Found SGI-IP27, setting up.\n"); - strlcpy(cpu_model, "IP27", sizeof(cpu_model)); - ip27_setup(); - - break; - - case SGI_IP35: - bios_printf("Found SGI-IP35, setting up.\n"); - /* IP27 is intentional, we use the same kernel */ - strlcpy(cpu_model, "IP27", sizeof(cpu_model)); - ip27_setup(); - - break; -#endif -#ifdef TGT_OCTANE - case SGI_OCTANE: - bios_printf("Found SGI-IP30, setting up.\n"); - strlcpy(cpu_model, "IP30", sizeof(cpu_model)); - ip30_setup(); - break; -#endif - default: - bios_printf("There is no support for this system type " - "(%02x) in this kernel.\n" - "Are you sure you have booted the right kernel " - "for this machine?\n", - sys_config.system_type); - bios_printf("Halting system.\n"); - Bios_Halt(); - for (;;) - continue; - /* NOTREACHED */ - } - - /* - * Look at arguments passed to us and compute boothowto. - */ - boothowto = RB_AUTOBOOT; - dobootopts(argc, argv); - - /* - * Figure out where we supposedly booted from. - */ - cp = Bios_GetEnvironmentVariable("OSLoadPartition"); - if (cp == NULL) - cp = "unknown"; - if (strlcpy(osloadpartition, cp, sizeof osloadpartition) >= - sizeof osloadpartition) - bios_printf("Value of `OSLoadPartition' is too large.\n" - "The kernel might not be able to find out its root device.\n"); - - /* - * Set pagesize to enable use of page macros and functions. - * Commit available memory to UVM system. - */ - uvmexp.pagesize = PAGE_SIZE; - uvm_setpagesize(); - - for (i = 0; i < MAXMEMSEGS && mem_layout[i].mem_last_page != 0; i++) { - uint64_t fp, lp; - uint64_t firstkernpage, lastkernpage; - paddr_t firstkernpa, lastkernpa; - - if (IS_XKPHYS((vaddr_t)start)) - firstkernpa = XKPHYS_TO_PHYS((vaddr_t)start); - else - firstkernpa = CKSEG0_TO_PHYS((vaddr_t)start); - if (IS_XKPHYS((vaddr_t)ekern)) - lastkernpa = XKPHYS_TO_PHYS((vaddr_t)ekern); - else - lastkernpa = CKSEG0_TO_PHYS((vaddr_t)ekern); - - firstkernpage = atop(trunc_page(firstkernpa)); - lastkernpage = atop(round_page(lastkernpa)); - - fp = mem_layout[i].mem_first_page; - lp = mem_layout[i].mem_last_page; - - /* Account for kernel and kernel symbol table. */ - if (fp >= firstkernpage && lp < lastkernpage) - continue; /* In kernel. */ - - if (lp < firstkernpage || fp > lastkernpage) { - uvm_page_physload(fp, lp, fp, lp, 0); - continue; /* Outside kernel. */ - } - - if (fp >= firstkernpage) - fp = lastkernpage; - else if (lp < lastkernpage) - lp = firstkernpage; - else { /* Need to split! */ - uint64_t xp = firstkernpage; - uvm_page_physload(fp, xp, fp, xp, 0); - fp = lastkernpage; - } - if (lp > fp) { - uvm_page_physload(fp, lp, fp, lp, 0); - } - } - - /* - * Configure cache. - */ - guessed = 0; - switch (bootcpu_hwinfo.type) { -#ifdef CPU_R4000 - case MIPS_R4000: - cpufamily = MIPS_R4000; - break; -#endif -#ifdef CPU_R4600 - case MIPS_R4600: - cpufamily = MIPS_R5000; - break; -#endif -#ifdef CPU_R5000 - case MIPS_R5000: - case MIPS_RM52X0: - cpufamily = MIPS_R5000; - break; -#endif -#ifdef CPU_RM7000 - case MIPS_RM7000: - case MIPS_RM9000: - cpufamily = MIPS_R5000; - break; -#endif -#ifdef CPU_R8000 - case MIPS_R8000: - cpufamily = MIPS_R8000; - break; -#endif -#ifdef CPU_R10000 - case MIPS_R10000: - case MIPS_R12000: - case MIPS_R14000: - cpufamily = MIPS_R10000; - break; -#endif - default: - /* - * If we can't identify the cpu type, it must be - * r10k-compatible on Octane and Origin families, and - * it is likely to be r5k-compatible on O2 and - * r4k-compatible on Ind{igo*,y}. - */ - guessed = 1; - switch (sys_config.system_type) { - case SGI_IP20: - case SGI_IP22: - bios_printf("Unrecognized processor type %02x, assuming" - " R4000 compatible\n", bootcpu_hwinfo.type); - cpufamily = MIPS_R4000; - break; - case SGI_O2: - bios_printf("Unrecognized processor type %02x, assuming" - " R5000 compatible\n", bootcpu_hwinfo.type); - cpufamily = MIPS_R5000; - break; - case SGI_IP26: - bios_printf("Unrecognized processor type %02x, assuming" - " R8000 compatible\n", bootcpu_hwinfo.type); - cpufamily = MIPS_R8000; - break; - default: - case SGI_IP27: - case SGI_IP28: - case SGI_OCTANE: - case SGI_IP35: - bios_printf("Unrecognized processor type %02x, assuming" - " R10000 compatible\n", bootcpu_hwinfo.type); - cpufamily = MIPS_R10000; - break; - } - break; - } - switch (cpufamily) { -#ifdef CPU_R4000 - case MIPS_R4000: - Mips4k_ConfigCache(ci); - break; -#endif -#if defined(CPU_R4600) || defined(CPU_R5000) || defined(CPU_RM7000) - case MIPS_R5000: -#if defined(TGT_INDY) || defined(TGT_INDIGO2) - if (sys_config.system_type == SGI_IP22) - ip22_ConfigCache(ci); - else -#endif - Mips5k_ConfigCache(ci); - break; -#endif -#ifdef CPU_R8000 - case MIPS_R8000: -#ifdef TGT_INDIGO2 - if (sys_config.system_type == SGI_IP26) - tcc_ConfigCache(ci); - else -#endif - tfp_ConfigCache(ci); - break; -#endif -#ifdef CPU_R10000 - case MIPS_R10000: - Mips10k_ConfigCache(ci); - break; -#endif - default: - if (guessed) { - bios_printf("There is no support for this processor " - "family in this kernel.\n" - "Are you sure you have booted the right kernel " - "for this machine?\n"); - } else { - bios_printf("There is no support for this processor " - "family (%02x) in this kernel.\n", - bootcpu_hwinfo.type); - } - bios_printf("Halting system.\n"); - Bios_Halt(); - for (;;) - continue; - /* NOTREACHED */ - break; - } - - /* - * Last chance to call the BIOS. Wiping the TLB means the BIOS' data - * areas are demapped on most systems. - */ - delay(20*1000); /* Let any UART FIFO drain... */ - - tlb_init(bootcpu_hwinfo.tlbsize); - -#ifdef CPU_R8000 /* { */ - /* - * Set up TrapBase to point to our own trap vector area. - */ - { - extern char tfp_trapbase[]; - cp0_set_trapbase((vaddr_t)tfp_trapbase); - } -#else /* } { */ - /* - * Copy down exception vector code. - */ - bcopy(exception, (char *)CACHE_ERR_EXC_VEC, e_exception - cache_err); - bcopy(exception, (char *)GEN_EXC_VEC, e_exception - exception); - - /* - * Build proper TLB refill handler trampolines. - */ - switch (cpufamily) { -#ifdef CPU_R4000 - case MIPS_R4000: - { - extern void xtlb_miss_err_r4k; - extern void xtlb_miss_err_r4000SC; - - if (ci->ci_l2.size == 0 || - ((cp0_get_prid() >> 4) & 0x0f) >= 4) /* R4400 */ - xtlb_handler = (vaddr_t)&xtlb_miss_err_r4k; - else { - xtlb_handler = (vaddr_t)&xtlb_miss_err_r4000SC; - xtlb_handler |= CKSEG1_BASE; - } - } - break; -#endif -#if defined(CPU_R5000) || defined(CPU_RM7000) - case MIPS_R5000: - { - /* - * R5000 processors need a specific chip bug workaround - * in their tlb handlers. Theoretically only revision 1 - * of the processor need it, but there is evidence - * later versions also need it. - * - * This is also necessary on RM52x0 and most RM7k/RM9k, - * and is a documented errata for these chips. - */ - extern void xtlb_miss_err_r5k; - xtlb_handler = (vaddr_t)&xtlb_miss_err_r5k; - } - break; -#endif - default: - { - extern void xtlb_miss; - xtlb_handler = (vaddr_t)&xtlb_miss; - } - break; - } - - build_trampoline(TLB_MISS_EXC_VEC, xtlb_handler); - build_trampoline(XTLB_MISS_EXC_VEC, xtlb_handler); -#endif /* } */ - -#ifdef CPU_R4000 - /* - * Enable R4000 EOP errata workaround code if necessary. - */ - if (cpufamily == MIPS_R4000 && ((cp0_get_prid() >> 4) & 0x0f) < 3) - r4000_errata = 1; -#endif - - /* - * Allocate U page(s) for proc[0], pm_tlbpid 1. - */ - ci->ci_curproc = &proc0; - proc0.p_cpu = ci; - proc0.p_addr = proc0paddr = ci->ci_curprocpaddr = - (struct user *)pmap_steal_memory(USPACE, NULL, NULL); - proc0.p_md.md_regs = (struct trapframe *)&proc0paddr->u_pcb.pcb_regs; - tlb_set_pid(MIN_USER_ASID); - - /* - * Get a console, very early but after initial mapping setup - * and exception handler setup - console probe code might need - * to invoke guarded_read(), and this needs our handlers to be - * available. - */ - consinit(); - printf("Initial setup done, switching console.\n"); - -#ifdef DDB - { - /* - * Early initialize cpu0 so that commands such as `mach tlb' - * can work from ddb if ddb is entered before cpu0 attaches. - */ - extern struct cpu_info cpu_info_primary; - bcopy(&bootcpu_hwinfo, &cpu_info_primary.ci_hw, - sizeof(struct cpu_hwinfo)); - } -#endif - - /* - * Init message buffer. - */ - msgbufbase = (caddr_t)pmap_steal_memory(MSGBUFSIZE, NULL, NULL); - initmsgbuf(msgbufbase, MSGBUFSIZE); - - /* - * Bootstrap VM system. - */ - pmap_bootstrap(); - -#ifdef CPU_R8000 - /* - * Turn on precise FPU exceptions. This also causes the FS bit in - * the FPU status register to be honoured, instead of being forced - * to one. - */ - setsr(getsr() | SR_SERIALIZE_FPU); - - /* - * Turn on sequential memory model. This makes sure that there are - * no risks of hitting virtual coherency exceptions, which are not - * recoverable on R8000. - */ - cp0_set_config((cp0_get_config() & ~CFGR_ICE) | CFGR_SMM); -#else - /* - * Turn off bootstrap exception vectors. - */ - setsr(getsr() & ~SR_BOOT_EXC_VEC); -#endif - - proc0.p_md.md_regs->sr = getsr(); - - /* - * Clear out the I and D caches. - */ - Mips_SyncCache(ci); - -#ifdef DDB - db_machine_init(); - if (boothowto & RB_KDB) - db_enter(); -#endif - - /* - * Return new stack pointer. - */ - return ((caddr_t)proc0paddr + USPACE - 64); -} - -/* - * Decode boot options. - */ -static void -dobootopts(int argc, void *argv) -{ - char *cp; - int i; - - /* XXX Should this be done differently, eg env vs. args? */ - for (i = 1; i < argc; i++) { - if (bios_is_32bit) - cp = (char *)(long)((int32_t *)argv)[i]; - else - cp = ((char **)argv)[i]; - if (cp == NULL) - continue; - - /* - * Parse PROM options. - */ - if (strncmp(cp, "OSLoadOptions=", 14) == 0) { - if (strcmp(&cp[14], "auto") == 0) - boothowto &= ~(RB_SINGLE|RB_ASKNAME); - else if (strcmp(&cp[14], "single") == 0) - boothowto |= RB_SINGLE; - else if (strcmp(&cp[14], "debug") == 0) - boothowto |= RB_KDB; - continue; - } - - /* - * Parse kernel options. - */ - if (*cp == '-') { - while (*++cp != '\0') - switch (*cp) { - case 'a': - boothowto |= RB_ASKNAME; - break; - case 'c': - boothowto |= RB_CONFIG; - break; - case 'd': - boothowto |= RB_KDB; - break; - case 's': - boothowto |= RB_SINGLE; - break; - } - } - } -} - - -/* - * Console initialization: called early on from mips_init(), before vm init - * is completed. - * Do enough configuration to choose and initialize a console. - */ -void -consinit() -{ - if (console_ok) - return; - cninit(); - console_ok = 1; -} - -/* - * cpu_startup: allocate memory for variable-sized tables, initialize CPU, and - * do auto-configuration. - */ -void -cpu_startup() -{ - vaddr_t minaddr, maxaddr; -#ifdef PMAPDEBUG - extern int pmapdebug; - int opmapdebug = pmapdebug; - - pmapdebug = 0; /* Shut up pmap debug during bootstrap. */ -#endif - - /* - * Good {morning,afternoon,evening,night}. - */ - printf("%s", version); - printf("real mem = %lu (%luMB)\n", ptoa((psize_t)physmem), - ptoa((psize_t)physmem)/1024/1024); - printf("rsvd mem = %lu (%luMB)\n", ptoa((psize_t)rsvdmem), - (ptoa((psize_t)rsvdmem) + 1023 * 1024)/1024/1024); - - /* - * Allocate a submap for exec arguments. This map effectively - * limits the number of processes exec'ing at any time. - */ - minaddr = vm_map_min(kernel_map); - exec_map = uvm_km_suballoc(kernel_map, &minaddr, &maxaddr, - 16 * NCARGS, VM_MAP_PAGEABLE, FALSE, NULL); - /* Allocate a submap for physio. */ - phys_map = uvm_km_suballoc(kernel_map, &minaddr, &maxaddr, - VM_PHYS_SIZE, 0, FALSE, NULL); - -#ifdef PMAPDEBUG - pmapdebug = opmapdebug; -#endif - printf("avail mem = %lu (%luMB)\n", ptoa((psize_t)uvmexp.free), - ptoa((psize_t)uvmexp.free)/1024/1024); - - cpu_cpuspeed = sgi_cpuspeed; - - /* - * Set up buffers, so they can be used to read disk labels. - */ - bufinit(); - - /* - * Configure the system. - */ - if (boothowto & RB_CONFIG) { -#ifdef BOOT_CONFIG - user_config(); -#else - printf("kernel does not support -c; continuing..\n"); -#endif - } -} - -/* - * Machine dependent system variables. - */ -int -cpu_sysctl(int *name, u_int namelen, void *oldp, size_t *oldlenp, void *newp, - size_t newlen, struct proc *p) -{ - /* All sysctl names at this level are terminal. */ - if (namelen != 1) - return ENOTDIR; /* Overloaded */ - - switch (name[0]) { - default: - return EOPNOTSUPP; - } -} - -int -sgi_cpuspeed(int *freq) -{ - /* - * XXX assumes all CPU have the same frequency - */ - *freq = curcpu()->ci_hw.clock / 1000000; - return (0); -} - -int waittime = -1; - -__dead void -boot(int howto) -{ - if ((howto & RB_RESET) != 0) - goto doreset; - - if (curproc) - savectx(curproc->p_addr, 0); - - if (cold) { - if ((howto & RB_USERREQ) == 0) - howto |= RB_HALT; - goto haltsys; - } - - boothowto = howto; - if ((howto & RB_NOSYNC) == 0 && waittime < 0) { - waittime = 0; - vfs_shutdown(curproc); - - if ((howto & RB_TIMEBAD) == 0) { - resettodr(); - } else { - printf("WARNING: not updating battery clock\n"); - } - } - if_downall(); - - uvm_shutdown(); - splhigh(); - cold = 1; - - if ((howto & RB_DUMP) != 0) - dumpsys(); - -haltsys: - config_suspend_all(DVACT_POWERDOWN); - - if ((howto & RB_HALT) != 0) { - if ((howto & RB_POWERDOWN) != 0) - printf("System Power Down.\n"); - else - printf("System Halt.\n"); - } else { -doreset: - printf("System restart.\n"); - } - - delay(1000000); - md_halt(howto); - - printf("Failed!!! Please reset manually.\n"); - for (;;) - continue; - /* NOTREACHED */ -} - -void -arcbios_halt(int howto) -{ - register_t sr; - - sr = disableintr(); - -#if 0 - /* restore ARCBios page size... */ - tlb_set_page_mask(PG_SIZE_4K); -#endif - - if (howto & RB_HALT) { -#ifdef TGT_INDIGO - /* Indigo does not support powerdown */ - if (sys_config.system_type == SGI_IP20) - howto &= ~RB_POWERDOWN; -#endif - if (howto & RB_POWERDOWN) { -#ifdef TGT_INDY - /* - * ARCBios needs to use the FPU on Indy during - * shutdown. - */ - if (sys_config.system_type == SGI_IP22) - setsr(getsr() | SR_COP_1_BIT); -#endif - Bios_PowerDown(); - } else - Bios_EnterInteractiveMode(); - } else - Bios_Reboot(); - - setsr(sr); -} - -u_long dumpmag = 0x8fca0101; /* Magic number for savecore. */ -int dumpsize = 0; /* Also for savecore. */ -long dumplo = 0; - -void -dumpconf(void) -{ - int nblks; - - if (dumpdev == NODEV || - (nblks = (bdevsw[major(dumpdev)].d_psize)(dumpdev)) == 0) - return; - if (nblks <= ctod(1)) - return; - - dumpsize = ptoa(physmem); - if (dumpsize > atop(round_page(dbtob(nblks - dumplo)))) - dumpsize = atop(round_page(dbtob(nblks - dumplo))); - else if (dumplo == 0) - dumplo = nblks - btodb(ptoa(physmem)); - - /* - * Don't dump on the first page in case the dump device includes a - * disk label. - */ - if (dumplo < btodb(PAGE_SIZE)) - dumplo = btodb(PAGE_SIZE); -} - -/* - * Doadump comes here after turning off memory management and getting on the - * dump stack, either when called above, or by the auto-restart code. - */ -void -dumpsys() -{ - extern int msgbufmapped; - - msgbufmapped = 0; - if (dumpdev == NODEV) - return; - /* - * For dumps during auto-configuration, if dump device has already - * configured... - */ - if (dumpsize == 0) - dumpconf(); - if (dumplo < 0) - return; - printf("\ndumping to dev %x, offset %ld\n", dumpdev, dumplo); - printf("dump not yet implemented\n"); -#if 0 /* XXX HAVE TO FIX XXX */ - switch (error = (*bdevsw[major(dumpdev)].d_dump)(dumpdev, dumplo,)) { - - case ENXIO: - printf("device bad\n"); - break; - - case EFAULT: - printf("device not ready\n"); - break; - - case EINVAL: - printf("area improper\n"); - break; - - case EIO: - printf("i/o error\n"); - break; - - default: - printf("error %d\n", error); - break; - - case 0: - printf("succeeded\n"); - } -#endif -} - -int -is_memory_range(paddr_t pa, psize_t len, psize_t limit) -{ - struct phys_mem_desc *seg; - uint64_t fp, lp; - int i; - - fp = atop(pa); - lp = atop(round_page(pa + len)); - - if (limit != 0 && lp > atop(limit)) - return 0; - - for (i = 0, seg = mem_layout; i < MAXMEMSEGS; i++, seg++) - if (fp >= seg->mem_first_page && lp <= seg->mem_last_page) - return 1; - - return 0; -} - -void -intr_barrier(void *cookie) -{ - sched_barrier(NULL); -} diff --git a/sys/arch/sgi/sgi/mainbus.c b/sys/arch/sgi/sgi/mainbus.c deleted file mode 100644 index a066a2b8ae5..00000000000 --- a/sys/arch/sgi/sgi/mainbus.c +++ /dev/null @@ -1,151 +0,0 @@ -/* $OpenBSD: mainbus.c,v 1.14 2020/08/26 03:29:06 visa Exp $ */ - -/* - * Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) - * - * 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 ``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 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. - * - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/device.h> -#include <sys/reboot.h> - -#include <mips64/archtype.h> -#include <machine/autoconf.h> - -/* Definition of the mainbus driver. */ -int mbmatch(struct device *, void *, void *); -void mbattach(struct device *, struct device *, void *); -int mbprint(void *, const char *); - -const struct cfattach mainbus_ca = { - sizeof(struct device), mbmatch, mbattach -}; - -struct cfdriver mainbus_cd = { - NULL, "mainbus", DV_DULL -}; - -int -mbmatch(struct device *parent, void *cfdata, void *aux) -{ - static int mbattached = 0; - - if (mbattached != 0) - return 0; - - return mbattached = 1; -} - -void -mbattach(struct device *parent, struct device *self, void *aux) -{ - struct cpu_attach_args caa; - - if (hw_prod != NULL) - printf(": %s", hw_prod); - printf("\n"); - - /* - * On multiprocessor capable systems, delegate everything to the - * IP-specific code. - */ - switch (sys_config.system_type) { -#ifdef TGT_ORIGIN - case SGI_IP27: - case SGI_IP35: - ip27_autoconf(self); - return; -#endif -#ifdef TGT_OCTANE - case SGI_OCTANE: - ip30_autoconf(self); - return; -#endif - default: - break; - } - - /* - * On other systems, attach the CPU, its clock, and the - * mainbus here. - * XXX Would be worth doing as ipXX_autoconf() too. - */ - - bzero(&caa, sizeof caa); - caa.caa_maa.maa_name = "cpu"; - caa.caa_hw = &bootcpu_hwinfo; - config_found(self, &caa, mbprint); - - switch (sys_config.system_type) { -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) - case SGI_IP20: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: - /* Interrupt Controller */ - caa.caa_maa.maa_name = "int"; - config_found(self, &caa.caa_maa, mbprint); -#ifdef TGT_INDIGO2 - if (sys_config.system_type == SGI_IP26) { - /* Streaming Cache Controller */ - caa.caa_maa.maa_name = "tcc"; - config_found(self, &caa.caa_maa, mbprint); - } -#endif - /* Memory Controller */ - caa.caa_maa.maa_name = "imc"; - config_found(self, &caa.caa_maa, mbprint); - - if (md_startclock == NULL) { - caa.caa_maa.maa_name = "clock"; - config_found(self, &caa.caa_maa, mbprint); - } - - ip22_post_autoconf(); - - break; -#endif -#ifdef TGT_O2 - case SGI_O2: - caa.caa_maa.maa_name = "clock"; - config_found(self, &caa.caa_maa, mbprint); - caa.caa_maa.maa_name = "macebus"; - config_found(self, &caa.caa_maa, mbprint); - caa.caa_maa.maa_name = "gbe"; - config_found(self, &caa.caa_maa, mbprint); - break; -#endif - default: - break; - } -} - -int -mbprint(void *aux, const char *pnp) -{ - if (pnp) - return (QUIET); - return (UNCONF); -} diff --git a/sys/arch/sgi/sgi/sginode.c b/sys/arch/sgi/sgi/sginode.c deleted file mode 100644 index dfdffeb46c5..00000000000 --- a/sys/arch/sgi/sgi/sginode.c +++ /dev/null @@ -1,681 +0,0 @@ -/* $OpenBSD: sginode.c,v 1.32 2015/12/03 15:38:06 visa Exp $ */ -/* - * Copyright (c) 2008, 2009, 2011 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2004 Opsycon AB. 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 REGENTS 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 REGENTS 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/proc.h> - -#include <uvm/uvm_extern.h> - -#include <machine/cpu.h> -#include <machine/memconf.h> -#include <machine/param.h> -#include <machine/autoconf.h> -#include <mips64/arcbios.h> -#include <mips64/archtype.h> - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcidevs.h> - -#include <machine/mnode.h> -#include <sgi/xbow/hub.h> -#include <sgi/xbow/widget.h> -#include <sgi/xbow/xbow.h> -#include <sgi/xbow/xbowdevs.h> - -void kl_add_memory_ip27(int16_t, int16_t *, unsigned int); -void kl_add_memory_ip35(int16_t, int16_t *, unsigned int); - -int kl_first_pass_board(lboard_t *, void *); -int kl_first_pass_comp(klinfo_t *, void *); - -#ifdef DEBUG -#define DB_PRF(x) bios_printf x -#else -#define DB_PRF(x) -#endif - -/* widget number of the XBow `hub', for each node */ -int kl_hub_widget[GDA_MAXNODES]; - -int kl_n_mode = 0; -u_int kl_n_shift = 32; -klinfo_t *kl_glass_console = NULL; - -void -kl_init(int ip35) -{ - kl_config_hdr_t *cfghdr; - uint64_t val; - uint64_t nibase = ip35 ? HUBNIBASE_IP35 : HUBNIBASE_IP27; - size_t gsz; - - /* will be recomputed when processing memory information */ - physmem = 0; - - cfghdr = IP27_KLCONFIG_HDR(0); - DB_PRF(("config @%p\n", cfghdr)); - DB_PRF(("magic %#llx version %x\n", cfghdr->magic, cfghdr->version)); - DB_PRF(("console %#lx baud %d\n", cfghdr->cons_info.uart_base, - cfghdr->cons_info.baud)); - - val = IP27_LHUB_L(nibase | HUBNI_STATUS); - kl_n_mode = (val & NI_MORENODES) != 0; - kl_n_shift = (ip35 ? 33 : 32) - kl_n_mode; - bios_printf("Machine is in %c mode.\n", kl_n_mode + 'M'); - - val = IP27_LHUB_L(HUBPI_REGION_PRESENT); - DB_PRF(("Region present %#llx.\n", val)); - val = IP27_LHUB_L(HUBPI_CALIAS_SIZE); - DB_PRF(("Calias size %#llx.\n", val)); - - /* - * Get a grip on the global data area, and figure out how many - * theoretical nodes are available. - */ - - gda = IP27_GDA(0); - gsz = IP27_GDA_SIZE(0); - if (gda->magic != GDA_MAGIC || gda->ver < 2) { - masternasid = 0; - maxnodes = 0; - } else { - masternasid = gda->masternasid; - maxnodes = (gsz - offsetof(gda_t, nasid)) / sizeof(int16_t); - if (maxnodes > GDA_MAXNODES) - maxnodes = GDA_MAXNODES; - /* in M mode, there can't be more than 64 nodes anyway */ - if (kl_n_mode == 0 && maxnodes > 64) - maxnodes = 64; - } - - /* - * Scan all nodes configurations to find out CPU and memory - * information, starting with the master node. - */ - - kl_scan_all_nodes(KLBRD_ANY, kl_first_pass_board, &ip35); -} - -/* - * Callback routine for the initial enumeration (boards). - */ -int -kl_first_pass_board(lboard_t *boardinfo, void *arg) -{ - DB_PRF(("%cboard type %x slot %x nasid %x nic %#llx ncomp %d\n", - boardinfo->struct_type & LBOARD ? 'l' : 'r', - boardinfo->brd_type, boardinfo->brd_slot, - boardinfo->brd_nasid, boardinfo->brd_nic, - boardinfo->brd_numcompts)); - - /* - * Assume the worst case of a restricted XBow, as found on - * Origin 200 systems. This value will be overridden should a - * full-blown XBow be found during component enumeration. - * - * On Origin 200, widget 0 reports itself as a Bridge, and - * interrupt widget is hardwired to #a (which is another facet - * of the bridge). - */ - if (kl_hub_widget[boardinfo->brd_nasid] == 0) - kl_hub_widget[boardinfo->brd_nasid] = 0x0a; - - kl_scan_board(boardinfo, KLSTRUCT_ANY, kl_first_pass_comp, arg); - - return 0; -} - -#ifdef DEBUG -static const char *klstruct_names[] = { - "unknown component", - "cpu", - "hub", - "memory", - "xbow", - "bridge", - "ioc3", - "pci", - "vme", - "router", - "graphics", - "scsi", - "fddi", - "mio", - "disk", - "tape", - "cdrom", - "hub uart", - "ioc3 Ethernet", - "ioc3 uart", - "component type 20", - "ioc3 keyboard", - "rad", - "hub tty", - "ioc3 tty", - "fc", - "module serialnumber", - "ioc3 mouse", - "tpu", - "gsn main board", - "gsn aux board", - "xthd", - "QLogic fc", - "firewire", - "usb", - "usb keyboard", - "usb mouse", - "dual scsi", - "PE brick", - "gigabit Ethernet", - "ide", - "ioc4", - "ioc4 uart", - "ioc4 tty", - "ioc4 keyboard", - "ioc4 mouse", - "ioc4 ATA", - "pci graphics" -}; -#endif - -/* - * Callback routine for the initial enumeration (components). - * We are interested in cpu and memory information only, but display a few - * other things if option DEBUG. - */ -int -kl_first_pass_comp(klinfo_t *comp, void *arg) -{ - int ip35 = *(int *)arg; - klcpu_t *cpucomp; - klmembnk_m_t *memcomp_m; - klxbow_t *xbowcomp; - arc_config64_t *arc; -#ifdef DEBUG - klmembnk_n_t *memcomp_n; - klhub_t *hubcomp; - klscsi_t *scsicomp; - klscctl_t *scsi2comp; - int i; -#endif - - arc = (arc_config64_t *)comp->arcs_compt; - -#ifdef DEBUG - if (comp->struct_type < nitems(klstruct_names)) - DB_PRF(("\t%s", klstruct_names[comp->struct_type])); - else - DB_PRF(("\tcomponent type %d", comp->struct_type)); - DB_PRF((", widget %x physid 0x%02x virtid %d", - comp->widid, comp->physid, comp->virtid)); - if (ip35) { - DB_PRF((" prt %d bus %d", comp->port, comp->pci_bus_num)); - if (comp->pci_multifunc) - DB_PRF((" pcifn %d", comp->pci_func_num)); - } - DB_PRF(("\n")); -#endif - - switch (comp->struct_type) { - case KLSTRUCT_CPU: - cpucomp = (klcpu_t *)comp; - DB_PRF(("\t type %x/%x %dMHz cache %dMB speed %dMHz\n", - cpucomp->cpu_prid, cpucomp->cpu_fpirr, - cpucomp->cpu_speed, cpucomp->cpu_scachesz, - cpucomp->cpu_scachespeed)); - /* - * XXX this assumes the first cpu encountered is the boot - * XXX cpu. - */ - if (bootcpu_hwinfo.clock == 0) { - bootcpu_hwinfo.c0prid = cpucomp->cpu_prid; - bootcpu_hwinfo.c1prid = cpucomp->cpu_prid; /* XXX */ - bootcpu_hwinfo.clock = cpucomp->cpu_speed * 1000000; - bootcpu_hwinfo.tlbsize = 64; - bootcpu_hwinfo.type = (cpucomp->cpu_prid >> 8) & 0xff; - } else - ncpusfound++; - break; - - case KLSTRUCT_MEMBNK: - memcomp_m = (klmembnk_m_t *)comp; -#ifdef DEBUG - memcomp_n = (klmembnk_n_t *)comp; - DB_PRF(("\t %dMB, select %x flags %x\n", - memcomp_m->membnk_memsz, memcomp_m->membnk_dimm_select, - kl_n_mode ? - memcomp_n->membnk_attr : memcomp_m->membnk_attr)); - - if (kl_n_mode) { - for (i = 0; i < MD_MEM_BANKS_N; i++) { - if (memcomp_n->membnk_bnksz[i] == 0) - continue; - DB_PRF(("\t\tbank %d %dMB\n", - i + 1, memcomp_n->membnk_bnksz[i])); - } - } else { - for (i = 0; i < MD_MEM_BANKS_M; i++) { - if (memcomp_m->membnk_bnksz[i] == 0) - continue; - DB_PRF(("\t\tbank %d %dMB\n", - i + 1, memcomp_m->membnk_bnksz[i])); - } - } -#endif - if (ip35) - kl_add_memory_ip35(comp->nasid, - memcomp_m->membnk_bnksz, - kl_n_mode ? MD_MEM_BANKS_N : MD_MEM_BANKS_M); - else - kl_add_memory_ip27(comp->nasid, - memcomp_m->membnk_bnksz, - kl_n_mode ? MD_MEM_BANKS_N : MD_MEM_BANKS_M); - break; - - case KLSTRUCT_GFX: - /* - * We rely upon the PROM setting up a fake ARCBios component - * for the graphics console, if there is one. - * Of course, the ARCBios structure is only available as long - * as we do not tear down the PROM TLB, which is why we check - * for this as early as possible and remember the console - * component (KL struct are not short-lived). - */ - if (arc != NULL && - arc->class != 0 && arc->type == arc_DisplayController && - ISSET(arc->flags, ARCBIOS_DEVFLAGS_CONSOLE_OUTPUT)) { - DB_PRF(("\t (console device)\n")); - /* paranoia */ - if (comp->widid >= WIDGET_MIN && - comp->widid <= WIDGET_MAX) - kl_glass_console = comp; - } - break; - - case KLSTRUCT_XBOW: - xbowcomp = (klxbow_t *)comp; - DB_PRF(("\t hub master link %d\n", - xbowcomp->xbow_hub_master_link)); - kl_hub_widget[comp->nasid] = xbowcomp->xbow_hub_master_link; -#ifdef DEBUG - for (i = 0; i < MAX_XBOW_LINKS; i++) { - if (!ISSET(xbowcomp->xbow_port_info[i].port_flag, - XBOW_PORT_ENABLE)) - continue; - DB_PRF(("\t\twidget %d nasid %d flg %u\n", 8 + i, - xbowcomp->xbow_port_info[i].port_nasid, - xbowcomp->xbow_port_info[i].port_flag)); - } -#endif - break; - -#ifdef DEBUG - case KLSTRUCT_HUB: - hubcomp = (klhub_t *)comp; - DB_PRF(("\t port %d flag %d speed %lldMHz\n", - hubcomp->hub_port.port_nasid, hubcomp->hub_port.port_flag, - hubcomp->hub_speed / 1000000)); - break; - - case KLSTRUCT_SCSI2: - scsi2comp = (klscctl_t *)comp; - for (i = 0; i < scsi2comp->scsi_buscnt; i++) { - scsicomp = (klscsi_t *)scsi2comp->scsi_bus[i]; - if (scsicomp == NULL) - continue; - DB_PRF(("\t\tbus %d, physid 0x%02x virtid %d," - " specific %lld, numdevs %d\n", - i, scsicomp->scsi_info.physid, - scsicomp->scsi_info.virtid, - scsicomp->scsi_specific, - scsicomp->scsi_numdevs)); - } - break; -#endif - } - -#ifdef DEBUG - if (arc != NULL) { - DB_PRF(("\t[ARCBios component:" - " class %d type %d flags %02x key 0x%llx", - arc->class, arc->type, arc->flags, arc->key)); - if (arc->id_len != 0) - DB_PRF((" %.*s]\n", - (int)arc->id_len, (const char *)arc->id)); - else - DB_PRF((" (no name)]\n")); - } -#endif - - return 0; -} - -/* - * Enumerate the boards of all nodes, and invoke a callback for those - * matching the given class. - */ -int -kl_scan_all_nodes(uint cls, int (*cb)(lboard_t *, void *), void *cbarg) -{ - uint node; - - if (kl_scan_node(masternasid, cls, cb, cbarg) != 0) - return 1; - for (node = 0; node < maxnodes; node++) { - if (gda->nasid[node] < 0) - continue; - if (gda->nasid[node] == masternasid) - continue; - if (kl_scan_node(gda->nasid[node], cls, cb, cbarg) != 0) - return 1; - } - - return 0; -} - -/* - * Enumerate the boards of a node, and invoke a callback for those matching - * the given class. - */ -int -kl_scan_node(int nasid, uint clss, int (*cb)(lboard_t *, void *), void *cbarg) -{ - lboard_t *boardinfo; - - for (boardinfo = IP27_KLFIRST_BOARD(nasid); boardinfo != NULL; - boardinfo = IP27_KLNEXT_BOARD(nasid, boardinfo)) { - if (clss == KLBRD_ANY || - (boardinfo->brd_type & IP27_BC_MASK) == clss) { - if ((*cb)(boardinfo, cbarg) != 0) - return 1; - } - if (boardinfo->brd_next == 0) - break; - } - - return 0; -} - -/* - * Enumerate the components of a board, and invoke a callback for those - * matching the given type. - */ -int -kl_scan_board(lboard_t *boardinfo, uint type, int (*cb)(klinfo_t *, void *), - void *cbarg) -{ - klinfo_t *comp; - int i; - - if (!ISSET(boardinfo->struct_type, LBOARD)) - return 0; - - for (i = 0; i < boardinfo->brd_numcompts; i++) { - comp = IP27_UNCAC_ADDR(klinfo_t *, boardinfo->brd_nasid, - boardinfo->brd_compts[i]); - - if (!ISSET(comp->flags, KLINFO_ENABLED) || - ISSET(comp->flags, KLINFO_FAILED)) - continue; - - if (type != KLSTRUCT_ANY && comp->struct_type != type) - continue; - - if ((*cb)(comp, cbarg) != 0) - return 1; - } - - return 0; -} - -/* - * Return the console device information. - */ -console_t * -kl_get_console() -{ - kl_config_hdr_t *cfghdr = IP27_KLCONFIG_HDR(0); - - return &cfghdr->cons_info; -} - -/* - * Process memory bank information. - * There are two different routines, because IP27 and IP35 do not - * layout memory the same way. - */ - -/* - * On IP27, access to each DIMM is interleaved, which cause it to map to - * four banks on 128MB boundaries. - * DIMMs of 128MB or smaller map everything in the first bank, though -- - * interleaving would be horribly non-optimal. - */ -void -kl_add_memory_ip27(int16_t nasid, int16_t *sizes, unsigned int cnt) -{ - paddr_t basepa; - uint64_t fp, lp, np; - unsigned int seg, nmeg; - - basepa = (paddr_t)nasid << kl_n_shift; - while (cnt-- != 0) { - nmeg = *sizes++; - for (seg = 0; seg < 4; basepa += (1 << 27), seg++) { - if (nmeg <= 128) - np = seg == 0 ? nmeg : 0; - else - np = nmeg / 4; - if (np == 0) - continue; - - DB_PRF(("IP27 memory from %#lx to %#llx (%llu MB)\n", - basepa, basepa + (np << 20), np)); - - np = atop(np << 20); /* MB to pages */ - fp = atop(basepa); - lp = fp + np; - - /* - * We do not manage the first 32MB, so skip them here - * if necessary. - */ - if (fp < atop(32 << 20)) { - fp = atop(32 << 20); - if (fp >= lp) - continue; - np = lp - fp; - physmem += atop(32 << 20); - } - - if (memrange_register(fp, lp, - ~(atop(1UL << kl_n_shift) - 1)) != 0) { - /* - * We could hijack the smallest segment here. - * But is it really worth doing? - */ - bios_printf("%lu MB of memory could not be " - "managed, increase MAXMEMSEGS\n", - ptoa(np) >> 20); - } - } - } -} - -/* - * On IP35, the smallest memory DIMMs are 256MB, and the largest is 1GB. - * Memory is reported at 1GB intervals. - */ -void -kl_add_memory_ip35(int16_t nasid, int16_t *sizes, unsigned int cnt) -{ - paddr_t basepa; - uint64_t fp, lp, np; - - basepa = (paddr_t)nasid << kl_n_shift; - while (cnt-- != 0) { - np = *sizes++; - if (np != 0) { - DB_PRF(("IP35 memory from %#lx to %#llx (%llu MB)\n", - basepa, basepa + (np << 20), np)); - - fp = atop(basepa); - np = atop(np << 20); /* MB to pages */ - lp = fp + np; - - /* - * We do not manage the first 64MB, so skip them here - * if necessary. - */ - if (fp < atop(64 << 20)) { - fp = atop(64 << 20); - if (fp >= lp) - continue; - np = lp - fp; - physmem += atop(64 << 20); - } - - if (memrange_register(fp, lp, - ~(atop(1UL << kl_n_shift) - 1)) != 0) { - /* - * We could hijack the smallest segment here. - * But is it really worth doing? - */ - bios_printf("%lu MB of memory could not be " - "managed, increase MAXMEMSEGS\n", - ptoa(np) >> 20); - } - } - basepa += 1UL << 30; /* 1 GB */ - } -} - -/* - * Extract unique device location from a klinfo structure. - */ -void -kl_get_location(klinfo_t *cmp, struct sgi_device_location *sdl) -{ - uint32_t wid; - int device = cmp->physid; - - /* - * If the widget is actually a PIC, we need to compensate - * for PCI device numbering. - */ - if (xbow_widget_id(cmp->nasid, cmp->widid, &wid) == 0) { - if (WIDGET_ID_VENDOR(wid) == XBOW_VENDOR_SGI3 && - WIDGET_ID_PRODUCT(wid) == XBOW_PRODUCT_SGI3_PIC) - device--; - } - - sdl->nasid = cmp->nasid; - sdl->widget = cmp->widid; - if (sys_config.system_type == SGI_IP35) { - /* - * IP35: need to be aware of secondary buses on PIC, and - * multifunction PCI cards. - */ - sdl->bus = cmp->pci_bus_num; - sdl->device = device; - if (cmp->pci_multifunc) - sdl->fn = cmp->pci_func_num; - else - sdl->fn = -1; - sdl->specific = cmp->port; - } else { - /* - * IP27: secondary buses and multifunction PCI devices are - * not recognized. - */ - sdl->bus = 0; - sdl->device = device; - sdl->fn = -1; - sdl->specific = 0; - } -} - -/* - * Similar to the above, but for the input console device, which information - * does not come from a klinfo structure. - */ -void -kl_get_console_location(console_t *cons, struct sgi_device_location *sdl) -{ - uint32_t wid; - int device = cons->npci; - - /* - * If the widget is actually a PIC, we need to compensate - * for PCI device numbering. - */ - if (xbow_widget_id(cons->nasid, cons->wid, &wid) == 0) { - if (WIDGET_ID_VENDOR(wid) == XBOW_VENDOR_SGI3 && - WIDGET_ID_PRODUCT(wid) == XBOW_PRODUCT_SGI3_PIC) - device--; - } - - sdl->nasid = cons->nasid; - sdl->widget = cons->wid; - sdl->fn = -1; - sdl->specific = cons->type; - - /* - * This is a disgusting hack. The console structure does not - * contain a precise PCI device identification, and will also - * not point to the relevant klinfo structure. - * - * We assume that if the console `type' is not the IOC3 PCI - * identifier, then it is an IOC4 device connected to a PIC - * bus, therefore we can compute proper PCI location from the - * `npci' field. - */ - - if (cons->type == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3) || - sys_config.system_type != SGI_IP35) { - sdl->bus = 0; - sdl->device = device; - } else { - sdl->bus = cons->npci & KLINFO_PHYSID_PIC_BUS1 ? 1 : 0; - sdl->device = device & KLINFO_PHYSID_WIDGET_MASK; - } -} diff --git a/sys/arch/sgi/sgi/wscons_machdep.c b/sys/arch/sgi/sgi/wscons_machdep.c deleted file mode 100644 index abcf131e234..00000000000 --- a/sys/arch/sgi/sgi/wscons_machdep.c +++ /dev/null @@ -1,376 +0,0 @@ -/* $OpenBSD: wscons_machdep.c,v 1.12 2015/12/22 21:36:57 mmcc Exp $ */ - -/* - * Copyright (c) 2010 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2001 Aaron Campbell - * 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 ``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 HIS RELATIVES 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 MIND, 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. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/conf.h> -#include <sys/device.h> -#include <sys/extent.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#if defined(TGT_ORIGIN) -#include <machine/mnode.h> -#endif - -#include <mips64/arcbios.h> -#include <mips64/archtype.h> - -#include <dev/cons.h> -#include <dev/ic/i8042reg.h> -#include <dev/ic/pckbcvar.h> -#include <dev/usb/ukbdvar.h> -#include <dev/wscons/wskbdvar.h> -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsdisplayvar.h> - -#include <sgi/dev/gbereg.h> -#include <sgi/dev/impactvar.h> -#include <sgi/dev/iockbcvar.h> -#include <sgi/dev/mkbcreg.h> -#include <sgi/gio/giovar.h> -#include <sgi/hpc/hpcreg.h> -#include <sgi/hpc/hpcvar.h> -#include <sgi/hpc/iocreg.h> -#include <sgi/localbus/crimebus.h> -#include <sgi/localbus/macebus.h> -#include <sgi/localbus/macebusvar.h> -#include <sgi/xbow/odysseyvar.h> - -#if defined(TGT_OCTANE) -#include <sgi/sgi/ip30.h> -#include <dev/pci/pcireg.h> -#include <dev/pci/pcidevs.h> -#endif - -#include "gbe.h" -#include "gio.h" -#include "iockbc.h" -#include "impact.h" -#include "mkbc.h" -#include "odyssey.h" -#include "pckbc.h" -#include "ukbd.h" -#include "zskbd.h" - -cons_decl(ws); -extern bus_addr_t comconsaddr; - -#if defined(TGT_OCTANE) || defined(TGT_ORIGIN) -struct sgi_device_location console_output; -struct sgi_device_location console_input; -int (*output_widget_cninit)(void) = NULL; - -int widget_cnprobe(void); -void widget_cnattach(void); -#endif - -void -wscnprobe(struct consdev *cp) -{ - int maj; - - /* Locate the major number. */ - for (maj = 0; maj < nchrdev; maj++) { - if (cdevsw[maj].d_open == wsdisplayopen) - break; - } - - if (maj == nchrdev) { - /* We are not in cdevsw[], give up. */ - panic("wsdisplay is not in cdevsw[]"); - } - - cp->cn_dev = makedev(maj, 0); - cp->cn_pri = CN_DEAD; - - switch (sys_config.system_type) { -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) - case SGI_IP20: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: -#if NGIO > 0 - if (giofb_cnprobe() == 0) { - if (strncmp(bios_console, "video", 5) == 0) - cp->cn_pri = CN_FORCED; - else - cp->cn_pri = CN_MIDPRI; - } -#endif - break; -#endif /* TGT_INDIGO || TGT_INDY || TGT_INDIGO2 */ - -#if defined(TGT_O2) - case SGI_O2: -#if NGBE > 0 - if (gbe_cnprobe(&crimebus_tag, GBE_BASE) != 0) { - if (strncmp(bios_console, "video", 5) == 0) - cp->cn_pri = CN_FORCED; - else - cp->cn_pri = CN_MIDPRI; - } -#endif - break; -#endif /* TGT_O2 */ - -#if defined(TGT_ORIGIN) - case SGI_IP27: - case SGI_IP35: - if (widget_cnprobe() != 0) { - if (strncmp(bios_console, - "/dev/graphics/textport", 22) == 0) - cp->cn_pri = CN_FORCED; - else - cp->cn_pri = CN_MIDPRI; - } - break; -#endif /* TGT_ORIGIN */ - -#if defined(TGT_OCTANE) - case SGI_OCTANE: - if (widget_cnprobe() != 0) { - if (strncmp(bios_console, "video", 5) == 0) - cp->cn_pri = CN_FORCED; - else - cp->cn_pri = CN_MIDPRI; - } - break; -#endif /* TGT_OCTANE */ - - default: - break; - } -} - -void -wscninit(struct consdev *cp) -{ -static int initted; - - if (initted) - return; - - initted = 1; - - switch (sys_config.system_type) { -#if defined(TGT_INDIGO) || defined(TGT_INDY) || defined(TGT_INDIGO2) - case SGI_IP20: - case SGI_IP22: - case SGI_IP26: - case SGI_IP28: -#if NGIO > 0 - if (giofb_cnattach() != 0) - return; -#endif - if (sys_config.system_type == SGI_IP20) { -#if NZSKBD > 0 - extern void zskbd_cnattach(int, int); - zskbd_cnattach(0, 0); -#endif - } else { -#if NPCKBC > 0 - if (pckbc_cnattach(&hpc3bus_tag, - HPC_BASE_ADDRESS_0 + IOC_BASE + IOC_KB_REGS + 3, - KBCMDP - KBDATAP, 0)) - return; -#endif - } - break; -#endif /* TGT_INDIGO || TGT_INDY || TGT_INDIGO2 */ - -#if defined(TGT_O2) - case SGI_O2: -#if NGBE > 0 - if (gbe_cnattach(&crimebus_tag, GBE_BASE) != 0) - return; -#endif - -#if NMKBC > 0 - if (mkbc_cnattach(&macebus_tag, MACE_IO_KBC_OFFS) == 0) - return; /* console keyboard found */ -#endif -#if NUKBD > 0 - /* fallback keyboard console attachment if the others failed */ - ukbd_cnattach(); -#endif - break; -#endif /* TGT_O2 */ - -#if defined(TGT_OCTANE) || defined(TGT_ORIGIN) - case SGI_IP27: - case SGI_IP35: - case SGI_OCTANE: - widget_cnattach(); - break; -#endif /* TGT_OCTANE || TGT_ORIGIN */ - - default: - break; - } -} - -void -wscnputc(dev_t dev, int i) -{ - wsdisplay_cnputc(dev, i); -} - -int -wscngetc(dev_t dev) -{ - int c; - - wskbd_cnpollc(dev, 1); - c = wskbd_cngetc(dev); - wskbd_cnpollc(dev, 0); - - return c; -} - -void -wscnpollc(dev_t dev, int on) -{ - wskbd_cnpollc(dev, on); -} - -/* - * Try to figure out if we have a glass console widget, and if we have - * a driver for it. - */ - -#if defined(TGT_OCTANE) || defined(TGT_ORIGIN) -int -widget_cnprobe() -{ -#ifdef TGT_ORIGIN - console_t *cons; -#endif - - switch (sys_config.system_type) { -#ifdef TGT_ORIGIN - case SGI_IP27: - case SGI_IP35: - /* - * Our first pass over the KL configuration data has figured - * out which component is the glass console, if any. - */ - if (kl_glass_console == NULL) - return 0; - kl_get_location(kl_glass_console, &console_output); - - cons = kl_get_console(); - kl_get_console_location(cons, &console_input); - break; -#endif -#ifdef TGT_OCTANE - case SGI_OCTANE: - console_output.nasid = masternasid; - console_output.widget = ip30_find_video(); - if (console_output.widget == 0) - return 0; - - console_input.nasid = masternasid; - console_input.widget = IP30_BRIDGE_WIDGET; - console_input.bus = 0; - console_input.device = IP30_IOC_SLOTNO; - console_input.fn = -1; - console_input.specific = - PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3); - break; -#endif - default: - return 0; - } - - /* - * Try supported frame buffers in no particular order. - */ - -#if NIMPACT_XBOW > 0 - if (impact_xbow_cnprobe() != 0) { - output_widget_cninit = impact_xbow_cnattach; - goto success; - } -#endif -#if NODYSSEY > 0 - if (odyssey_cnprobe() != 0) { - output_widget_cninit = odyssey_cnattach; - goto success; - } -#endif - - return 0; - -success: - /* - * At this point, we are committed to setup a glass console, - * so prevent serial console from winning over. - */ - comconsaddr = 0; - - return 1; -} - -void -widget_cnattach() -{ - /* should not happen */ - if (output_widget_cninit == NULL) - return; - - if ((*output_widget_cninit)() != 0) - return; - -#if NIOCKBC > 0 - if (iockbc_cnattach() == 0) - return; /* console keyboard found */ -#endif -#if NUKBD > 0 - /* fallback keyboard console attachment if the others failed */ - ukbd_cnattach(); -#endif -} -#endif /* TGT_ORIGIN || TGT_OCTANE */ diff --git a/sys/arch/sgi/stand/Makefile b/sys/arch/sgi/stand/Makefile deleted file mode 100644 index d18503c5228..00000000000 --- a/sys/arch/sgi/stand/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -# $OpenBSD: Makefile,v 1.8 2012/03/28 20:44:23 miod Exp $ - -SUBDIR= sgivol - -.if ${MACHINE} == "sgi" -SUBDIR+= libsa libsa32 libz libz32 -SUBDIR+= boot64 boot32 bootecoff -.endif - -.include <bsd.subdir.mk> diff --git a/sys/arch/sgi/stand/Makefile.inc b/sys/arch/sgi/stand/Makefile.inc deleted file mode 100644 index b99376334ec..00000000000 --- a/sys/arch/sgi/stand/Makefile.inc +++ /dev/null @@ -1,46 +0,0 @@ -# $OpenBSD: Makefile.inc,v 1.10 2012/10/19 13:51:59 miod Exp $ -# $NetBSD: Makefile.inc,v 1.7 2000/08/20 14:57:16 mrg Exp $ - -.ifndef __INCLUDED_STAND_MAKEFILE_INC -__INCLUDED_STAND_MAKEFILE_INC= - -BINDIR= /usr/mdec - -STANDALONE?= -D_STANDALONE - -.if ${MACHINE} == "sgi" -CPPFLAGS+= ${STANDALONE} -CPPFLAGS+= -I. - -CFLAGS+= -fno-stack-protector -Wall -CFLAGS+= -fno-builtin-vprintf -fno-builtin-printf -fno-builtin-putchar -CFLAGS+= -fno-builtin-exit -SAABI?= -mips3 -mno-abicalls -D_NO_ABICALLS -G 0 -fno-pic -fno-common -AS?= as -LD?= ld -LIBSA_CPPFLAGS?= -DNEEDS_HEAP_H -.endif - -### Figure out what to use for libsa -LIBSADIR?= ${.CURDIR}/../libsa - -.if exists(${LIBSADIR}/${__objdir}) -LIBSAOBJDIR= ${LIBSADIR}/${__objdir} -.else -LIBSAOBJDIR= ${LIBSADIR} -.endif - -LIBSA= ${LIBSAOBJDIR}/libsa.a - -### Figure out what to use for libz -LIBZDIR?= ${.CURDIR}/../libz - -.if exists(${LIBZDIR}/${__objdir}) -LIBZOBJDIR= ${LIBZDIR}/${__objdir} -.else -LIBZOBJDIR= ${LIBZDIR} -.endif - -LIBZ= ${LIBZOBJDIR}/libz.a - -.endif diff --git a/sys/arch/sgi/stand/Makefile32.inc b/sys/arch/sgi/stand/Makefile32.inc deleted file mode 100644 index 4b5e1977735..00000000000 --- a/sys/arch/sgi/stand/Makefile32.inc +++ /dev/null @@ -1,28 +0,0 @@ -# $OpenBSD: Makefile32.inc,v 1.6 2016/10/05 11:55:45 visa Exp $ - -.ifndef __INCLUDED_STAND_MAKEFILE32_INC -__INCLUDED_STAND_MAKEFILE32_INC= - -.if ${MACHINE} == "sgi" -# Silence warnings -CFLAGS+= -fno-builtin-snprintf -CFLAGS+= -fno-builtin-memcpy -CFLAGS+= -fno-builtin-memcmp -CFLAGS+= -fno-builtin-memset -CFLAGS+= -fno-builtin-strncpy -CFLAGS+= -fno-builtin-strncmp -# Override toolchain options to force 32 bit binaries -SAABI= -mno-abicalls -D_NO_ABICALLS -mabi=32 -mips2 -Wa,-G0 -AS?= as -AS+= -32 -LD?= ld -LD+= -m elf32btsmip -LIBSA_CPPFLAGS= -CFLAGS+= -DLIBSA_LONGLONG_PRINTF -.endif - -### Figure out what to use for libsa and libz -LIBSADIR= ${.CURDIR}/../libsa32 -LIBZDIR= ${.CURDIR}/../libz32 - -.endif diff --git a/sys/arch/sgi/stand/boot/Makefile b/sys/arch/sgi/stand/boot/Makefile deleted file mode 100644 index b9283f2d3b9..00000000000 --- a/sys/arch/sgi/stand/boot/Makefile +++ /dev/null @@ -1,32 +0,0 @@ -# $OpenBSD: Makefile,v 1.20 2019/10/29 02:55:52 deraadt Exp $ - -NOMAN= noman - -CFLAGS+= ${SAABI} -mno-abicalls -D_NO_ABICALLS -nostdinc -D__sgi__ \ - -I${.CURDIR}/../include -I${.CURDIR}/../../../.. \ - -I${.CURDIR}/../../../../lib/libsa \ - -I${.OBJDIR} -CFLAGS+= -D__INTERNAL_LIBSA_CREAD ${STANDALONE} -fno-pie -LDFLAGS+= -nopie -znorelro - -AFLAGS+= ${SAABI} - -S= ${.CURDIR}/../../../.. -SRCS= start.S arcbios.c boot.c conf.c diskio.c filesystem.c \ - netfs.c netio.c strstr.c - -.PATH: ${S}/lib/libsa -SRCS+= loadfile.c arc4.c - -.PATH: ${S}/lib/libkern/arch/mips64 ${S}/lib/libkern -SRCS+= memcpy.c memmove.c strchr.c strcmp.S strlcat.c strlcpy.c strlen.c \ - strncmp.c strrchr.c - -CLEANFILES+= machine mips64 - -.if !make(clean) && !make(cleandir) && !make(includes) && !make(libdep) && \ - !make(sadep) && !make(salibdir) && !make(obj) -.BEGIN: - @([ -h machine ] || ln -s ${.CURDIR}/../../include machine) - @([ -h mips64 ] || ln -s ${.CURDIR}/../../../mips64/include mips64) -.endif diff --git a/sys/arch/sgi/stand/boot/arcbios.c b/sys/arch/sgi/stand/boot/arcbios.c deleted file mode 100644 index e4196d7aff3..00000000000 --- a/sys/arch/sgi/stand/boot/arcbios.c +++ /dev/null @@ -1,408 +0,0 @@ -/* $OpenBSD: arcbios.c,v 1.20 2014/03/29 18:09:30 guenther Exp $ */ -/*- - * Copyright (c) 1996 M. Warner Losh. All rights reserved. - * Copyright (c) 1996-2004 Opsycon AB. 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 REGENTS 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 REGENTS 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. - */ - -#include <sys/param.h> -#include <lib/libkern/libkern.h> - -#include <mips64/arcbios.h> -#include <mips64/archtype.h> -#include <machine/autoconf.h> -#include <machine/cpu.h> -#include <machine/mnode.h> - -#include <stand.h> - -#ifdef __LP64__ -int bios_is_32bit; -#endif -void *bios_base; -#ifdef __LP64__ -u_int kl_n_shift = 32; -#endif - -int arcbios_init(void); -const char *boot_get_path_component(const char *, char *, int *); -const char *boot_getnr(const char *, int *); - -static const struct systypes { - char *sys_name; - int sys_ip; -} sys_types[] = { - { "SGI-IP20", 20 }, - { "SGI-IP22", 22 }, - { "SGI-IP26", 26 }, - { "SGI-IP28", 28 }, - { "SGI-IP30", 30 }, - { "SGI-IP32", 32 } -}; - -#define KNOWNSYSTEMS (nitems(sys_types)) - -/* - * ARCBios trampoline code. - */ -#ifdef __LP64__ -#define ARC_Call(Name,Offset) \ -__asm__("\n" \ -" .text\n" \ -" .ent " #Name "\n" \ -" .align 3\n" \ -" .set noreorder\n" \ -" .globl " #Name "\n" \ -#Name":\n" \ -" lw $3, bios_is_32bit\n"\ -" ld $2, bios_base\n"\ -" beqz $3, 1f\n" \ -" nop\n" \ -" lw $3, 0x20($2)\n" \ -" lw $2," #Offset "($3)\n"\ -" jr $2\n" \ -" nop\n" \ -"1:\n" \ -" ld $3, 2*0x20($2)\n"\ -" ld $2, 2*" #Offset "($3)\n"\ -" jr $2\n" \ -" nop\n" \ -" .end " #Name "\n" ); -#else -#define ARC_Call(Name,Offset) \ -__asm__("\n" \ -" .text\n" \ -" .ent " #Name "\n" \ -" .align 3\n" \ -" .set noreorder\n" \ -" .globl " #Name "\n" \ -#Name":\n" \ -" lw $2, bios_base\n"\ -" lw $3, 0x20($2)\n" \ -" lw $2," #Offset "($3)\n"\ -" jr $2\n" \ -" nop\n" \ -" .end " #Name "\n" ); -#endif - -#if 0 -ARC_Call(Bios_Load, 0x00); -ARC_Call(Bios_Invoke, 0x04); -ARC_Call(Bios_Execute, 0x08); -#endif -ARC_Call(Bios_Halt, 0x0c); -#if 0 -ARC_Call(Bios_PowerDown, 0x10); -ARC_Call(Bios_Restart, 0x14); -ARC_Call(Bios_Reboot, 0x18); -#endif -ARC_Call(Bios_EnterInteractiveMode, 0x1c); -#if 0 -ARC_Call(Bios_Unused1, 0x20); -#endif -ARC_Call(Bios_GetPeer, 0x24); -ARC_Call(Bios_GetChild, 0x28); -#if 0 -ARC_Call(Bios_GetParent, 0x2c); -ARC_Call(Bios_GetConfigurationData, 0x30); -ARC_Call(Bios_AddChild, 0x34); -ARC_Call(Bios_DeleteComponent, 0x38); -ARC_Call(Bios_GetComponent, 0x3c); -ARC_Call(Bios_SaveConfiguration, 0x40); -#endif -ARC_Call(Bios_GetSystemId, 0x44); -ARC_Call(Bios_GetMemoryDescriptor, 0x48); -#if 0 -ARC_Call(Bios_Unused2, 0x4c); -ARC_Call(Bios_GetTime, 0x50); -ARC_Call(Bios_GetRelativeTime, 0x54); -ARC_Call(Bios_GetDirectoryEntry, 0x58); -#endif -ARC_Call(Bios_Open, 0x5c); -ARC_Call(Bios_Close, 0x60); -ARC_Call(Bios_Read, 0x64); -#if 0 -ARC_Call(Bios_GetReadStatus, 0x68); -#endif -ARC_Call(Bios_Write, 0x6c); -ARC_Call(Bios_Seek, 0x70); -#if 0 -ARC_Call(Bios_Mount, 0x74); -ARC_Call(Bios_GetEnvironmentVariable, 0x78); -ARC_Call(Bios_SetEnvironmentVariable, 0x7c); -ARC_Call(Bios_GetFileInformation, 0x80); -ARC_Call(Bios_SetFileInformation, 0x84); -ARC_Call(Bios_FlushAllCaches, 0x88); -ARC_Call(Bios_TestUnicodeCharacter, 0x8c); -ARC_Call(Bios_GetDisplayStatus, 0x90); -#endif - -/* - * Simple getchar/putchar interface. - */ - -#if 0 -int -getchar() -{ - char buf[4]; - long cnt; - - if (Bios_Read(0, &buf[0], 1, &cnt) != 0) - return (-1); - - return (buf[0] & 255); -} -#endif - -void -putchar(int c) -{ - char buf[4]; - long cnt; - - if (c == '\n') { - buf[0] = '\r'; - buf[1] = c; - cnt = 2; - } else { - buf[0] = c; - cnt = 1; - } - - Bios_Write(1, &buf[0], cnt, &cnt); -} - -/* - * Identify ARCBios type. - */ -int -arcbios_init() -{ - arc_config_t *cf; - arc_sid_t *sid; -#ifdef __LP64__ - register_t prid; -#endif - char *sysid = NULL; - int sysid_len; - int i; - - /* - * Figure out where ARCBios can be addressed. On R8000, we can not - * use compatibility space, but on IP27/IP35, we can not blindly - * use XKPHYS due to subspacing, while compatibility space works. - * Fortunately we can get the processor ID to tell these apart, even - * though 32-bit coprocessor 0 instructions are not supposed to be - * supported on the R8000 (they probably misbehave somehow if the - * register has bits sets in the upper 32 bits, which is not the - * case of the R8000 PrId register). - */ -#ifdef __LP64__ - __asm__ volatile ("mfc0 %0, $15" /* COP_0_PRID */ : "=r" (prid)); - if ((prid & 0xff00) == (MIPS_R8000 << 8)) - bios_base = (void *)PHYS_TO_XKPHYS(ARCBIOS_BASE, CCA_CACHED); - else - bios_base = (void *)PHYS_TO_CKSEG0(ARCBIOS_BASE); -#else - bios_base = (void *)(int32_t)PHYS_TO_CKSEG0(ARCBIOS_BASE); -#endif - - /* - * Figure out if this is an ARCBios machine and if it is, see if we're - * dealing with a 32 or 64 bit version. - */ -#ifdef __LP64__ - if ((ArcBiosBase32->magic == ARC_PARAM_BLK_MAGIC) || - (ArcBiosBase32->magic == ARC_PARAM_BLK_MAGIC_BUG)) { - bios_is_32bit = 1; - } else if ((ArcBiosBase64->magic == ARC_PARAM_BLK_MAGIC) || - (ArcBiosBase64->magic == ARC_PARAM_BLK_MAGIC_BUG)) { - bios_is_32bit = 0; - } -#endif - - /* - * Minimal system identification. - */ - sid = (arc_sid_t *)Bios_GetSystemId(); - cf = (arc_config_t *)Bios_GetChild(NULL); - if (cf != NULL) { -#ifdef __LP64__ - if (bios_is_32bit) { - sysid = (char *)(long)cf->id; - sysid_len = cf->id_len; - } else { - sysid = (char *)((arc_config64_t *)cf)->id; - sysid_len = ((arc_config64_t *)cf)->id_len; - } -#else - sysid = (char *)(long)cf->id; - sysid_len = cf->id_len; -#endif - - if (sysid_len > 0 && sysid != NULL) { - sysid_len--; - for (i = 0; i < KNOWNSYSTEMS; i++) { - if (strlen(sys_types[i].sys_name) != sysid_len) - continue; - if (strncmp(sys_types[i].sys_name, sysid, - sysid_len) != 0) - continue; - return sys_types[i].sys_ip; /* Found it. */ - } - } - } else { -#ifdef __LP64__ - if (IP27_KLD_KLCONFIG(0)->magic == IP27_KLDIR_MAGIC) { - /* - * If we find a kldir assume IP27. Boot blocks - * do not need to tell IP27 and IP35 apart. - */ - return 27; - } -#endif - } - - printf("UNRECOGNIZED SYSTEM '%s' VENDOR '%s' PRODUCT '%s'\n", - cf == NULL || sysid == NULL ? "(null)" : sysid, - sid->vendor, sid->prodid); - printf("Halting system!\n"); - Bios_Halt(); - printf("Halting failed, use manual reset!\n"); - for (;;) ; -} - -/* - * Decompose the device pathname and find driver. - * Returns pointer to remaining filename path in file. - */ -int -devopen(struct open_file *f, const char *fname, char **file) -{ - const char *cp, *ncp, *ecp; - struct devsw *dp; - int partition = 0; - char namebuf[256]; - char devname[32]; - int rc, i, n, noopen = 0; - - ecp = cp = fname; - namebuf[0] = '\0'; - - /* - * Scan the component list and find device and partition. - */ - if (strncmp(cp, "bootp()", 7) == 0) { - strlcpy(devname, "bootp", sizeof(devname)); - strlcpy(namebuf, cp, sizeof(namebuf)); - noopen = 1; - } else if (strncmp(cp, "dksc(", 5) == 0) { - strncpy(devname, "scsi", sizeof(devname)); - cp += 5; - cp = boot_getnr(cp, &i); - /* i = controller number */ - if (*cp++ == ',') { - cp = boot_getnr(cp, &i); - /* i = target id */ - if (*cp++ == ',') { - memcpy(namebuf, fname, cp - fname); - namebuf[cp - fname] = '\0'; - strlcat(namebuf, "0)", sizeof namebuf); - - cp = boot_getnr(cp, &i); - partition = i; - cp++; /* skip final ) */ - } - } - } else { - ncp = boot_get_path_component(cp, namebuf, &i); - while (ncp != NULL) { - if (strcmp(namebuf, "partition") == 0) - partition = i; - ecp = ncp; - - /* XXX Do this with a table if more devs are added. */ - if (strcmp(namebuf, "scsi") == 0) - strncpy(devname, namebuf, sizeof(devname)); - - cp = ncp; - ncp = boot_get_path_component(cp, namebuf, &i); - } - - memcpy(namebuf, fname, ecp - fname); - namebuf[ecp - fname] = '\0'; - } - - /* - * Dig out the driver. - */ - dp = devsw; - n = ndevs; - while (n--) { - if (strcmp(devname, dp->dv_name) == 0) { - if (noopen) - rc = 0; - else - rc = (dp->dv_open)(f, namebuf, partition, 0); - if (rc == 0) { - f->f_dev = dp; - if (file && *cp != '\0') - *file = (char *)cp; - } - return (rc); - } - dp++; - } - return (ENXIO); -} - -const char * -boot_get_path_component(const char *p, char *comp, int *no) -{ - while (*p && *p != '(') - *comp++ = *p++; - *comp = '\0'; - - if (*p == '\0') - return (NULL); - - *no = 0; - p++; - while (*p && *p != ')') { - if (*p >= '0' && *p <= '9') - *no = *no * 10 + *p++ - '0'; - else - return (NULL); - } - return (++p); -} - -const char * -boot_getnr(const char *p, int *no) -{ - *no = 0; - while (*p >= '0' && *p <= '9') - *no = *no * 10 + *p++ - '0'; - return p; -} diff --git a/sys/arch/sgi/stand/boot/boot.c b/sys/arch/sgi/stand/boot/boot.c deleted file mode 100644 index cd3e104ab6b..00000000000 --- a/sys/arch/sgi/stand/boot/boot.c +++ /dev/null @@ -1,323 +0,0 @@ -/* $OpenBSD: boot.c,v 1.30 2020/06/06 10:53:09 visa Exp $ */ - -/* - * Copyright (c) 2004 Opsycon AB, www.opsycon.se. - * - * 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 ``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 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. - * - */ - -#include <sys/param.h> -#include <sys/stat.h> -#define _KERNEL -#include <sys/fcntl.h> -#undef _KERNEL - -#include <lib/libkern/libkern.h> -#include <lib/libsa/arc4.h> -#include <stand.h> - -#include <mips64/arcbios.h> -#include <mips64/cpu.h> - -#include <sys/exec_elf.h> -#undef ELFSIZE -#include "loadfile.h" - -void dobootopts(int, char **); -int loadrandom(const char *, const char *, void *, size_t); -char *strstr(char *, const char *); /* strstr.c */ - -enum { - AUTO_NONE, - AUTO_YES, - AUTO_NO, - AUTO_MINI, - AUTO_DEBUG -} bootauto = AUTO_NONE; -char *OSLoadPartition = NULL; -char *OSLoadFilename = NULL; - -int IP; - -char rnddata[BOOTRANDOM_MAX]; -struct rc4_ctx randomctx; - -/* - * OpenBSD/sgi Boot Loader. - */ -void -boot_main(int argc, char *argv[]) -{ - uint64_t marks[MARK_MAX]; - u_int64_t *esym; - char line[1024]; - u_long entry; - int fd; - extern int arcbios_init(void); - extern char version[]; - - IP = arcbios_init(); - printf("\nOpenBSD/sgi-IP%d ARCBios boot version %s\n", IP, version); - /* we want to print IP20 but load IP22 */ - if (IP == 20) - IP = 22; - - for (entry = 0; entry < argc; entry++) - printf("arg %d: %s\n", entry, argv[entry]); - - dobootopts(argc, argv); - if (OSLoadPartition == NULL) { - /* - * Things are probably horribly wrong, or user has no idea - * what's he's doing. Be nice lads and try to provide - * working defaults, which ought to work on all systems. - */ - OSLoadPartition = "disk(0)part(0)"; - } - strlcpy(line, OSLoadPartition, sizeof(line)); - if (OSLoadFilename != NULL) - strlcat(line, OSLoadFilename, sizeof(line)); - - printf("Boot: %s\n", line); - - /* - * Try and load randomness if booting from a disk. - */ - - if (bootauto != AUTO_MINI && - strstr(OSLoadPartition, "bootp(") == NULL && - strstr(OSLoadPartition, "cdrom(") == NULL) { - /* XXX set RB_GOODRANDOM in boothowto */ - loadrandom(OSLoadPartition, BOOTRANDOM, rnddata, - sizeof(rnddata)); - } - - rc4_keysetup(&randomctx, rnddata, sizeof rnddata); - rc4_skip(&randomctx, 1536); - - /* - * Load the kernel and symbol table. - */ - - marks[MARK_START] = 0; - if ((fd = loadfile(line, marks, LOAD_KERNEL | COUNT_KERNEL)) != -1) { - (void)close(fd); - - entry = marks[MARK_ENTRY]; -#ifdef __LP64__ - esym = (u_int64_t *)marks[MARK_END]; -#else -#undef CKSEG0_BASE -#define CKSEG0_BASE 0xffffffff80000000ULL - esym = (u_int64_t *)(uint32_t)PHYS_TO_CKSEG0(marks[MARK_END]); -#endif - - if (entry != 0) - ((void (*)())entry)(argc, argv, esym); - } - - /* We failed to load the kernel. */ - panic("Boot FAILED!"); - /* NOTREACHED */ -} - -__dead void -_rtt() -{ - Bios_EnterInteractiveMode(); - for (;;) ; -} - -/* - * Decode boot options. - */ -void -dobootopts(int argc, char **argv) -{ - static char filenamebuf[1 + 32]; - char *SystemPartition = NULL; - char *cp, *sep; - int i; - char *writein = NULL; - - for (i = 1; i < argc; i++) { - cp = argv[i]; - if (cp == NULL) - continue; - if (strncmp(cp, "OSLoadOptions=", 14) == 0) { - if (strcmp(&cp[14], "auto") == 0) - bootauto = AUTO_YES; - else if (strcmp(&cp[14], "single") == 0) - bootauto = AUTO_NO; - else if (strcmp(&cp[14], "mini") == 0) - bootauto = AUTO_MINI; - else if (strcmp(&cp[14], "debug") == 0) - bootauto = AUTO_DEBUG; - } else if (strncmp(cp, "OSLoadPartition=", 16) == 0) - OSLoadPartition = &cp[16]; - else if (strncmp(cp, "OSLoadFilename=", 15) == 0) - OSLoadFilename = &cp[15]; - else if (strncmp(cp, "SystemPartition=", 16) == 0) - SystemPartition = &cp[16]; - else { - /* - * Either a boot-related environment variable, or - * a boot write-in (boot path or options to the - * program being loaded). - */ - if (*cp == '-') - continue; /* options */ - if (strchr(cp, '=') != NULL) - continue; /* variable (or bad choice */ - /* of filename) */ - if (writein == NULL) - writein = cp; - } - } - - switch (bootauto) { - case AUTO_NONE: - /* If "OSLoadOptions=" is missing, use boot path if given. */ - if (writein != NULL) { - /* check for a possible path component */ - sep = strchr(writein, '('); - if (sep != NULL && strchr(sep, ')') != NULL) { - /* looks like this is a full path */ - OSLoadPartition = ""; - } else { - /* relative path, keep OSLoadPartition */ - } - OSLoadFilename = writein; - } - break; - case AUTO_MINI: - { - static char loadpart[64]; - char *p; - - strlcpy(loadpart, argv[0], sizeof loadpart); - if ((p = strstr(loadpart, "partition(8)")) != NULL) { - p += strlen("partition("); - } else if (strncmp(loadpart, "dksc(", 5) == 0) { - p = strstr(loadpart, ",8)"); - if (p != NULL) - p++; - } else - p = NULL; - - if (p != NULL) { - p[0] = '0'; - p[2] = '\0'; - snprintf(filenamebuf, sizeof filenamebuf, - "/bsd.rd.IP%d", IP); - OSLoadPartition = loadpart; - OSLoadFilename = filenamebuf; - } - } - break; - default: - break; - } -} - -/* - * Prevent loading a wrong kernel. - */ -int -check_phdr(void *v) -{ - Elf64_Phdr *phdr = (Elf64_Phdr *)v; - uint64_t addr; - - switch (IP) { - case 22: - addr = 0xffffffff88000000ULL >> 24; - break; - case 26: - addr = 0xa800000008000000ULL >> 24; - break; - case 27: - addr = 0xa800000000000000ULL >> 24; - break; - case 28: - case 30: - addr = 0xa800000020000000ULL >> 24; - break; - case 32: - addr = 0xffffffff80000000ULL >> 24; - break; - default: - /* - * If the system could not be identified, accept any - * address and hope the user knows what's he's doing. - */ - return 0; - } - - if ((phdr->p_vaddr >> 24) != addr) { - /* I'm sorry Dave, I can't let you do that. */ - printf("This kernel does not seem to be compiled for this" - " machine type.\nYou need to boot an IP%d kernel.\n", IP); - return 1; - } - - return 0; -} - -/* - * Load the saved randomness file. - */ -int -loadrandom(const char *partition, const char *name, void *buf, size_t buflen) -{ - char path[MAXPATHLEN]; - struct stat sb; - int fd, error = 0; - - strlcpy(path, partition, sizeof path); - strlcat(path, name, sizeof path); - - fd = open(path, O_RDONLY); - if (fd == -1) { - if (errno != EPERM) - printf("cannot open %s: %s\n", path, strerror(errno)); - return (-1); - } - if (fstat(fd, &sb) == -1) { - error = -1; - goto done; - } - if (read(fd, buf, buflen) != buflen) { - error = -1; - goto done; - } - if (sb.st_mode & S_ISTXT) { - printf("NOTE: random seed is being reused.\n"); - error = -1; - goto done; - } - fchmod(fd, sb.st_mode | S_ISTXT); -done: - close(fd); - return (error); -} diff --git a/sys/arch/sgi/stand/boot/conf.c b/sys/arch/sgi/stand/boot/conf.c deleted file mode 100644 index 98699afd778..00000000000 --- a/sys/arch/sgi/stand/boot/conf.c +++ /dev/null @@ -1,51 +0,0 @@ -/* $OpenBSD: conf.c,v 1.9 2020/12/09 18:10:19 krw Exp $ */ - -/* - * Copyright (c) 1997 Per Fogelstrom - * - * 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 ``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 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. - * - */ -#include <stand.h> - -const char version[] = "1.13"; - -extern void nullsys(); -extern int nodev(); -extern int noioctl(); - -int diostrategy(void *, int, daddr_t, size_t, void *, size_t *); -int dioopen(struct open_file *, ...); -int dioclose(struct open_file *); -#define dioioctl noioctl - -int netstrategy(void *, int, daddr_t, size_t, void *, size_t *); -int netopen(struct open_file *, ...); -int netclose(struct open_file *); -#define netioctl noioctl - -struct devsw devsw[] = { - { "scsi", diostrategy, dioopen, dioclose, dioioctl }, - { "bootp", netstrategy, netopen, netclose, netioctl } -}; - -int ndevs = (sizeof(devsw)/sizeof(devsw[0])); diff --git a/sys/arch/sgi/stand/boot/diskio.c b/sys/arch/sgi/stand/boot/diskio.c deleted file mode 100644 index 48104ca11ac..00000000000 --- a/sys/arch/sgi/stand/boot/diskio.c +++ /dev/null @@ -1,252 +0,0 @@ -/* $OpenBSD: diskio.c,v 1.14 2020/12/09 18:10:19 krw Exp $ */ - -/* - * Copyright (c) 2016 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2000 Opsycon AB (www.opsycon.se) - * Copyright (c) 2000 Rtmx, Inc (www.rtmx.com) - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed for Rtmx, Inc by - * Opsycon Open System Consulting AB, Sweden. - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - */ - -#include <sys/param.h> -#include <lib/libkern/libkern.h> -#include <stand.h> - -#include <sys/disklabel.h> -#include <mips64/arcbios.h> - -char *strstr(char *, const char *); /* strstr.c */ - -struct dio_softc { - int sc_fd; /* PROM file ID */ - int sc_part; /* Disk partition number. */ - struct disklabel sc_label; /* Disk label for this disk. */ -}; - -int -diostrategy(void *devdata, int rw, daddr_t bn, size_t reqcnt, void *addr, - size_t *cnt) -{ - struct dio_softc *sc = (struct dio_softc *)devdata; - struct partition *pp = &sc->sc_label.d_partitions[sc->sc_part]; - uint64_t blkoffset; - arc_quad_t offset; - long result; - - if (rw != F_READ) - return EOPNOTSUPP; - - blkoffset = - (DL_SECTOBLK(&sc->sc_label, DL_GETPOFFSET(pp)) + bn) * DEV_BSIZE; - offset.hi = blkoffset >> 32; - offset.lo = blkoffset; - - if (Bios_Seek(sc->sc_fd, &offset, 0) < 0 || - Bios_Read(sc->sc_fd, addr, reqcnt, &result) < 0) - return EIO; - - if (cnt != NULL) - *cnt = result; - return 0; -} - -int -dioopen(struct open_file *f, ...) -{ - char *ctlr; - int partition; - struct dio_softc *sc; - struct disklabel *lp; - struct sgilabel *sl; - long fd; - /* XXX getdisklabel() assumes DEV_BSIZE bytes available */ - char buf[DEV_BSIZE + LABELOFFSET]; - arc_quad_t offset; - daddr_t native_offset; - long result; - va_list ap; - char rawctlr[1 + MAXPATHLEN]; - char *partptr; - - va_start(ap, f); - ctlr = va_arg(ap, char *); - partition = va_arg(ap, int); - va_end(ap); - - if (partition >= MAXPARTITIONS) - return ENXIO; - - /* - * If booting from disk, `ctlr` is something like - * whatever()partition(0) - * or - * dksc(whatever,0) - * where 0 is the volume header #0 partition, which is the - * OpenBSD area, where the OpenBSD disklabel can be found. - * - * However, the OpenBSD `a' partition, where the kernel is to be - * found, may not start at the same offset. - * - * In order to be able to correctly load any file from the OpenBSD - * partitions, we need to access the volume header partition table - * and the OpenBSD label. - * - * Therefore, make sure we replace `partition(*)' with `partition(10)' - * before reaching ARCBios, in order to access the raw disk. - * - * We could use partition #8 and use the value of SystemPartition in - * the environment to avoid doing this, but this would prevent us - * from being able to boot from a different disk than the one - * pointed to by SystemPartition. - */ - - strlcpy(rawctlr, ctlr, sizeof rawctlr); - partptr = strstr(rawctlr, "partition("); - if (partptr != NULL) { - strlcpy(partptr, "partition(10)", - sizeof rawctlr - (partptr - rawctlr)); - } else { - if ((partptr = strstr(rawctlr, "dksc(")) != NULL) { - partptr = strstr(partptr, ",0)"); - if (partptr != NULL && partptr[3] == '\0') - strlcpy(partptr, ",10)", - sizeof rawctlr - (partptr - rawctlr)); - } - } - - sl = NULL; /* no volume header found yet */ - if (partptr != NULL) { - if (Bios_Open(rawctlr, 0, &fd) < 0) - return ENXIO; - - /* - * Read the volume header. - */ - offset.hi = offset.lo = 0; - if (Bios_Seek(fd, &offset, 0) < 0 || - Bios_Read(fd, buf, DEV_BSIZE, &result) < 0 || - result != DEV_BSIZE) - return EIO; - - sl = (struct sgilabel *)buf; - if (sl->magic != SGILABEL_MAGIC) { -#ifdef DEBUG - printf("Invalid volume header magic %x\n", sl->magic); -#endif - Bios_Close(fd); - sl = NULL; - } - } - - if (sl == NULL) { - if (Bios_Open(ctlr, 0, &fd) < 0) - return ENXIO; - } - - sc = alloc(sizeof(struct dio_softc)); - bzero(sc, sizeof(struct dio_softc)); - f->f_devdata = (void *)sc; - lp = &sc->sc_label; - - sc->sc_fd = fd; - sc->sc_part = partition; - - if (sl != NULL) { - native_offset = sl->partitions[0].first; - } else { - /* - * We could not read the volume header, or there isn't any. - * Stick to the device we were given, and assume the - * OpenBSD disklabel can be found at the beginning. - */ - native_offset = 0; - } - - /* - * Read the native OpenBSD label. - */ -#ifdef DEBUG - printf("OpenBSD label @%lld\n", native_offset + LABELSECTOR); -#endif - offset.hi = ((native_offset + LABELSECTOR) * DEV_BSIZE) >> 32; - offset.lo = (native_offset + LABELSECTOR) * DEV_BSIZE; - - if (Bios_Seek(fd, &offset, 0) < 0 || - Bios_Read(fd, buf, DEV_BSIZE, &result) < 0 || - result != DEV_BSIZE) - return EIO; - - if (getdisklabel(buf + LABELOFFSET, lp) == NULL) { -#ifdef DEBUG - printf("Found native disklabel, " - "partition %c starts at %lld\n", - 'a' + partition, - DL_GETPOFFSET(&lp->d_partitions[partition])); -#endif - } else { - /* - * Assume the OpenBSD partition spans the whole device. - */ - lp->d_secsize = DEV_BSIZE; - lp->d_secpercyl = 1; - lp->d_npartitions = MAXPARTITIONS; - DL_SETPOFFSET(&lp->d_partitions[partition], native_offset); - DL_SETPSIZE(&lp->d_partitions[partition], -1ULL); -#ifdef DEBUG - printf("No native disklabel found, " - "assuming partition %c starts at %lld\n", - 'a' + partition, native_offset); -#endif - } - - return 0; -} - -int -dioclose(struct open_file *f) -{ - Bios_Close(((struct dio_softc *)f->f_devdata)->sc_fd); - free(f->f_devdata, sizeof(struct dio_softc)); - f->f_devdata = NULL; - return (0); -} diff --git a/sys/arch/sgi/stand/boot/filesystem.c b/sys/arch/sgi/stand/boot/filesystem.c deleted file mode 100644 index a9ae8b301a9..00000000000 --- a/sys/arch/sgi/stand/boot/filesystem.c +++ /dev/null @@ -1,50 +0,0 @@ -/* $NetBSD: filesystem.c,v 1.2 1995/02/16 02:33:05 cgd Exp $ */ - -/* - * Copyright (c) 1993 Philip A. Nelson. - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Philip A. Nelson. - * 4. The name of Philip A. Nelson may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY PHILIP NELSON ``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 PHILIP NELSON 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. - * - * filesystem.c - */ - -#include <stand.h> -#include <ufs.h> -#include <ufs2.h> -#include "netfs.h" - -struct fs_ops file_system[] = { - { netfs_open, netfs_close, netfs_read, netfs_write, netfs_seek, - netfs_stat }, - { ufs_open, ufs_close, ufs_read, ufs_write, ufs_seek, - ufs_stat, ufs_readdir, ufs_fchmod }, - { ufs2_open, ufs2_close, ufs2_read, ufs2_write, ufs2_seek, - ufs2_stat, ufs2_readdir, ufs2_fchmod }, -}; - -int nfsys = sizeof(file_system)/sizeof(struct fs_ops); diff --git a/sys/arch/sgi/stand/boot/netfs.c b/sys/arch/sgi/stand/boot/netfs.c deleted file mode 100644 index 76bed9a4a6d..00000000000 --- a/sys/arch/sgi/stand/boot/netfs.c +++ /dev/null @@ -1,291 +0,0 @@ -/* $OpenBSD: netfs.c,v 1.3 2020/12/09 18:10:19 krw Exp $ */ - -/*- - * Copyright (c) 2001 Steve Murphree, Jr. - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by TooLs GmbH. - * 4. The name of TooLs GmbH may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``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 TOOLS GMBH 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. - */ - -/* - * TFTP file system. - */ - -#include <sys/param.h> -#include <lib/libkern/libkern.h> -#include <stand.h> - -#include <sys/stat.h> - -#include "netfs.h" - -/* - * In-core open file. - */ -struct tftp_file { - char filename[128]; - off_t f_seekp; /* seek pointer */ - char *f_buf; /* buffer for data block */ - off_t f_off; /* index into buffer for data block */ - daddr32_t f_buf_blkno; /* block number of data block */ - size_t f_buf_size; -}; - -#define TFTP_BLOCK_SHIFT 9 -#define TFTP_BLOCK_SIZE (1<<TFTP_BLOCK_SHIFT) /* 512 by tftp convention */ -#define TFTP_BLOCK_NO(x) ((x >> TFTP_BLOCK_SHIFT) + 1) -#define TFTP_BLOCK_OFF(x) (x % TFTP_BLOCK_SIZE) - -static int tftp_read_file(struct open_file *, char **, size_t *); - -/* - * Read a portion of a file into an internal buffer. Return - * the location in the buffer and the amount in the buffer. - */ - -char tftp_buf[TFTP_BLOCK_SIZE]; /* static */ -struct tftp_file tftp_ctrl; - -static int -tftp_read_file(f, buf_p, size_p) - struct open_file *f; - char **buf_p; /* out */ - size_t *size_p; /* out */ -{ - struct tftp_file *fp = (struct tftp_file *)f->f_fsdata; - long off; - daddr32_t file_block; - size_t block_size; - int i, rc; - - off = TFTP_BLOCK_OFF(fp->f_seekp); - file_block = TFTP_BLOCK_NO(fp->f_seekp); - block_size = TFTP_BLOCK_SIZE; - - if (file_block == fp->f_buf_blkno + 1) { - /* - * Normal, incremental block transfer. - */ - rc = (f->f_dev->dv_strategy)(f->f_devdata, F_READ, - file_block, block_size, fp->f_buf, &fp->f_buf_size); - if (rc) - return (rc); - if (!(file_block % 4)) /* twiddle every 4 blocks */ - twiddle(); - fp->f_buf_blkno = file_block; - } else if (file_block > fp->f_buf_blkno + 1) { - /* - * Read ahead to the requested block; If we need - * those we skipped, see below. - */ - for (i = (fp->f_buf_blkno + 1); i <= file_block; i++) { - rc = (f->f_dev->dv_strategy)(f->f_devdata, F_READ, - i, block_size, fp->f_buf, &fp->f_buf_size); - if (rc) - return (rc); - } - fp->f_buf_blkno = file_block; - } else if (file_block < fp->f_buf_blkno) { - /* - * Uh oh... We can't rewind. Reopen the file - * and start again. - */ - char filename[128]; - - strlcpy(filename, fp->filename, sizeof filename); - netfs_close(f); - netfs_open(filename, f); - - /* restore f_seekp reset by netfs_open() */ - fp->f_seekp = (file_block - 1) * TFTP_BLOCK_SIZE + off; - for (i = 1; i <= file_block; i++) { - rc = (f->f_dev->dv_strategy)(f->f_devdata, F_READ, - i, block_size, fp->f_buf, &fp->f_buf_size); - if (rc) - return (rc); - } - fp->f_buf_blkno = file_block; - } - - /* - * Return address of byte in buffer corresponding to - * offset, and size of remainder of buffer after that - * byte. - */ - *buf_p = fp->f_buf + off; - *size_p = fp->f_buf_size - off; - - /* - * But truncate buffer at end of file. - */ - if (fp->f_buf_size > block_size){ - twiddle(); - return(EIO); - } - - - return (0); -} - -/* - * Open a file. - */ -int -netfs_open(path, f) - char *path; - struct open_file *f; -{ - struct tftp_file *fp; - int rc = 0; -extern int netstrategy(void *, int, daddr_t, size_t, void *, size_t *); - - if (f->f_dev->dv_strategy != netstrategy) - return EINVAL; - - /* locate file system specific data structure and zero it.*/ - fp = &tftp_ctrl; - bzero(fp, sizeof(struct tftp_file)); - f->f_fsdata = (void *)fp; - fp->f_seekp = 0; - fp->f_buf = tftp_buf; - bzero(fp->f_buf, TFTP_BLOCK_SIZE); - fp->f_buf_size = 0; - - strlcpy(fp->filename, path, sizeof fp->filename); - - twiddle(); - rc = (f->f_dev->dv_open)(f, path); - return (rc); -} - -int -netfs_close(f) - struct open_file *f; -{ - struct tftp_file *fp = (struct tftp_file *)f->f_fsdata; - - fp->f_buf = NULL; - f->f_fsdata = NULL; - (f->f_dev->dv_close)(f); - return (0); -} - -/* - * Copy a portion of a file into kernel memory. - * Cross block boundaries when necessary. - */ -int -netfs_read(f, start, size, resid) - struct open_file *f; - void *start; - size_t size; - size_t *resid; /* out */ -{ - struct tftp_file *fp = (struct tftp_file *)f->f_fsdata; - size_t csize; - char *buf; - size_t buf_size; - int rc = 0; - char *addr = start; - - while (size != 0) { - rc = tftp_read_file(f, &buf, &buf_size); - if (rc) - break; - - csize = size; - if (csize > buf_size) - csize = buf_size; - - bcopy(buf, addr, csize); - - fp->f_seekp += csize; - addr += csize; - size -= csize; - } - if (resid) - *resid = size; - return (rc); -} - -/* - * Not implemented. - */ -int -netfs_write(f, start, size, resid) - struct open_file *f; - void *start; - size_t size; - size_t *resid; /* out */ -{ - - return (EROFS); -} - -/* - * We only see forward. We can't rewind. - */ -off_t -netfs_seek(f, offset, where) - struct open_file *f; - off_t offset; - int where; -{ - struct tftp_file *fp = (struct tftp_file *)f->f_fsdata; - - switch (where) { - case SEEK_SET: - fp->f_seekp = offset; - break; - case SEEK_CUR: - fp->f_seekp += offset; - break; - case SEEK_END: - errno = EIO; - return (-1); - break; - default: - return (-1); - } - return (fp->f_seekp); -} - -int -netfs_stat(f, sb) - struct open_file *f; - struct stat *sb; -{ - return EIO; -} - -#ifndef NO_READDIR -int -netfs_readdir (struct open_file *f, char *name) -{ - return EIO; -} -#endif - diff --git a/sys/arch/sgi/stand/boot/netfs.h b/sys/arch/sgi/stand/boot/netfs.h deleted file mode 100644 index f6e1c4b44da..00000000000 --- a/sys/arch/sgi/stand/boot/netfs.h +++ /dev/null @@ -1,43 +0,0 @@ -/* $OpenBSD: netfs.h,v 1.1 2012/03/19 17:38:31 miod Exp $ */ - -/*- - * Copyright (c) 2001 Steve Murphree, Jr. - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by TooLs GmbH. - * 4. The name of TooLs GmbH may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``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 TOOLS GMBH 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. - */ - -int netfs_open(char *path, struct open_file *f); -int netfs_close(struct open_file *f); -int netfs_read(struct open_file *f, void *buf, - size_t size, size_t *resid); -int netfs_write(struct open_file *f, void *buf, - size_t size, size_t *resid); -off_t netfs_seek(struct open_file *f, off_t offset, int where); -int netfs_stat(struct open_file *f, struct stat *sb); -#ifndef NO_READDIR -int netfs_readdir(struct open_file *f, char *name); -#endif diff --git a/sys/arch/sgi/stand/boot/netio.c b/sys/arch/sgi/stand/boot/netio.c deleted file mode 100644 index 2595e56566c..00000000000 --- a/sys/arch/sgi/stand/boot/netio.c +++ /dev/null @@ -1,88 +0,0 @@ -/* $OpenBSD: netio.c,v 1.3 2020/12/09 18:10:19 krw Exp $ */ - -/* - * Copyright (c) 2012 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - - -#include <sys/param.h> -#include <lib/libkern/libkern.h> -#include <stand.h> - -#include <mips64/arcbios.h> - -int -netstrategy(void *devdata, int rw, daddr_t bn, size_t reqcnt, void *addr, - size_t *cnt) -{ - long fd = (long)devdata; - long result; - int rc; - - if (rw != F_READ) - return EOPNOTSUPP; - - rc = Bios_Read(fd, addr, reqcnt, &result); - if (rc != 0) - return (EIO); - - if (cnt != NULL) - *cnt = result; - return 0; -} - -int -netopen(struct open_file *f, ...) -{ - char *path; - long fd; - int rc; - va_list ap; - - va_start(ap, f); - path = va_arg(ap, char *); - va_end(ap); - - /* to match netfs.c filename buffers... */ - if (strlen(path) > 128 - 1) - return ENAMETOOLONG; - - rc = Bios_Open(path, 0, &fd); - if (rc != 0) { - switch (rc) { - case arc_EACCES: - return EACCES; - case arc_EISDIR: - return EISDIR; - case arc_ENOENT: - return ENOENT; - default: - return ENXIO; - } - } - - f->f_devdata = (void *)fd; - - return 0; -} - -int -netclose(struct open_file *f) -{ - long fd = (long)f->f_devdata; - - (void)Bios_Close(fd); - return 0; -} diff --git a/sys/arch/sgi/stand/boot/start.S b/sys/arch/sgi/stand/boot/start.S deleted file mode 100644 index 31c64793f9f..00000000000 --- a/sys/arch/sgi/stand/boot/start.S +++ /dev/null @@ -1,55 +0,0 @@ -/* $OpenBSD: start.S,v 1.4 2012/09/29 21:40:48 miod Exp $ */ - -/* - * Copyright (c) 2001 Opsycon AB (www.opsycon.se) - * - * 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. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed under OpenBSD by - * Opsycon AB, Sweden (www.opsycon.com). - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. - * - */ - -#define ABICALLS - -#include <machine/regdef.h> -#include <machine/asm.h> - -/* - * Frame required for the debugger (if we have any). - */ -#define START_FRAME ((4 * 4) + 4 + 4) - - .globl __start -__start: -#ifndef __LP64__ /* LP64 code is compiled without gp support */ - LA gp, _gp -#endif - - jal boot_main - -1: - b 1b - diff --git a/sys/arch/sgi/stand/boot/strstr.c b/sys/arch/sgi/stand/boot/strstr.c deleted file mode 100644 index 95832a656b8..00000000000 --- a/sys/arch/sgi/stand/boot/strstr.c +++ /dev/null @@ -1,56 +0,0 @@ -/*- - * Copyright (c) 1990 The Regents of the University of California. - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * Chris Torek. - * - * 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. - * 3. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. - */ - -#include <sys/param.h> -#include <lib/libkern/libkern.h> - -/* - * Find the first occurrence of find in s. - */ -char * -strstr(char *s, const char *find) -{ - char c, sc; - size_t len; - - if ((c = *find++) != 0) { - len = strlen(find); - do { - do { - if ((sc = *s++) == 0) - return (NULL); - } while (sc != c); - } while (strncmp(s, find, len) != 0); - s--; - } - return s; -} diff --git a/sys/arch/sgi/stand/boot32/Makefile b/sys/arch/sgi/stand/boot32/Makefile deleted file mode 100644 index e319a1ed942..00000000000 --- a/sys/arch/sgi/stand/boot32/Makefile +++ /dev/null @@ -1,18 +0,0 @@ -# $OpenBSD: Makefile,v 1.3 2020/04/06 02:10:33 visa Exp $ - -.include "${.CURDIR}/../Makefile32.inc" -LDSCRIPT= ${.CURDIR}/ld.script -LDFLAGS+= ${SALDFLAGS} -T ${LDSCRIPT} -e __start -s -PROG= boot32 -.PATH: ${.CURDIR}/../boot -.include "${.CURDIR}/../boot/Makefile" - -SRCS+= ashrdi3.c divdi3.c moddi3.c udivdi3.c umoddi3.c qdivrem.c - -${PROG}: $(OBJS) $(LDADD) - $(LD) $(LDFLAGS) -o ${PROG} $(OBJS) -L${LIBSADIR} ${LIBSA} \ - -L${LIBZDIR} ${LIBZ} - -LINKS= ${BINDIR}/${PROG} ${BINDIR}/boot-IP32 - -.include <bsd.prog.mk> diff --git a/sys/arch/sgi/stand/boot32/ld.script b/sys/arch/sgi/stand/boot32/ld.script deleted file mode 100644 index 5ca7826d883..00000000000 --- a/sys/arch/sgi/stand/boot32/ld.script +++ /dev/null @@ -1,75 +0,0 @@ -OUTPUT_FORMAT("elf32-tradbigmips", "elf32-tradbigmips", - "elf32-tradlittlemips") -OUTPUT_ARCH(mips) -ENTRY(_start) -SECTIONS -{ - /* Read-only sections, merged into text segment: */ - . = 0x80010000 + SIZEOF_HEADERS; - .text : - { - _ftext = . ; - *(.text) - *(.rodata) - *(.rodata1) - *(.rodata.str1.4) - *(.reginfo) - *(.init) - *(.stub) - /* .gnu.warning sections are handled specially by elf32.em. */ - *(.gnu.warning) - } =0 - _etext = .; - PROVIDE (etext = .); - .fini : { *(.fini) } =0 - .data : - { - _fdata = . ; - *(.data) - CONSTRUCTORS - } - .data1 : { *(.data1) } - .ctors : { *(.ctors) } - .dtors : { *(.dtors) } - _gp = ALIGN(16) + 0x7ff0; - .got : - { - *(.got.plt) *(.got) - } - /* We want the small data sections together, so single-instruction offsets - can access them all, and initialized data all before uninitialized, so - we can shorten the on-disk segment size. */ - .sdata : { *(.sdata) } - .lit8 : { *(.lit8) } - .lit4 : { *(.lit4) } - _edata = .; - PROVIDE (edata = .); - __bss_start = .; - _fbss = .; - .sbss : { *(.sbss) *(.scommon) } - .bss : - { - *(.dynbss) - *(.bss) - *(COMMON) - } - _end = . ; - PROVIDE (end = .); - /* These are needed for ELF backends which have not yet been - converted to the new style linker. */ - .stab 0 : { *(.stab) } - .stabstr 0 : { *(.stabstr) } - /* DWARF debug sections. - Symbols in the .debug DWARF section are relative to the beginning of the - section so we begin .debug at 0. It's not clear yet what needs to happen - for the others. */ - .debug 0 : { *(.debug) } - .debug_srcinfo 0 : { *(.debug_srcinfo) } - .debug_aranges 0 : { *(.debug_aranges) } - .debug_pubnames 0 : { *(.debug_pubnames) } - .debug_sfnames 0 : { *(.debug_sfnames) } - .line 0 : { *(.line) } - /* These must appear regardless of . */ - .gptab.sdata : { *(.gptab.data) *(.gptab.sdata) } - .gptab.sbss : { *(.gptab.bss) *(.gptab.sbss) } -} diff --git a/sys/arch/sgi/stand/boot64/Makefile b/sys/arch/sgi/stand/boot64/Makefile deleted file mode 100644 index b25ac6ef318..00000000000 --- a/sys/arch/sgi/stand/boot64/Makefile +++ /dev/null @@ -1,26 +0,0 @@ -# $OpenBSD: Makefile,v 1.4 2015/09/27 19:11:37 miod Exp $ - -LDFLAGS+= ${SALDFLAGS} --oformat=elf64-tradbigmips -e __start -STRIP= strip -INSTALL_STRIP= - -PROG= boot64 -.PATH: ${.CURDIR}/../boot -.include "${.CURDIR}/../boot/Makefile" - -${PROG}: $(OBJS) $(LDADD) - @# Link first as self-contained binary to enforce there are no - @# unresolved symbols - $(LD) $(LDFLAGS) -o ${PROG} $(OBJS) -L${LIBSADIR} ${LIBSA} \ - -L${LIBZDIR} ${LIBZ} - @# then link as a relocatable binary - $(LD) $(LDFLAGS) -r -o ${PROG} $(OBJS) -L${LIBSADIR} ${LIBSA} \ - -L${LIBZDIR} ${LIBZ} - $(STRIP) --strip-unneeded ${PROG} - -LINKS= ${BINDIR}/${PROG} ${BINDIR}/boot-IP26 -LINKS+= ${BINDIR}/${PROG} ${BINDIR}/boot-IP27 -LINKS+= ${BINDIR}/${PROG} ${BINDIR}/boot-IP28 -LINKS+= ${BINDIR}/${PROG} ${BINDIR}/boot-IP30 - -.include <bsd.prog.mk> diff --git a/sys/arch/sgi/stand/bootecoff/Makefile b/sys/arch/sgi/stand/bootecoff/Makefile deleted file mode 100644 index ff2505cbed2..00000000000 --- a/sys/arch/sgi/stand/bootecoff/Makefile +++ /dev/null @@ -1,19 +0,0 @@ -# $OpenBSD: Makefile,v 1.2 2020/04/06 16:23:44 visa Exp $ - -.include "${.CURDIR}/../Makefile32.inc" -STRIP?= strip -LDSCRIPT= ${.CURDIR}/ld.script -LDFLAGS+= ${SALDFLAGS} -T ${LDSCRIPT} -e __start -N -s -PROG= bootecoff -.PATH: ${.CURDIR}/../boot -.include "${.CURDIR}/../boot/Makefile" - -SRCS+= ashrdi3.c divdi3.c moddi3.c udivdi3.c umoddi3.c qdivrem.c - -${PROG}: $(OBJS) $(LDADD) - $(LD) $(LDFLAGS) -o ${PROG} $(OBJS) -L${LIBSADIR} ${LIBSA} \ - -L${LIBZDIR} ${LIBZ} - -LINKS= ${BINDIR}/${PROG} ${BINDIR}/boot-IP22 - -.include <bsd.prog.mk> diff --git a/sys/arch/sgi/stand/bootecoff/ld.script b/sys/arch/sgi/stand/bootecoff/ld.script deleted file mode 100644 index deee3ac2bf1..00000000000 --- a/sys/arch/sgi/stand/bootecoff/ld.script +++ /dev/null @@ -1,71 +0,0 @@ -OUTPUT_FORMAT("ecoff-bigmips", "ecoff-bigmips", - "ecoff-littlemips") -OUTPUT_ARCH(mips) -ENTRY(_start) -SECTIONS -{ - /* Read-only sections, merged into text segment: */ - . = 0x88002000 + SIZEOF_HEADERS; - .text : - { - _ftext = . ; - *(.text) - *(.rodata) - *(.rodata1) - *(.rodata.str1.4) - *(.reginfo) - *(.init) - *(.stub) - /* .gnu.warning sections are handled specially by elf32.em. */ - *(.gnu.warning) - } =0 - _etext = .; - PROVIDE (etext = .); - .fini : { *(.fini) } =0 - .data : - { - _fdata = . ; - *(.data) - CONSTRUCTORS - } - .data1 : { *(.data1) } - .ctors : { *(.ctors) } - .dtors : { *(.dtors) } - _gp = ALIGN(16) + 0x7ff0; - .got : - { - *(.got.plt) *(.got) - } - /* We want the small data sections together, so single-instruction offsets - can access them all, and initialized data all before uninitialized, so - we can shorten the on-disk segment size. */ - .sdata : { *(.sdata) } - .lit8 : { *(.lit8) } - .lit4 : { *(.lit4) } - _edata = .; - PROVIDE (edata = .); - __bss_start = .; - _fbss = .; - .sbss : { *(.sbss) *(.scommon) } - .bss : - { - *(.dynbss) - *(.bss) - *(COMMON) - } - _end = . ; - PROVIDE (end = .); - /DISCARD/ : { - *(.pdr) - *(.mdebug.abi32) - *(.comment) - *(.stab) - *(.stabstr) - *(.debug) - *(.debug_srcinfo) - *(.debug_aranges) - *(.debug_pubnames) - *(.debug_sfnames) - *(.line) - } -} diff --git a/sys/arch/sgi/stand/libsa/Makefile b/sys/arch/sgi/stand/libsa/Makefile deleted file mode 100644 index 6eccda49388..00000000000 --- a/sys/arch/sgi/stand/libsa/Makefile +++ /dev/null @@ -1,44 +0,0 @@ -# $OpenBSD: Makefile,v 1.14 2020/05/25 16:27:05 deraadt Exp $ - -LIB= sa - -.PATH: ${.CURDIR}/../../../../lib/libsa - -CLEANFILES += machine mips64 - -CFLAGS+= ${CEXTRAFLAGS} ${SAABI} -nostdinc -mno-abicalls -D_NO_ABICALLS \ - -fno-pie \ - -I${.CURDIR} -I${.CURDIR}/../include -I${.CURDIR}/../.. \ - -I${.CURDIR}/../../.. -I${.CURDIR}/../../../.. \ - -I${.CURDIR}/../../../../lib/libsa \ - -I${.OBJDIR} - -CPPFLAGS+= -D__INTERNAL_LIBSA_CREAD ${STANDALONE} -CPPFLAGS+= ${LIBSA_CPPFLAGS} - -# stand routines -SRCS= alloc.c exit.c getfile.c getln.c globals.c \ - memcmp.c memcpy.c memmove.c memset.c printf.c snprintf.c strerror.c strncpy.c - -# io routines -SRCS+= close.c closeall.c dev.c disklabel.c dkcksum.c fchmod.c \ - fstat.c fchmod.c ioctl.c lseek.c open.c read.c stat.c write.c cread.c - -# boot filesystems -SRCS+= ufs.c ufs2.c nfs.c cd9660.c - -${OBJS}: ${.CURDIR}/../Makefile.inc - -NOPROFILE= -NOPIC= - -.if !make(clean) && !make(cleandir) && !make(includes) && !make(libdep) && \ - !make(sadep) && !make(salibdir) && !make(obj) -.BEGIN: - @([ -h machine ] || ln -s ${.CURDIR}/../../include machine) - @([ -h mips64 ] || ln -s ${.CURDIR}/../../../mips64/include mips64) -.endif - -install: - -.include <bsd.lib.mk> diff --git a/sys/arch/sgi/stand/libsa/heap.h b/sys/arch/sgi/stand/libsa/heap.h deleted file mode 100644 index da42d8b5e22..00000000000 --- a/sys/arch/sgi/stand/libsa/heap.h +++ /dev/null @@ -1,35 +0,0 @@ -/* $OpenBSD: heap.h,v 1.1 2009/05/14 18:57:43 miod Exp $ */ -/* public domain */ - -/* - * Declarations for the libsa heap allocator. - * - * Relocatable 64 bit bootblocks use memory below the load address and - * can not use the `end' symbol. - */ - -#ifdef __LP64__ -#define NEEDS_HEAP_INIT - -#define HEAP_LIMIT heap_limit -#define HEAP_SIZE (1UL << 20) /* 1MB */ -#define HEAP_START heap_start - -static unsigned long heap_start; -static unsigned long heap_limit; -static char *top; /* no longer declared in alloc.c */ - -static inline void heap_init(void); -static inline void -heap_init() -{ - extern char __start[]; - - if (top == NULL) { - heap_limit = (unsigned long)&__start; - heap_start = heap_limit - HEAP_SIZE; - top = (char *)heap_start; - } -} - -#endif diff --git a/sys/arch/sgi/stand/libsa32/Makefile b/sys/arch/sgi/stand/libsa32/Makefile deleted file mode 100644 index c22a59bb067..00000000000 --- a/sys/arch/sgi/stand/libsa32/Makefile +++ /dev/null @@ -1,4 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2009/05/14 18:57:43 miod Exp $ - -.include "${.CURDIR}/../Makefile32.inc" -.include "${.CURDIR}/../libsa/Makefile" diff --git a/sys/arch/sgi/stand/libz/Makefile b/sys/arch/sgi/stand/libz/Makefile deleted file mode 100644 index c6911a3fadc..00000000000 --- a/sys/arch/sgi/stand/libz/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -# $OpenBSD: Makefile,v 1.5 2012/08/31 08:14:08 pascal Exp $ - -S=${.CURDIR}/../../../.. -ZDST=${.OBJDIR} - -.PATH: ${S}/lib/libz - -.include "${S}/lib/libz/Makefile" -CFLAGS+= ${CEXTRAFLAGS} ${SAABI} -mno-abicalls -D_NO_ABICALLS \ - ${AFLAGS} -fno-pie -I${S} diff --git a/sys/arch/sgi/stand/libz32/Makefile b/sys/arch/sgi/stand/libz32/Makefile deleted file mode 100644 index d217799d624..00000000000 --- a/sys/arch/sgi/stand/libz32/Makefile +++ /dev/null @@ -1,4 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2009/05/14 18:57:43 miod Exp $ - -.include "${.CURDIR}/../Makefile32.inc" -.include "${.CURDIR}/../libz/Makefile" diff --git a/sys/arch/sgi/stand/sgivol/Makefile b/sys/arch/sgi/stand/sgivol/Makefile deleted file mode 100644 index e6fc37cdbf3..00000000000 --- a/sys/arch/sgi/stand/sgivol/Makefile +++ /dev/null @@ -1,16 +0,0 @@ -# $OpenBSD: Makefile,v 1.3 2005/04/27 18:02:16 deraadt Exp $ -# $NetBSD: Makefile,v 1.5 2002/12/13 02:36:37 lukem Exp $ - -MAN= sgivol.8 -MANSUBDIR=sgi - -.if ${MACHINE} == "sgi" -PROG= sgivol -LDADD+= -lutil -LDSTATIC=-static - -.else -NOPROG= -.endif - -.include <bsd.prog.mk> diff --git a/sys/arch/sgi/stand/sgivol/sgivol.8 b/sys/arch/sgi/stand/sgivol/sgivol.8 deleted file mode 100644 index 877c0704646..00000000000 --- a/sys/arch/sgi/stand/sgivol/sgivol.8 +++ /dev/null @@ -1,127 +0,0 @@ -.\" $OpenBSD: sgivol.8,v 1.7 2020/04/23 21:28:10 jmc Exp $ -.\" -.\" Copyright (c) 2005 Theo de Raadt -.\" 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 ``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 REGENTS 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. -.\" -.\" -.Dd $Mdocdate: April 23 2020 $ -.Dt SGIVOL 8 sgi -.Os -.Sh NAME -.Nm sgivol -.Nd initialise and manipulate SGI disk volume headers -.Sh SYNOPSIS -.Nm sgivol -.Op Fl q -.Ar disk -.Nm sgivol -.Op Fl q -.Fl d Ar vhfilename -.Ar disk -.Nm sgivol -.Op Fl q -.Fl i -.Op Fl h Ar vhsize -.Ar disk -.Nm sgivol -.Op Fl q -.Fl l Ar vhfilename1 Ar vhfilename2 -.Ar disk -.Nm sgivol -.Op Fl q -.Fl r Ar vhfilename diskfilename -.Ar disk -.Nm sgivol -.Op Fl q -.Fl w Ar vhfilename diskfilename -.Ar disk -.Sh DESCRIPTION -.Nm -is used to initialise and manipulate SGI disk volume headers. -.Pp -The SGI volume header is a disklabel-like structure located at the -start of a disk. -It is typically 3135 (512-byte) blocks in size, and can store a -variety of files inside it, typically boot programs. -.Pp -The options are as follows: -.Bl -tag -width flag_opt -.It Fl d Ar vhfilename -Delete the file -.Ar vhfilename -from the filesystem storage space in the volume header. -.It Fl h Ar vhsize -Choose an alternate volume header size, in (512-byte) disk blocks. -The default is 3135 blocks. -.It Fl i -Initialise a volume header on the supplied device. -.It Fl l Ar vhfilename1 Ar vhfilename2 -Link the file -.Ar vhfilename1 -to the file -.Ar vhfilename2 -within the filesystem storage space in the volume header. -.It Fl q -Be quiet about various diagnostic issues. -.It Fl r Ar vhfilename diskfilename -Locate the file -.Ar vhfilename -in the storage space of the volume header, and copy it to the -standard file -.Ar diskfilename . -.It Fl w Ar vhfilename diskfilename -Copy the standard file -.Ar diskfilename -to the filesystem storage space in the volume header, placing -it there with the name -.Ar vhfilename . -.It Ar disk -The name of the disk containing the partition in which the second-stage -boot program resides and the first-stage boot program is to be installed. -This can either be specified in short form (e.g., -.Sq sd0 -or as the explicit device node, such as -.Pa /dev/rsd0c ) . -.Pp -Note that you must be in single-user mode or have your kernel in -insecure mode (see the -.Xr sysctl 8 -.Va kern.securelevel -variable or -.Pa /etc/rc.securelevel ) -to enable access to the raw partition of a mounted disk. -.El -.Pp -If no special flags are supplied, -.Nm -will display the current volume header information. -.Sh EXAMPLES -The typical use is -.Bd -literal -offset indent -# /usr/mdec/sgivol -i sd0 -# /usr/mdec/sgivol -w boot /usr/mdec/boot sd0 -.Ed -.Sh SEE ALSO -.Xr disklabel 8 , -.Xr init 8 diff --git a/sys/arch/sgi/stand/sgivol/sgivol.c b/sys/arch/sgi/stand/sgivol/sgivol.c deleted file mode 100644 index 1066bf00eab..00000000000 --- a/sys/arch/sgi/stand/sgivol/sgivol.c +++ /dev/null @@ -1,607 +0,0 @@ -/* $OpenBSD: sgivol.c,v 1.24 2017/09/08 05:36:52 deraadt Exp $ */ -/* $NetBSD: sgivol.c,v 1.8 2003/11/08 04:59:00 sekiya Exp $ */ - -/*- - * Copyright (c) 2001 The NetBSD Foundation, Inc. - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Michael Hitch and Hubert Feyrer. - * - * 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. - */ - -#include <unistd.h> -#include <err.h> -#include <errno.h> -#include <fcntl.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <util.h> - -#include <sys/disklabel.h> -#include <sys/endian.h> -#include <sys/ioctl.h> -#include <sys/param.h> -#include <sys/stat.h> -#include <sys/dkio.h> - -/* - * Some IRIX man pages refer to the size being a multiple of whole cylinders. - * Later ones only refer to the size being "typically" 2MB. IRIX fx(1) - * uses a default drive geometry if one can't be determined, suggesting - * that "whole cylinder" multiples are not required. - */ - -#define SGI_SIZE_VOLHDR 3135 /* Can be overridden via -h parameter. */ - -/* - * Mode of operation can be one of: - * -i Initialise volume header. - * -r Read a file from volume header. - * -w Write a file to volume header. - * -l Link a file into the volume header. - * -d Delete a file from the volume header. - * -p Modify a partition. - */ - -char mode; -int quiet; -int fd; -int partno, partfirst, partblocks, parttype; -struct sgilabel *volhdr; -int32_t checksum; - -/* Volume header size in sectors. */ -u_int32_t volhdr_size = SGI_SIZE_VOLHDR; - -const char *vfilename = ""; -const char *ufilename = ""; - -struct disklabel lbl; - -unsigned char *buf; -unsigned int bufsize; - -const char *sgi_types[] = { - "Volume Header", - "Repl Trks", - "Repl Secs", - "Raw", - "BSD4.2", - "SysV", - "Volume", - "EFS", - "LVol", - "RLVol", - "XFS", - "XSFLog", - "XLV", - "XVM" -}; - -void display_vol(void); -void init_volhdr(void); -void read_file(void); -void write_file(void); -void link_file(void); -void delete_file(void); -void modify_partition(void); -void write_volhdr(void); -int allocate_space(int); -void checksum_vol(void); -void usage(void); - -int -main(int argc, char *argv[]) -{ - int ch, oflags; - char fname[FILENAME_MAX]; - char *endp; - - quiet = 0; - mode = ' '; - - while ((ch = getopt(argc, argv, "irwlpdqfh:")) != -1) { - switch (ch) { - case 'q': - quiet = 1; - break; - case 'f': - /* Legacy. Do nothing. */ - break; - case 'i': - mode = 'i'; - break; - case 'h': - volhdr_size = strtol(optarg, &endp, 0); - if (*endp != '\0' || errno != 0) - errx(1, "incorrect volume header size: %s", - optarg); - break; - case 'r': - mode = 'r'; - break; - case 'w': - mode = 'w'; - break; - case 'l': - mode = 'l'; - break; - case 'd': - mode = 'd'; - break; - case 'p': - mode = 'p'; - break; - default: - usage(); - } - } - argc -= optind; - argv += optind; - - if (mode == 'r' || mode == 'w' || mode == 'l') { - if (argc != 3) - usage(); - vfilename = argv[0]; - ufilename = argv[1]; - argc -= 2; - argv += 2; - } else if (mode == 'd') { - if (argc != 2) - usage(); - vfilename = argv[0]; - argc--; - argv++; - } else if (mode == 'p') { - if (argc != 5) - usage(); - partno = strtol(argv[0], &endp, 0); - if (*endp != '\0' || errno != 0 || - partno < 0 || partno > SGI_SIZE_VOLDIR) - errx(1, "invalid partition number: %s", argv[0]); - partfirst = strtol(argv[1], &endp, 0); - if (*endp != '\0' || errno != 0) - errx(1, "invalid partition start: %s", argv[1]); - partblocks = strtol(argv[2], &endp, 0); - if (*endp != '\0' || errno != 0) - errx(1, "invalid partition size: %s", argv[2]); - parttype = strtol(argv[3], &endp, 0); - if (*endp != '\0' || errno != 0) - errx(1, "invalid partition type: %s", argv[3]); - argc -= 4; - argv += 4; - } - if (argc != 1) - usage(); - - oflags = ((mode == 'i' || mode == 'w' || mode == 'l' || mode == 'd' - || mode == 'p') ? O_RDWR : O_RDONLY); - - /* Open raw device. */ - if ((fd = open(argv[0], oflags)) < 0) { - snprintf(fname, sizeof(fname), "/dev/r%s%c", - argv[0], 'a' + getrawpartition()); - if ((fd = open(fname, oflags)) < 0) - err(1, "open %s", fname); - } - - /* Get disklabel for device. */ - if (ioctl(fd, DIOCGDINFO, &lbl) == -1) - err(1, "ioctl DIOCGDINFO"); - - /* Allocate a buffer that matches the device sector size. */ - bufsize = lbl.d_secsize; - if (bufsize < sizeof(struct sgilabel)) - errx(1, "sector size is smaller than SGI volume header!\n"); - if ((buf = malloc(bufsize)) == NULL) - err(1, "failed to allocate buffer"); - - /* Read SGI volume header. */ - if (read(fd, buf, bufsize) != bufsize) - err(1, "read volhdr"); - volhdr = (struct sgilabel *)buf; - - if (mode == 'i') { - init_volhdr(); - exit(0); - } - - if (betoh32(volhdr->magic) != SGILABEL_MAGIC) - errx(2, "no Volume Header found, magic=%x. Use -i first.", - betoh32(volhdr->magic)); - - if (mode == 'r') - read_file(); - else if (mode == 'w') - write_file(); - else if (mode == 'l') - link_file(); - else if (mode == 'd') - delete_file(); - else if (mode == 'p') - modify_partition(); - else if (!quiet) - display_vol(); - - exit (0); -} - -void -display_vol(void) -{ - int32_t *l; - int i; - - l = (int32_t *)buf; - checksum = 0; - for (i = 0; i < sizeof(struct sgilabel) / sizeof(int32_t); ++i) - checksum += betoh32(l[i]); - - printf("disklabel shows %llu sectors with %u bytes per sector\n", - DL_GETDSIZE(&lbl), lbl.d_secsize); - printf("checksum: %08x%s\n", checksum, checksum == 0 ? "" : " *ERROR*"); - printf("root part: %d\n", betoh32(volhdr->root)); - printf("swap part: %d\n", betoh32(volhdr->swap)); - printf("bootfile: %s\n", volhdr->bootfile); - - /* volhdr->devparams[0..47] */ - printf("\nVolume header files:\n"); - for (i = 0; i < SGI_SIZE_VOLDIR; ++i) { - if (volhdr->voldir[i].name[0] != '\0') { - printf("%-8s offset %4d blocks, " - "length %8d bytes (%d blocks)\n", - volhdr->voldir[i].name, - betoh32(volhdr->voldir[i].block), - betoh32(volhdr->voldir[i].bytes), - howmany(betoh32(volhdr->voldir[i].bytes), - DEV_BSIZE)); - } - } - - printf("\nSGI partitions:\n"); - for (i = 0; i < MAXPARTITIONS; ++i) { - if (betoh32(volhdr->partitions[i].blocks) != 0) { - printf("%2d:%c blocks %8d first %8d type %2d (%s)\n", - i, i + 'a', betoh32(volhdr->partitions[i].blocks), - betoh32(volhdr->partitions[i].first), - betoh32(volhdr->partitions[i].type), - betoh32(volhdr->partitions[i].type) > - (sizeof(sgi_types) / sizeof(sgi_types[0])) ? - "???" : - sgi_types[betoh32(volhdr->partitions[i].type)]); - } - } -} - -void -init_volhdr(void) -{ - memset(volhdr, 0, sizeof(struct sgilabel)); - volhdr->magic = htobe32(SGILABEL_MAGIC); - volhdr->root = htobe16(0); - volhdr->swap = htobe16(1); - strlcpy(volhdr->bootfile, "/bsd", sizeof(volhdr->bootfile)); - volhdr->dp.dp_skew = 1; /* XXX */ - volhdr->dp.dp_gap1 = 1; /* XXX */ - volhdr->dp.dp_gap2 = 1; /* XXX */ - volhdr->dp.dp_cyls = htobe16(lbl.d_ncylinders); - volhdr->dp.dp_shd0 = 0; - volhdr->dp.dp_trks0 = htobe16(lbl.d_ntracks); - volhdr->dp.dp_secs = htobe16(lbl.d_nsectors); - volhdr->dp.dp_secbytes = htobe16(lbl.d_secsize); - volhdr->dp.dp_interleave = 1; - volhdr->dp.dp_nretries = htobe32(22); - volhdr->partitions[10].blocks = - htobe32(DL_SECTOBLK(&lbl, DL_GETDSIZE(&lbl))); - volhdr->partitions[10].first = 0; - volhdr->partitions[10].type = htobe32(SGI_PTYPE_VOLUME); - volhdr->partitions[8].blocks = htobe32(DL_SECTOBLK(&lbl, volhdr_size)); - volhdr->partitions[8].first = 0; - volhdr->partitions[8].type = htobe32(SGI_PTYPE_VOLHDR); - volhdr->partitions[0].blocks = - htobe32(DL_SECTOBLK(&lbl, DL_GETDSIZE(&lbl) - volhdr_size)); - volhdr->partitions[0].first = htobe32(DL_SECTOBLK(&lbl, volhdr_size)); - volhdr->partitions[0].type = htobe32(SGI_PTYPE_BSD); - write_volhdr(); -} - -void -read_file(void) -{ - FILE *fp; - int i; - - if (!quiet) - printf("Reading file %s\n", vfilename); - for (i = 0; i < SGI_SIZE_VOLDIR; ++i) { - if (strncmp(vfilename, volhdr->voldir[i].name, - strlen(volhdr->voldir[i].name)) == 0) - break; - } - if (i >= SGI_SIZE_VOLDIR) - errx(1, "%s: file not found", vfilename); - /* XXX assumes volume header starts at 0? */ - lseek(fd, betoh32(volhdr->voldir[i].block) * DEV_BSIZE, SEEK_SET); - if ((fp = fopen(ufilename, "w")) == NULL) - err(1, "open %s", ufilename); - i = betoh32(volhdr->voldir[i].bytes); - while (i > 0) { - if (read(fd, buf, bufsize) != bufsize) - err(1, "read file"); - fwrite(buf, 1, i > bufsize ? bufsize : i, fp); - i -= i > bufsize ? bufsize : i; - } - fclose(fp); -} - -void -write_file(void) -{ - FILE *fp; - int slot; - int block, i, fsize, fbufsize; - struct stat st; - char *fbuf; - - if (!quiet) - printf("Writing file %s\n", ufilename); - - if (stat(ufilename, &st) != 0) - err(1, "stat %s", ufilename); - if (st.st_size == 0) - errx(1, "%s: file is empty", vfilename); - - if (!quiet) - printf("File %s has %lld bytes\n", ufilename, st.st_size); - slot = -1; - for (i = 0; i < SGI_SIZE_VOLDIR; ++i) { - if (volhdr->voldir[i].name[0] == '\0' && slot < 0) - slot = i; - if (strcmp(vfilename, volhdr->voldir[i].name) == 0) { - slot = i; - break; - } - } - if (slot == -1) - errx(1, "no more directory entries available"); - if (betoh32(volhdr->voldir[slot].block) > 0) { - if (!quiet) - printf("File %s exists, removing old file\n", - vfilename); - volhdr->voldir[slot].name[0] = 0; - volhdr->voldir[slot].block = volhdr->voldir[slot].bytes = 0; - } - /* XXX assumes volume header starts at 0? */ - block = allocate_space((int)st.st_size); - if (block < 0) - errx(1, "no more space available"); - - /* - * Make sure the name in the volume header is max. 8 chars, - * NOT including NUL. - */ - if (strlen(vfilename) > sizeof(volhdr->voldir[slot].name)) - warnx("%s: filename is too long and will be truncated", - vfilename); - strncpy(volhdr->voldir[slot].name, vfilename, - sizeof(volhdr->voldir[slot].name)); - - volhdr->voldir[slot].block = htobe32(block); - volhdr->voldir[slot].bytes = htobe32(st.st_size); - - write_volhdr(); - - /* Write the file itself. */ - if (lseek(fd, block * DEV_BSIZE, SEEK_SET) == -1) - err(1, "lseek write"); - fbufsize = volhdr->dp.dp_secbytes; - if ((fbuf = malloc(fbufsize)) == NULL) - err(1, "failed to allocate buffer"); - i = st.st_size; - fp = fopen(ufilename, "r"); - while (i > 0) { - bzero(fbuf, fbufsize); - fsize = i > fbufsize ? fbufsize : i; - if (fread(fbuf, 1, fsize, fp) != fsize) - err(1, "reading file from disk"); - if (write(fd, fbuf, fbufsize) != fbufsize) - err(1, "writing file to SGI volume header"); - i -= fsize; - } - fclose(fp); - free(fbuf); -} - -void -link_file(void) -{ - int slot, i; - int32_t block, bytes; - - if (!quiet) - printf("Linking file %s to %s\n", vfilename, ufilename); - for (i = 0; i < SGI_SIZE_VOLDIR; ++i) { - if (strncmp(vfilename, volhdr->voldir[i].name, - strlen(volhdr->voldir[i].name)) == 0) - break; - } - if (i >= SGI_SIZE_VOLDIR) - errx(1, "%s: file not found", vfilename); - - block = volhdr->voldir[i].block; - bytes = volhdr->voldir[i].bytes; - - slot = -1; - for (i = 0; i < SGI_SIZE_VOLDIR; ++i) { - if (volhdr->voldir[i].name[0] == '\0' && slot < 0) - slot = i; - if (strcmp(ufilename, volhdr->voldir[i].name) == 0) { - slot = i; - break; - } - } - if (slot == -1) - errx(1, "no more directory entries available"); - - /* - * Make sure the name in the volume header is max. 8 chars, - * NOT including NUL. - */ - if (strlen(ufilename) > sizeof(volhdr->voldir[slot].name)) - warnx("%s: filename is too long and will be truncated", - ufilename); - strncpy(volhdr->voldir[slot].name, ufilename, - sizeof(volhdr->voldir[slot].name)); - - volhdr->voldir[slot].block = block; - volhdr->voldir[slot].bytes = bytes; - write_volhdr(); -} - -void -delete_file(void) -{ - int i; - - for (i = 0; i < SGI_SIZE_VOLDIR; ++i) { - if (strcmp(vfilename, volhdr->voldir[i].name) == 0) { - break; - } - } - if (i >= SGI_SIZE_VOLDIR) - errx(1, "%s: file not found", vfilename); - - /* XXX: we don't compact the file space, so get fragmentation */ - volhdr->voldir[i].name[0] = '\0'; - volhdr->voldir[i].block = volhdr->voldir[i].bytes = 0; - write_volhdr(); -} - -void -modify_partition(void) -{ - if (!quiet) - printf("Modify partition %d start %d length %d\n", - partno, partfirst, partblocks); - volhdr->partitions[partno].blocks = htobe32(partblocks); - volhdr->partitions[partno].first = htobe32(partfirst); - volhdr->partitions[partno].type = htobe32(parttype); - write_volhdr(); -} - -void -write_volhdr(void) -{ - checksum_vol(); - - if (!quiet) - display_vol(); - if (lseek(fd, 0, SEEK_SET) == -1) - err(1, "lseek 0"); - if (write(fd, buf, bufsize) != bufsize) - err(1, "write volhdr"); -} - -int -allocate_space(int size) -{ - int n, blocks; - int first; - - blocks = howmany(size, DEV_BSIZE); - first = roundup(2 * DEV_BSIZE, volhdr->dp.dp_secbytes) / DEV_BSIZE; - - for (n = 0; n < SGI_SIZE_VOLDIR;) { - if (volhdr->voldir[n].name[0]) { - if (first < (betoh32(volhdr->voldir[n].block) + - howmany(betoh32(volhdr->voldir[n].bytes), - DEV_BSIZE)) && - (first + blocks) > - betoh32(volhdr->voldir[n].block)) { - - first = roundup( - betoh32(volhdr->voldir[n].block) + - howmany(betoh32(volhdr->voldir[n].bytes), - DEV_BSIZE), - volhdr->dp.dp_secbytes / DEV_BSIZE); -#if DEBUG - printf("allocate: " - "n=%d first=%d blocks=%d size=%d\n", - n, first, blocks, size); - printf("%s %d %d\n", volhdr->voldir[n].name, - volhdr->voldir[n].block, - volhdr->voldir[n].bytes); - printf("first=%d block=%d last=%d end=%d\n", - first, volhdr->voldir[n].block, - first + blocks - 1, - volhdr->voldir[n].block + - howmany(volhdr->voldir[n].bytes, - DEV_BSIZE)); -#endif - n = 0; - continue; - } - } - ++n; - } - if (first + blocks > DL_GETDSIZE(&lbl)) - first = -1; - /* XXX assumes volume header is partition 8 */ - /* XXX assumes volume header starts at 0? */ - if (first + blocks >= betoh32(volhdr->partitions[8].blocks)) - first = -1; - return (first); -} - -void -checksum_vol(void) -{ - int32_t *l; - int i; - - volhdr->checksum = checksum = 0; - l = (int32_t *)buf; - for (i = 0; i < sizeof(struct sgilabel) / sizeof(int32_t); ++i) - checksum += betoh32(l[i]); - volhdr->checksum = htobe32(-checksum); -} - -void -usage(void) -{ - extern char *__progname; - - fprintf(stderr, - "usage: %s [-q] disk\n" - " %s [-q] -d vhfilename disk\n" - " %s [-q] -i [-h vhsize] disk\n" - " %s [-q] -l vhfilename1 vhfilename2 disk\n" - " %s [-q] -r vhfilename diskfilename disk\n" - " %s [-q] -w vhfilename diskfilename disk\n", - __progname, __progname, __progname, __progname, __progname, - __progname); - - exit(1); -} diff --git a/sys/arch/sgi/xbow/Makefile b/sys/arch/sgi/xbow/Makefile deleted file mode 100644 index b0a96ac8d49..00000000000 --- a/sys/arch/sgi/xbow/Makefile +++ /dev/null @@ -1,7 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2008/04/07 22:47:40 miod Exp $ - -AWK= awk - -xbowdevs.h xbowdevs_data.h: xbowdevs devlist2h.awk - /bin/rm -f xbowdevs.h xbowdevs_data.h - ${AWK} -f devlist2h.awk xbowdevs diff --git a/sys/arch/sgi/xbow/devlist2h.awk b/sys/arch/sgi/xbow/devlist2h.awk deleted file mode 100644 index a7106aa986b..00000000000 --- a/sys/arch/sgi/xbow/devlist2h.awk +++ /dev/null @@ -1,168 +0,0 @@ -#! /usr/bin/awk -f -# $OpenBSD: devlist2h.awk,v 1.2 2008/07/28 18:50:59 miod Exp $ -# $NetBSD: devlist2h.awk,v 1.2 1996/01/22 21:08:09 cgd Exp $ -# -# Copyright (c) 1995, 1996 Christopher G. Demetriou -# 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. -# 3. All advertising materials mentioning features or use of this software -# must display the following acknowledgement: -# This product includes software developed by Christopher G. Demetriou. -# 4. The name of the author may not be used to endorse or promote products -# derived from this software without specific prior written permission -# -# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 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. -# -BEGIN { - nproducts = nvendor_dup = nvendors = 0 - dfile="xbowdevs_data.h" - hfile="xbowdevs.h" -} -NR == 1 { - VERSION = $0 - gsub("\\$", "", VERSION) - - printf("/*\n") > dfile - printf(" * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT.\n") \ - > dfile - printf(" *\n") > dfile - printf(" * generated from:\n") > dfile - printf(" *\t%s\n", VERSION) > dfile - printf(" */\n\n") > dfile - - printf("/*\n") > hfile - printf(" * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT.\n") \ - > hfile - printf(" *\n") > hfile - printf(" * generated from:\n") > hfile - printf(" *\t%s\n", VERSION) > hfile - printf(" */\n") > hfile - - next -} -$1 == "vendor" { - nvendors++ - - if ($2 in vendorindex) { - printf("duplicate vendor name %s\n", $2); - nvendor_dup++; - } - - vendorindex[$2] = nvendors; # record index for this name, for later. - vendors[nvendors, 1] = $2; # name - vendors[nvendors, 2] = $3; # id - printf("#define\tXBOW_VENDOR_%s\t%s\n", vendors[nvendors, 1], - vendors[nvendors, 2]) > hfile - - next -} -$1 == "product" { - nproducts++ - - products[nproducts, 1] = $2; # vendor name - products[nproducts, 2] = $3; # product id - products[nproducts, 3] = $4; # id - printf("#define\tXBOW_PRODUCT_%s_%s\t%s\t", products[nproducts, 1], - products[nproducts, 2], products[nproducts, 3]) > hfile - - i=4; f = 5; - - # comments - ocomment = oparen = 0 - if (f <= NF) { - printf("\t/* ") > hfile - ocomment = 1; - } - while (f <= NF) { - if ($f == "#") { - printf("(") > hfile - oparen = 1 - f++ - continue - } - if (oparen) { - printf("%s", $f) > hfile - if (f < NF) - printf(" ") > hfile - f++ - continue - } - products[nproducts, i] = $f - printf("%s", products[nproducts, i]) > hfile - if (f < NF) - printf(" ") > hfile - i++; f++; - } - if (oparen) - printf(")") > hfile - if (ocomment) - printf(" */") > hfile - printf("\n") > hfile - - next -} -{ - if ($0 == "") - blanklines++ - print $0 > hfile - if (blanklines < 2) - print $0 > dfile -} -END { - # print out the match tables - - printf("\n") > dfile - - if (nvendor_dup > 0) - exit(1); - - printf("/* Descriptions of known devices. */\n") > dfile - - printf("struct xbow_product {\n") > dfile - printf("\tuint32_t vendor;\n") > dfile - printf("\tuint32_t product;\n") > dfile - printf("\tconst char *productname;\n") > dfile - printf("};\n\n") > dfile - - - printf("static const struct xbow_product xbow_products[] = {\n") \ - > dfile - for (i = 1; i <= nproducts; i++) { - printf("\t{\n") > dfile - printf("\t XBOW_VENDOR_%s, XBOW_PRODUCT_%s_%s,\n", - products[i, 1], products[i, 1], products[i, 2]) \ - > dfile - - printf("\t \"") > dfile - j = 4; - needspace = 0; - while (products[i, j] != "") { - if (needspace) - printf(" ") > dfile - printf("%s", products[i, j]) > dfile - needspace = 1 - j++ - } - printf("\",\n") > dfile - printf("\t},\n") > dfile - } - printf("\t{ 0, 0, NULL, }\n") > dfile - printf("};\n\n") > dfile -} diff --git a/sys/arch/sgi/xbow/files.xbow b/sys/arch/sgi/xbow/files.xbow deleted file mode 100644 index a58bd3f16ee..00000000000 --- a/sys/arch/sgi/xbow/files.xbow +++ /dev/null @@ -1,28 +0,0 @@ -# $OpenBSD: files.xbow,v 1.9 2012/05/10 21:30:09 miod Exp $ - -# IP30 and IP27 planar XBow bus -define xbow {[widget = -1], [vendor = -1], [product = -1]} -device xbow -attach xbow at mainbus -file arch/sgi/xbow/xbow.c xbow - -# IP30 Heart -device xheart {} : onewirebus -attach xheart at xbow -file arch/sgi/xbow/xheart.c xheart - -# PCI Bridge -device xbridge {} -attach xbridge at xbow -device xbpci {[bus = -1]} : pcibus -attach xbpci at xbridge -file arch/sgi/xbow/xbridge.c xbridge - -# Odyssey graphics -device odyssey: wsemuldisplaydev, rasops32 -attach odyssey at xbow -file arch/sgi/xbow/odyssey.c odyssey needs-flag - -# ImpactSR graphics -attach impact at xbow with impact_xbow -file arch/sgi/xbow/impact_xbow.c impact_xbow diff --git a/sys/arch/sgi/xbow/hub.h b/sys/arch/sgi/xbow/hub.h deleted file mode 100644 index 485ac09f6a2..00000000000 --- a/sys/arch/sgi/xbow/hub.h +++ /dev/null @@ -1,233 +0,0 @@ -/* $OpenBSD: hub.h,v 1.11 2016/01/02 05:49:36 visa Exp $ */ - -/* - * Copyright (c) 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * HUB access macros. - */ -#define LWIN_SIZE_BITS 24 -#define LWIN_SIZE (1ULL << LWIN_SIZE_BITS) - -#define NODE_LWIN_BASE(nasid, widget) \ - (IP27_NODE_IO_BASE(nasid) + ((uint64_t)(widget) << LWIN_SIZE_BITS)) - -#define IP27_LHUB_ADDR(_x) \ - ((volatile uint64_t *)(NODE_LWIN_BASE(0, 1) + (_x))) -#define IP27_RHUB_ADDR(_n, _x) \ - ((volatile uint64_t *)(NODE_LWIN_BASE(_n, 1) + 0x800000 + (_x))) -#define IP27_RHUB_PI_ADDR(_n, _sn, _x) \ - ((volatile uint64_t *)(NODE_LWIN_BASE(_n, 1) + 0x800000 + \ - ((_sn) ? HUBPI_OFFSET : 0) + (_x))) - -#define IP27_LHUB_L(r) *(IP27_LHUB_ADDR(r)) -#define IP27_LHUB_S(r, d) *(IP27_LHUB_ADDR(r)) = (d) -#define IP27_RHUB_L(n, r) *(IP27_RHUB_ADDR((n), (r))) -#define IP27_RHUB_S(n, r, d) *(IP27_RHUB_ADDR((n), (r))) = (d) -#define IP27_RHUB_PI_L(n, s, r) *(IP27_RHUB_PI_ADDR((n), (s), (r))) -#define IP27_RHUB_PI_S(n, s, r, d) *(IP27_RHUB_PI_ADDR((n), (s), (r))) = (d) - -#define NODE_HSPEC_BASE(nasid) \ - (IP27_NODE_HSPEC_BASE(nasid)) - -#define IP27_LHSPEC_ADDR(_x) \ - ((volatile uint64_t *)(NODE_HSPEC_BASE(0) + (_x))) -#define IP27_RHSPEC_ADDR(_n, _x) \ - ((volatile uint64_t *)(NODE_HSPEC_BASE(_n) + 0x20000000 + (_x))) - -#define IP27_LHSPEC_L(r) *(IP27_LHSPEC_ADDR(r)) -#define IP27_LHSPEC_S(r, d) *(IP27_LHSPEC_ADDR(r)) = (d) -#define IP27_RHSPEC_L(n, r) *(IP27_RHSPEC_ADDR((n), (r))) -#define IP27_RHSPEC_S(n, r, d) *(IP27_RHSPEC_ADDR((n), (r))) = (d) - -/* - * HUB SPECIAL space (very incomplete) - */ - -#define LBOOTBASE_IP27 0x10000000 -#define LBOOTSIZE_IP27 0x10000000 - -#define LREGBASE_IP35 0x10000000 -#define LREGSIZE_IP35 0x08000000 -#define LBOOTBASE_IP35 0x18000000 -#define LBOOTSIZE_IP35 0x08000000 - -#define HSPEC_L1_UARTBASE 0x00000080 -#define HSPEC_SYNERGY0 0x04000000 /* synergy #0 base */ -#define HSPEC_SYNERGY1 0x05000000 /* synergy #1 base */ - -#define HSPEC_L1_UART(r) \ - (LREGBASE_IP35 + HSPEC_L1_UARTBASE + ((r) << 3)) -#define HSPEC_SYNERGY(s,r) \ - (LREGBASE_IP35 + ((s) ? HSPEC_SYNERGY1 : HSPEC_SYNERGY0) + ((r) << 3)) - -/* - * HUB IO space (very incomplete) - */ - -/* - * HUB PI - Processor Interface - */ - -#define HUBPIBASE 0x00000000 - -#define HUBPI_REGION_PRESENT 0x00000018 -#define HUBPI_CPU_NUMBER 0x00000020 -#define HUBPI_CALIAS_SIZE 0x00000028 -#define PI_CALIAS_SIZE_0 0 - - -#define HUBPI_CPU0_PRESENT 0x00000040 -#define HUBPI_CPU1_PRESENT 0x00000048 -#define HUBPI_CPU0_ENABLED 0x00000050 -#define HUBPI_CPU1_ENABLED 0x00000058 - -#define HUBPI_IR_CHANGE 0x00000090 -#define PI_IR_SET 0x100 -#define PI_IR_CLR 0x000 -#define HUBPI_IR0 0x00000098 -#define HUBPI_IR1 0x000000a0 -#define HUBPI_CPU0_IMR0 0x000000a8 -#define HUBPI_CPU0_IMR1 0x000000b0 -#define HUBPI_CPU1_IMR0 0x000000b8 -#define HUBPI_CPU1_IMR1 0x000000c0 - -#define HUBPI_RT_COUNT 0x00030100 - -/* - * Offset to use to access the second PI over the remote hub interface - * on IP35. - */ -#define HUBPI_OFFSET 0x00200000 - -/* - * ISR bit assignments. - */ - -/** Level 1 interrupt */ -/* ?? MSC panic */ -#define HUBPI_ISR1_MSC_ERROR 63 -/* NI interface error */ -#define HUBPI_ISR1_NI_ERROR 62 -/* MD correctable error */ -#define HUBPI_ISR1_MD_COR_ERROR 61 -/* cpu correctable error B */ -#define HUBPI_ISR1_COR_ERROR_B 60 -/* cpu correctable error A */ -#define HUBPI_ISR1_COR_ERROR_A 59 -/* clock error */ -#define HUBPI_ISR1_CLOCK_ERROR 58 -/* IP35 NACK interrupts */ -#define HUBPI_ISR1_NACK_B 57 -#define HUBPI_ISR1_NACK_A 56 -/* IP35 LB error */ -#define HUBPI_ISR1_LB 55 -/* IP35 XB error */ -#define HUBPI_ISR1_XB 54 -/* 53-45 used by PROM */ -/* 44-43 available */ -/* 42-41 LLP errors */ -/* NI broadcast errors */ -#define HUBPI_ISR1_NI_ERROR_B 40 -#define HUBPI_ISR1_NI_ERROR_A 39 -/* 38-36 used by IP35 PROM */ -/* 35-0 available */ - -/** Level 0 interrupt */ -/* 63-11 available */ -/* IPI interrupts */ -#define HUBPI_ISR0_IPI_D 10 -#define HUBPI_ISR0_IPI_C 9 -#define HUBPI_ISR0_IPI_B 8 -#define HUBPI_ISR0_IPI_A 7 -/* ? */ -#define HUBPI_CC_PEND_B 6 -#define HUBPI_CC_PEND_A 5 -/* ? */ -#define HUBPI_ISR0_UART 4 -/* page migration interrupt */ -#define HUBPI_ISR0_PAGE_MIGRATION 3 -/* graphics->cpu interrupts */ -#define HUBPI_ISR0_GFX_B 2 -#define HUBPI_ISR0_GFX_A 1 -/* 0 reserved */ - -#define HUBPI_INTR1_WIDGET_MAX 35 -#define HUBPI_INTR1_WIDGET_MIN 0 -#define HUBPI_INTR0_WIDGET_MAX 63 -#define HUBPI_INTR0_WIDGET_MIN 11 - -#define HUBPI_NINTS 64 /* per register */ - -/* - * HUB MD - Memory/Directory - */ - -#define HUBMDBASE_IP27 0x00200000 -#define HUBMDBASE_IP35 0x00780000 - -#define HUBMD_LED0 0x00020050 - - -/* - * HUB IO - Widget I/O - */ - -#define HUBIOBASE 0x00400000 - -#define HUBIO_IOTTE(x) (0x00000160 + (x) * 8) -#define IOTTE_MAX 7 -#define IOTTE_SWIN0 (IOTTE_MAX - 1) - -#define IOTTE(space,widget,offset) \ - (((space) << 12) | ((widget) << 8) | (offset)) -#define IOTTE_SPACE_DEVICE 1 -#define IOTTE_SPACE_MEMORY 0 -#define IOTTE_SPACE(iotte) (((iotte) >> 12) & 0x01) -#define IOTTE_WIDGET(iotte) (((iotte) >> 8) & 0x0f) -#define IOTTE_OFFSET(iotte) ((iotte) & 0xff) - - -/* - * HUB LB - Local Bedrock - */ - -#define HUBLBBASE_IP35 0x00600000 - -/* - * HUB NI - Network Interface - */ - -#define HUBNIBASE_IP27 0x00600000 -#define HUBNIBASE_IP35 0x00680000 - -#define HUBNI_STATUS 0x00000000 -#define NI_MORENODES 0x0000000000040000 -#define HUBNI_RESET 0x00000008 -#define NI_RESET_ACTION_IP27 0x02 -#define NI_RESET_PORT_IP27 0x80 -#define NI_RESET_LOCAL_IP27 0x01 -#define NI_RESET_ACTION_IP35 0x01 -#define NI_RESET_PORT_IP35 0x02 -#define NI_RESET_LOCAL_IP35 0x04 -#define HUBNI_RESET_ENABLE 0x00000010 -#define NI_RESET_ENABLE 0x01 - -/* - * HUB XB - Crossbar interface - */ - -#define HUBXBBASE_IP35 0x00700000 diff --git a/sys/arch/sgi/xbow/impact_xbow.c b/sys/arch/sgi/xbow/impact_xbow.c deleted file mode 100644 index bfe2bb350a3..00000000000 --- a/sys/arch/sgi/xbow/impact_xbow.c +++ /dev/null @@ -1,168 +0,0 @@ -/* $OpenBSD: impact_xbow.c,v 1.2 2017/09/08 05:36:52 deraadt Exp $ */ - -/* - * Copyright (c) 2010, 2012 Miodrag Vallat. - * Copyright (c) 2009, 2010 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Driver for the SGI ImpactSR graphics board (XBow attachment). - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> - -#include <machine/autoconf.h> - -#include <mips64/arcbios.h> - -#include <sgi/dev/impactvar.h> -#include <sgi/xbow/widget.h> -#include <sgi/xbow/xbow.h> -#include <sgi/xbow/xbowdevs.h> - -#define IMPACTSR_REG_OFFSET 0x00000000 -#define IMPACTSR_REG_SIZE 0x00200000 - -struct impact_xbow_softc { - struct impact_softc sc_base; - - struct mips_bus_space iot_store; -}; - -int impact_xbow_match(struct device *, void *, void *); -void impact_xbow_attach(struct device *, struct device *, void *); - -const struct cfattach impact_xbow_ca = { - sizeof(struct impact_xbow_softc), impact_xbow_match, impact_xbow_attach -}; - -int impact_xbow_is_console(struct xbow_attach_args *); - -int -impact_xbow_match(struct device *parent, void *match, void *aux) -{ - struct xbow_attach_args *xaa = aux; - - if (xaa->xaa_vendor == XBOW_VENDOR_SGI5 && - xaa->xaa_product == XBOW_PRODUCT_SGI5_IMPACT) - return 1; - - return 0; -} - -void -impact_xbow_attach(struct device *parent, struct device *self, void *aux) -{ - struct xbow_attach_args *xaa = aux; - struct impact_xbow_softc *sc = (struct impact_xbow_softc *)self; - bus_space_tag_t iot; - bus_space_handle_t ioh; - int console; - - if (strncmp(bios_graphics, "alive", 5) != 0) { - printf(" device has not been setup by firmware!\n"); - return; - } - - printf(" revision %d\n", xaa->xaa_revision); - - console = impact_xbow_is_console(xaa); - - if (console != 0) { - iot = NULL; - ioh = 0; - } else { - /* - * Create a copy of the bus space tag. - */ - bcopy(xaa->xaa_iot, &sc->iot_store, - sizeof(struct mips_bus_space)); - iot = &sc->iot_store; - - /* Setup bus space mappings. */ - if (bus_space_map(iot, IMPACTSR_REG_OFFSET, - IMPACTSR_REG_SIZE, 0, &ioh)) { - printf("failed to map registers\n"); - return; - } - } - - if (impact_attach_common(&sc->sc_base, iot, ioh, console, 1) != 0) { - if (console == 0) - bus_space_unmap(iot, ioh, IMPACTSR_REG_SIZE); - } -} - -/* - * Console support. - */ - -int -impact_xbow_cnprobe() -{ - u_int32_t wid, vendor, product; - - if (xbow_widget_id(console_output.nasid, console_output.widget, - &wid) != 0) - return 0; - - vendor = WIDGET_ID_VENDOR(wid); - product = WIDGET_ID_PRODUCT(wid); - - if (vendor != XBOW_VENDOR_SGI5 || product != XBOW_PRODUCT_SGI5_IMPACT) - return 0; - - if (strncmp(bios_graphics, "alive", 5) != 0) - return 0; - - return 1; -} - -int -impact_xbow_cnattach() -{ - static struct mips_bus_space impact_iot_store; - bus_space_tag_t iot; - bus_space_handle_t ioh; - int rc; - - /* Build bus space accessor. */ - xbow_build_bus_space(&impact_iot_store, console_output.nasid, - console_output.widget); - iot = &impact_iot_store; - - rc = bus_space_map(iot, IMPACTSR_REG_OFFSET, IMPACTSR_REG_SIZE, - 0, &ioh); - if (rc != 0) - return rc; - - rc = impact_cnattach_common(iot, ioh, 1); - if (rc != 0) { - bus_space_unmap(iot, ioh, IMPACTSR_REG_SIZE); - return rc; - } - - return 0; -} - -int -impact_xbow_is_console(struct xbow_attach_args *xaa) -{ - return xaa->xaa_nasid == console_output.nasid && - xaa->xaa_widget == console_output.widget; -} diff --git a/sys/arch/sgi/xbow/odyssey.c b/sys/arch/sgi/xbow/odyssey.c deleted file mode 100644 index fa5595611c6..00000000000 --- a/sys/arch/sgi/xbow/odyssey.c +++ /dev/null @@ -1,1149 +0,0 @@ -/* $OpenBSD: odyssey.c,v 1.15 2021/03/11 11:17:00 jsg Exp $ */ -/* - * Copyright (c) 2009, 2010 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Driver for the SGI VPro (aka Odyssey) Graphics Card. - */ - -/* - * The details regarding the design and operation of this hardware, along with - * the necessary magic numbers, are only available thanks to the reverse - * engineering work undertaken by Stanislaw Skowronek <skylark@linux-mips.org>. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/malloc.h> - -#include <machine/autoconf.h> - -#include <mips64/arcbios.h> - -#include <sgi/dev/gl.h> -#include <sgi/xbow/odysseyreg.h> -#include <sgi/xbow/odysseyvar.h> -#include <sgi/xbow/widget.h> -#include <sgi/xbow/xbow.h> -#include <sgi/xbow/xbowdevs.h> - -#include <dev/wscons/wsconsio.h> -#include <dev/wscons/wsdisplayvar.h> -#include <dev/rasops/rasops.h> - -/* - * Colourmap data. - */ -struct odyssey_cmap { - u_int8_t cm_red[256]; - u_int8_t cm_green[256]; - u_int8_t cm_blue[256]; -}; - -/* - * Screen data. - */ -struct odyssey_screen { - struct device *sc; /* Back pointer. */ - - struct rasops_info ri; /* Screen raster display info. */ - struct odyssey_cmap cmap; /* Display colour map. */ - uint32_t attr; /* Rasops attributes. */ - - int width; /* Width in pixels. */ - int height; /* Height in pixels. */ - int depth; /* Colour depth in bits. */ - int linebytes; /* Bytes per line. */ -}; - -struct odyssey_softc { - struct device sc_dev; - - struct mips_bus_space iot_store; - bus_space_tag_t iot; - bus_space_handle_t ioh; - - int console; /* Is this the console? */ - int screens; /* No of screens allocated. */ - - struct odyssey_screen *curscr; /* Current screen. */ -}; - -int odyssey_match(struct device *, void *, void *); -void odyssey_attach(struct device *, struct device *, void *); - -int odyssey_is_console(struct xbow_attach_args *); - -void odyssey_cmd_wait(struct odyssey_softc *); -void odyssey_data_wait(struct odyssey_softc *); -void odyssey_cmd_flush(struct odyssey_softc *, int); - -void odyssey_setup(struct odyssey_softc *); -void odyssey_init_screen(struct odyssey_screen *); - -/* - * Colour map handling for indexed modes. - */ -int odyssey_getcmap(struct odyssey_cmap *, struct wsdisplay_cmap *); -int odyssey_putcmap(struct odyssey_cmap *, struct wsdisplay_cmap *); - -/* - * Hardware acceleration for rasops. - */ -void odyssey_rop(struct odyssey_softc *, int, int, int, int, int, int); -void odyssey_copyrect(struct odyssey_softc *, int, int, int, int, int, int); -void odyssey_fillrect(struct odyssey_softc *, int, int, int, int, u_int); -int odyssey_do_cursor(struct rasops_info *); -int odyssey_putchar(void *, int, int, u_int, uint32_t); -int odyssey_copycols(void *, int, int, int, int); -int odyssey_erasecols(void *, int, int, int, uint32_t); -int odyssey_copyrows(void *, int, int, int); -int odyssey_eraserows(void *, int, int, uint32_t); - -u_int32_t ieee754_sp(uint); - -/* - * Interfaces for wscons. - */ -int odyssey_ioctl(void *, u_long, caddr_t, int, struct proc *); -paddr_t odyssey_mmap(void *, off_t, int); -int odyssey_alloc_screen(void *, const struct wsscreen_descr *, void **, - int *, int *, uint32_t *); -void odyssey_free_screen(void *, void *); -int odyssey_show_screen(void *, void *, int, void (*)(void *, int, int), - void *); -int odyssey_load_font(void *, void *, struct wsdisplay_font *); -int odyssey_list_font(void *, struct wsdisplay_font *); - -static struct odyssey_screen odyssey_consdata; -static struct odyssey_softc odyssey_cons_sc; - -struct wsscreen_descr odyssey_stdscreen = { - "std", /* Screen name. */ -}; - -struct wsdisplay_accessops odyssey_accessops = { - .ioctl = odyssey_ioctl, - .mmap = odyssey_mmap, - .alloc_screen = odyssey_alloc_screen, - .free_screen = odyssey_free_screen, - .show_screen = odyssey_show_screen, - .load_font = odyssey_load_font, - .list_font = odyssey_list_font -}; - -const struct wsscreen_descr *odyssey_scrlist[] = { - &odyssey_stdscreen -}; - -struct wsscreen_list odyssey_screenlist = { - nitems(odyssey_scrlist), odyssey_scrlist -}; - -const struct cfattach odyssey_ca = { - sizeof(struct odyssey_softc), odyssey_match, odyssey_attach, -}; - -struct cfdriver odyssey_cd = { - NULL, "odyssey", DV_DULL, -}; - -int -odyssey_match(struct device *parent, void *match, void *aux) -{ - struct xbow_attach_args *xaa = aux; - - if (xaa->xaa_vendor == XBOW_VENDOR_SGI2 && - xaa->xaa_product == XBOW_PRODUCT_SGI2_ODYSSEY) - return 1; - - return 0; -} - -void -odyssey_attach(struct device *parent, struct device *self, void *aux) -{ - struct xbow_attach_args *xaa = aux; - struct wsemuldisplaydev_attach_args waa; - struct odyssey_softc *sc = (void *)self; - struct odyssey_screen *screen; - - if (strncmp(bios_graphics, "alive", 5) != 0) { - printf(" device has not been setup by firmware!\n"); - return; - } - - printf(" revision %d\n", xaa->xaa_revision); - - /* - * Create a copy of the bus space tag. - */ - bcopy(xaa->xaa_iot, &sc->iot_store, sizeof(struct mips_bus_space)); - sc->iot = &sc->iot_store; - - /* Setup bus space mappings. */ - if (bus_space_map(sc->iot, ODYSSEY_REG_OFFSET, ODYSSEY_REG_SIZE, - BUS_SPACE_MAP_LINEAR, &sc->ioh)) { - printf("failed to map bus space!\n"); - return; - } - - if (odyssey_is_console(xaa)) { - /* - * Setup has already been done via odyssey_cnattach(). - */ - screen = &odyssey_consdata; - sc->curscr = screen; - sc->curscr->sc = (void *)sc; - sc->console = 1; - } else { - /* - * Setup screen data. - */ - sc->curscr = malloc(sizeof(struct odyssey_screen), M_DEVBUF, - M_NOWAIT); - if (sc->curscr == NULL) { - printf("failed to allocate screen memory!\n"); - return; - } - sc->curscr->sc = (void *)sc; - screen = sc->curscr; - - /* Setup hardware and clear screen. */ - odyssey_setup(sc); - odyssey_fillrect(sc, 0, 0, 1280, 1024, 0x000000); - odyssey_cmd_flush(sc, 0); - - /* Set screen defaults. */ - screen->width = 1280; - screen->height = 1024; - screen->depth = 32; - screen->linebytes = screen->width * screen->depth / 8; - - odyssey_init_screen(screen); - } - - waa.console = sc->console; - waa.scrdata = &odyssey_screenlist; - waa.accessops = &odyssey_accessops; - waa.accesscookie = screen; - waa.defaultscreens = 0; - config_found(self, &waa, wsemuldisplaydevprint); -} - -void -odyssey_init_screen(struct odyssey_screen *screen) -{ - u_char *colour; - int i; - - /* - * Initialise screen. - */ - - /* Initialise rasops. */ - memset(&screen->ri, 0, sizeof(struct rasops_info)); - - screen->ri.ri_flg = RI_CENTER; - screen->ri.ri_depth = screen->depth; - screen->ri.ri_width = screen->width; - screen->ri.ri_height = screen->height; - screen->ri.ri_stride = screen->linebytes; - - if (screen->depth == 32) { - screen->ri.ri_bpos = 16; - screen->ri.ri_bnum = 8; - screen->ri.ri_gpos = 8; - screen->ri.ri_gnum = 8; - screen->ri.ri_rpos = 0; - screen->ri.ri_rnum = 8; - } else if (screen->depth == 16) { - screen->ri.ri_rpos = 10; - screen->ri.ri_rnum = 5; - screen->ri.ri_gpos = 5; - screen->ri.ri_gnum = 5; - screen->ri.ri_bpos = 0; - screen->ri.ri_bnum = 5; - } - - rasops_init(&screen->ri, screen->height / 8, screen->width / 8); - - /* - * Initialise colourmap, if required. - */ - if (screen->depth == 8) { - for (i = 0; i < 16; i++) { - colour = (u_char *)&rasops_cmap[i * 3]; - screen->cmap.cm_red[i] = colour[0]; - screen->cmap.cm_green[i] = colour[1]; - screen->cmap.cm_blue[i] = colour[2]; - } - for (i = 240; i < 256; i++) { - colour = (u_char *)&rasops_cmap[i * 3]; - screen->cmap.cm_red[i] = colour[0]; - screen->cmap.cm_green[i] = colour[1]; - screen->cmap.cm_blue[i] = colour[2]; - } - } - - screen->ri.ri_hw = screen->sc; - - screen->ri.ri_ops.putchar = odyssey_putchar; - screen->ri.ri_do_cursor = odyssey_do_cursor; - screen->ri.ri_ops.copyrows = odyssey_copyrows; - screen->ri.ri_ops.copycols = odyssey_copycols; - screen->ri.ri_ops.eraserows = odyssey_eraserows; - screen->ri.ri_ops.erasecols = odyssey_erasecols; - - odyssey_stdscreen.ncols = screen->ri.ri_cols; - odyssey_stdscreen.nrows = screen->ri.ri_rows; - odyssey_stdscreen.textops = &screen->ri.ri_ops; - odyssey_stdscreen.fontwidth = screen->ri.ri_font->fontwidth; - odyssey_stdscreen.fontheight = screen->ri.ri_font->fontheight; - odyssey_stdscreen.capabilities = screen->ri.ri_caps; -} - -/* - * Hardware initialisation. - */ -void -odyssey_setup(struct odyssey_softc *sc) -{ - u_int64_t val; - int i; - - /* Initialise Buzz Graphics Engine. */ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x20008003); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x21008010); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x22008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x23008002); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x2400800c); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x2500800e); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x27008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x28008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x290080d6); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x2a0080e0); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x2c0080ea); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x2e008380); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x2f008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x30008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x31008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x32008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x33008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x34008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x35008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x310081e0); - odyssey_cmd_flush(sc, 0); - - /* Initialise Buzz X-Form. */ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x9080bda2); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f800000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0xbf800000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x4e000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x40400000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x4e000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x4d000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x34008000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x9080bdc8); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f800000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f800000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f800000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f800000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x34008010); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x908091df); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3f800000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x34008000); - odyssey_cmd_flush(sc, 0); - - /* Initialise Buzz Raster. */ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x0001203b); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00001000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00001000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00001000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00001000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x0001084a); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000080); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000080); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010845); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x000000ff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x000076ff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x0001141b); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000001); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00011c16); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x03000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010404); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00011023); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00ff0ff0); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00ff0ff0); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x000000ff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00011017); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00002000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000050); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x20004950); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x0001204b); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x004ff3ff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00ffffff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00ffffff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00ffffff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - odyssey_cmd_flush(sc, 0); - - /* - * Initialise Pixel Blaster & Jammer. - */ - for (i = 0; i < 32; i++) { - if ((i & 0xf) == 0) - odyssey_data_wait(sc); - - bus_space_write_8(sc->iot, sc->ioh, ODYSSEY_DATA_FIFO, - ((0x30000001ULL | ((0x2900 + i) << 14)) << 32) | - 0x905215a6); - } - - odyssey_data_wait(sc); - bus_space_write_8(sc->iot, sc->ioh, ODYSSEY_DATA_FIFO, - ((0x30000001ULL | (0x2581 << 14)) << 32) | 0x0); - - /* Gamma ramp. */ - for (i = 0; i < 0x600; i++) { - if ((i & 0xf) == 0) - odyssey_data_wait(sc); - - if (i < 0x200) - val = i >> 2; - else if (i < 0x300) - val = ((i - 0x200) >> 1) + 0x80; - else - val = ((i - 0x300) >> 0) + 0x100; - - val = (val << 20) | (val << 10) | val; - - bus_space_write_8(sc->iot, sc->ioh, ODYSSEY_DATA_FIFO, - ((0x30000001ULL | ((0x1a00 + i) << 14)) << 32) | val); - } -} - -void -odyssey_cmd_wait(struct odyssey_softc *sc) -{ - u_int32_t val, timeout = 1000000; - - val = bus_space_read_4(sc->iot, sc->ioh, ODYSSEY_STATUS); - while ((val & ODYSSEY_STATUS_CMD_FIFO_LOW) == 0) { - delay(1); - if (--timeout == 0) { - printf("odyssey: timeout waiting for command fifo!\n"); - return; - } - val = bus_space_read_4(sc->iot, sc->ioh, ODYSSEY_STATUS); - } -} - -void -odyssey_data_wait(struct odyssey_softc *sc) -{ - u_int32_t val, timeout = 1000000; - - val = bus_space_read_4(sc->iot, sc->ioh, ODYSSEY_DBE_STATUS); - while ((val & 0x7f) > 0) { - delay(1); - if (--timeout == 0) { - printf("odyssey: timeout waiting for data fifo!\n"); - return; - } - val = bus_space_read_4(sc->iot, sc->ioh, ODYSSEY_DBE_STATUS); - } -} - -void -odyssey_cmd_flush(struct odyssey_softc *sc, int quick) -{ - - odyssey_cmd_wait(sc); - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010443); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x000000fa); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); - - if (quick) - return; - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010019); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010443); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000096); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010443); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x000000fa); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010046); -} - -/* - * Interfaces for wscons. - */ - -int -odyssey_ioctl(void *v, u_long cmd, caddr_t data, int flags, struct proc *p) -{ - struct odyssey_screen *screen = (struct odyssey_screen *)v; - int rc; - - switch (cmd) { - case WSDISPLAYIO_GTYPE: - *(u_int *)data = WSDISPLAY_TYPE_ODYSSEY; - break; - - case WSDISPLAYIO_GINFO: - { - struct wsdisplay_fbinfo *fb = (struct wsdisplay_fbinfo *)data; - - fb->height = screen->height; - fb->width = screen->width; - fb->depth = screen->depth; - fb->cmsize = screen->depth == 8 ? 256 : 0; - } - break; - - case WSDISPLAYIO_LINEBYTES: - *(u_int *)data = screen->linebytes; - break; - - case WSDISPLAYIO_GETCMAP: - if (screen->depth == 8) { - struct wsdisplay_cmap *cm = - (struct wsdisplay_cmap *)data; - - rc = odyssey_getcmap(&screen->cmap, cm); - if (rc != 0) - return (rc); - } - break; - - case WSDISPLAYIO_PUTCMAP: - if (screen->depth == 8) { - struct wsdisplay_cmap *cm = - (struct wsdisplay_cmap *)data; - - rc = odyssey_putcmap(&screen->cmap, cm); - if (rc != 0) - return (rc); - } - break; - - case WSDISPLAYIO_GVIDEO: - case WSDISPLAYIO_SVIDEO: - /* Handled by the upper layer. */ - break; - - default: - return (-1); - } - - return (0); -} - -int -odyssey_getcmap(struct odyssey_cmap *cm, struct wsdisplay_cmap *rcm) -{ - u_int index = rcm->index, count = rcm->count; - int rc; - - if (index >= 256 || count > 256 - index) - return (EINVAL); - - if ((rc = copyout(&cm->cm_red[index], rcm->red, count)) != 0) - return (rc); - if ((rc = copyout(&cm->cm_green[index], rcm->green, count)) != 0) - return (rc); - if ((rc = copyout(&cm->cm_blue[index], rcm->blue, count)) != 0) - return (rc); - - return (0); -} - -int -odyssey_putcmap(struct odyssey_cmap *cm, struct wsdisplay_cmap *rcm) -{ - u_int index = rcm->index, count = rcm->count; - int rc; - - if (index >= 256 || count > 256 - index) - return (EINVAL); - - if ((rc = copyin(rcm->red, &cm->cm_red[index], count)) != 0) - return (rc); - if ((rc = copyin(rcm->green, &cm->cm_green[index], count)) != 0) - return (rc); - if ((rc = copyin(rcm->blue, &cm->cm_blue[index], count)) != 0) - return (rc); - - return (0); -} - -paddr_t -odyssey_mmap(void *v, off_t offset, int protection) -{ - return (-1); -} - -int -odyssey_alloc_screen(void *v, const struct wsscreen_descr *type, - void **cookiep, int *curxp, int *curyp, uint32_t *attrp) -{ - struct odyssey_screen *screen = (struct odyssey_screen *)v; - struct odyssey_softc *sc = (struct odyssey_softc *)screen->sc; - - /* We do not allow multiple consoles at the moment. */ - if (sc->screens > 0) - return (ENOMEM); - - sc->screens++; - - /* Return rasops_info via cookie. */ - *cookiep = &screen->ri; - - /* Move cursor to top left of screen. */ - *curxp = 0; - *curyp = 0; - - /* Correct screen attributes. */ - screen->ri.ri_ops.pack_attr(&screen->ri, 0, 0, 0, attrp); - screen->attr = *attrp; - - return (0); -} - -void -odyssey_free_screen(void *v, void *cookie) -{ - /* We do not allow multiple consoles at the moment. */ -} - -int -odyssey_show_screen(void *v, void *cookie, int waitok, - void (*cb)(void *, int, int), void *cbarg) -{ - /* We do not allow multiple consoles at the moment. */ - return (0); -} - -int -odyssey_load_font(void *v, void *emulcookie, struct wsdisplay_font *font) -{ - struct odyssey_screen *screen = (struct odyssey_screen *)v; - - return rasops_load_font(&screen->ri, emulcookie, font); -} - -int -odyssey_list_font(void *v, struct wsdisplay_font *font) -{ - struct odyssey_screen *screen = (struct odyssey_screen *)v; - - return rasops_list_font(&screen->ri, font); -} - -/* - * Hardware accelerated functions. - */ - -void -odyssey_rop(struct odyssey_softc *sc, int x, int y, int w, int h, int op, int c) -{ - /* Setup raster operation. */ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010404); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00100000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_LOGIC_OP); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, op); - odyssey_cmd_flush(sc, 1); - - odyssey_fillrect(sc, x, y, w, h, c); - - /* Return to copy mode. */ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010404); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00100000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_LOGIC_OP); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, - OPENGL_LOGIC_OP_COPY); - odyssey_cmd_flush(sc, 1); -} - -void -odyssey_copyrect(struct odyssey_softc *sc, int sx, int sy, int dx, int dy, - int w, int h) -{ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010658); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00120000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00002031); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00002000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, sx | (sy << 16)); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x80502050); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, w | (h << 16)); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x82223042); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00002000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, dx | (dy << 16)); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x3222204b); - - odyssey_cmd_flush(sc, 1); -} - -void -odyssey_fillrect(struct odyssey_softc *sc, int x, int y, int w, int h, u_int c) -{ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_BEGIN); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_QUADS); - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_COLOR_3UB); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, c & 0xff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, (c >> 8) & 0xff); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, (c >> 16) & 0xff); - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_VERTEX_2I); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, x); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, y); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_VERTEX_2I); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, x + w); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, y); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_VERTEX_2I); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, x + w); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, y + h); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_VERTEX_2I); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, x); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, y + h); - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_END); - - odyssey_cmd_flush(sc, 1); -} - -int -odyssey_do_cursor(struct rasops_info *ri) -{ - struct odyssey_softc *sc = ri->ri_hw; - struct odyssey_screen *screen = sc->curscr; - int y, x, w, h, fg, bg; - - w = ri->ri_font->fontwidth; - h = ri->ri_font->fontheight; - x = ri->ri_xorigin + ri->ri_ccol * w; - y = ri->ri_yorigin + ri->ri_crow * h; - - ri->ri_ops.unpack_attr(ri, screen->attr, &fg, &bg, NULL); - - odyssey_rop(sc, x, y, w, h, OPENGL_LOGIC_OP_XOR, ri->ri_devcmap[fg]); - odyssey_cmd_flush(sc, 0); - - return 0; -} - -int -odyssey_putchar(void *cookie, int row, int col, u_int uc, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct odyssey_softc *sc = ri->ri_hw; - struct wsdisplay_font *font = ri->ri_font; - int bg, fg, ul, i, j, ci, l; - uint x, y, w, h; - u_int8_t *fontbitmap; - u_int chunk; - - w = ri->ri_font->fontwidth; - h = ri->ri_font->fontheight; - x = ri->ri_xorigin + col * w; - y = ri->ri_yorigin + row * h; - - fontbitmap = (u_int8_t *)(font->data + (uc - font->firstchar) * - ri->ri_fontscale); - ri->ri_ops.unpack_attr(ri, attr, &fg, &bg, &ul); - - /* Handle spaces with a single fillrect. */ - if (uc == ' ') { - odyssey_fillrect(sc, x, y, w, h, ri->ri_devcmap[bg]); - odyssey_cmd_flush(sc, 0); - return 0; - } - - odyssey_fillrect(sc, x, y, w, h, 0xff0000); - - /* Setup pixel painting. */ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010405); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00002400); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_COLOR_3UB); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00011453); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000002); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - odyssey_cmd_flush(sc, 0); - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x2900812f); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_BEGIN); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x0000000a); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0xcf80a92f); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, ieee754_sp(x)); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, ieee754_sp(y)); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, - ieee754_sp(x + font->fontwidth)); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, - ieee754_sp(y + font->fontheight)); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_VERTEX_2I); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00004570); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x0f00104c); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000071); - - for (i = font->fontheight; i != 0; i--) { - - /* Get bitmap for current line. */ - if (font->fontwidth <= 8) - chunk = *fontbitmap; - else - chunk = *(u_int16_t *)fontbitmap; - fontbitmap += font->stride; - - /* Handle underline. */ - if (ul && i == 1) - chunk = 0xffff; - - /* Draw character. */ - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, - 0x00004570); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, - 0x0fd1104c); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, - 0x00000071); - - w = font->fontwidth; - l = 0; - - for (j = 0; j < font->fontwidth; j++) { - - if (l == 0) { - - l = (w > 14 ? 14 : w); - w -= 14; - - /* Number of pixels. */ - bus_space_write_4(sc->iot, sc->ioh, - ODYSSEY_CMD_FIFO, (0x00014011 | - (l << 10))); - - } - - if (font->fontwidth > 8) - ci = (chunk & (1 << (16 - j)) ? fg : bg); - else - ci = (chunk & (1 << (8 - j)) ? fg : bg); - - bus_space_write_4(sc->iot, sc->ioh, - ODYSSEY_CMD_FIFO, ri->ri_devcmap[ci]); - - l--; - } - } - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, OPENGL_END); - odyssey_cmd_flush(sc, 1); - - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x290080d6); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00011453); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00000000); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00010405); - bus_space_write_4(sc->iot, sc->ioh, ODYSSEY_CMD_FIFO, 0x00002000); - odyssey_cmd_flush(sc, 0); - - return 0; -} - -int -odyssey_copycols(void *cookie, int row, int src, int dst, int num) -{ - struct rasops_info *ri = cookie; - struct odyssey_softc *sc = ri->ri_hw; - int i; - - if (src < dst) { - - /* We cannot control copy direction, so copy col by col. */ - for (i = num - 1; i >= 0; i--) - odyssey_copyrect(sc, - ri->ri_xorigin + (src + i) * ri->ri_font->fontwidth, - ri->ri_yorigin + row * ri->ri_font->fontheight, - ri->ri_xorigin + (dst + i) * ri->ri_font->fontwidth, - ri->ri_yorigin + row * ri->ri_font->fontheight, - ri->ri_font->fontwidth, ri->ri_font->fontheight); - - } else { - - odyssey_copyrect(sc, - ri->ri_xorigin + src * ri->ri_font->fontwidth, - ri->ri_yorigin + row * ri->ri_font->fontheight, - ri->ri_xorigin + dst * ri->ri_font->fontwidth, - ri->ri_yorigin + row * ri->ri_font->fontheight, - num * ri->ri_font->fontwidth, ri->ri_font->fontheight); - - } - - odyssey_cmd_flush(sc, 0); - - return 0; -} - -int -odyssey_erasecols(void *cookie, int row, int col, int num, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct odyssey_softc *sc = ri->ri_hw; - int bg, fg; - - ri->ri_ops.unpack_attr(cookie, attr, &fg, &bg, NULL); - - row *= ri->ri_font->fontheight; - col *= ri->ri_font->fontwidth; - num *= ri->ri_font->fontwidth; - - odyssey_fillrect(sc, ri->ri_xorigin + col, ri->ri_yorigin + row, - num, ri->ri_font->fontheight, ri->ri_devcmap[bg]); - odyssey_cmd_flush(sc, 0); - - return 0; -} - -int -odyssey_copyrows(void *cookie, int src, int dst, int num) -{ - struct rasops_info *ri = cookie; - struct odyssey_softc *sc = ri->ri_hw; - int i; - - if (src < dst) { - - /* We cannot control copy direction, so copy row by row. */ - for (i = num - 1; i >= 0; i--) - odyssey_copyrect(sc, ri->ri_xorigin, ri->ri_yorigin + - (src + i) * ri->ri_font->fontheight, - ri->ri_xorigin, ri->ri_yorigin + - (dst + i) * ri->ri_font->fontheight, - ri->ri_emuwidth, ri->ri_font->fontheight); - - } else { - - odyssey_copyrect(sc, ri->ri_xorigin, - ri->ri_yorigin + src * ri->ri_font->fontheight, - ri->ri_xorigin, - ri->ri_yorigin + dst * ri->ri_font->fontheight, - ri->ri_emuwidth, num * ri->ri_font->fontheight); - - } - - odyssey_cmd_flush(sc, 0); - - return 0; -} - -int -odyssey_eraserows(void *cookie, int row, int num, uint32_t attr) -{ - struct rasops_info *ri = cookie; - struct odyssey_softc *sc = ri->ri_hw; - int x, y, w, bg, fg; - - ri->ri_ops.unpack_attr(cookie, attr, &fg, &bg, NULL); - - if ((num == ri->ri_rows) && ISSET(ri->ri_flg, RI_FULLCLEAR)) { - num = ri->ri_height; - x = y = 0; - w = ri->ri_width; - } else { - num *= ri->ri_font->fontheight; - x = ri->ri_xorigin; - y = ri->ri_yorigin + row * ri->ri_font->fontheight; - w = ri->ri_emuwidth; - } - - odyssey_fillrect(sc, x, y, w, num, ri->ri_devcmap[bg]); - odyssey_cmd_flush(sc, 0); - - return 0; -} - -u_int32_t -ieee754_sp(uint v) -{ - u_int8_t exp = 0; - int i = 12; /* 0 <= v < 2048 */ - - /* - * Convert a small integer to IEEE754 single precision floating point: - * - * Sign - 1 bit - * Exponent - 8 bits (with 2^(8-1)-1 = 127 bias) - * Fraction - 23 bits - */ - - /* Determine shift for fraction. */ - while (i && (v & (1 << --i)) == 0); - - if (v != 0) - exp = 127 + i; - - return (exp << 23) | ((v << (23 - i)) & 0x7fffff); -} - -/* - * Console support. - */ - -int -odyssey_cnprobe() -{ - u_int32_t wid, vendor, product; - - /* Probe for Odyssey graphics card. */ - if (xbow_widget_id(console_output.nasid, console_output.widget, - &wid) != 0) - return 0; - - vendor = WIDGET_ID_VENDOR(wid); - product = WIDGET_ID_PRODUCT(wid); - - if (vendor != XBOW_VENDOR_SGI2 || product != XBOW_PRODUCT_SGI2_ODYSSEY) - return 0; - - if (strncmp(bios_graphics, "alive", 5) != 0) - return 0; - - return 1; -} - -int -odyssey_cnattach() -{ - struct odyssey_softc *sc; - struct odyssey_screen *screen; - int rc; - - sc = &odyssey_cons_sc; - screen = &odyssey_consdata; - sc->curscr = screen; - sc->curscr->sc = (void *)sc; - - /* Build bus space accessor. */ - xbow_build_bus_space(&sc->iot_store, console_output.nasid, - console_output.widget); - sc->iot = &sc->iot_store; - - /* Setup bus space mappings. */ - rc = bus_space_map(sc->iot, ODYSSEY_REG_OFFSET, ODYSSEY_REG_SIZE, - BUS_SPACE_MAP_LINEAR, &sc->ioh); - if (rc != 0) - return rc; - - /* Setup hardware and clear screen. */ - odyssey_setup(sc); - odyssey_fillrect(sc, 0, 0, 1280, 1024, 0x000000); - odyssey_cmd_flush(sc, 0); - - /* Set screen defaults. */ - screen->width = 1280; - screen->height = 1024; - screen->depth = 32; - screen->linebytes = screen->width * screen->depth / 8; - - odyssey_init_screen(screen); - - /* - * Attach wsdisplay. - */ - screen->ri.ri_ops.pack_attr(&screen->ri, 0, 0, 0, &screen->attr); - wsdisplay_cnattach(&odyssey_stdscreen, &screen->ri, 0, 0, screen->attr); - - return 0; -} - -int -odyssey_is_console(struct xbow_attach_args *xaa) -{ - return xaa->xaa_nasid == console_output.nasid && - xaa->xaa_widget == console_output.widget; -} diff --git a/sys/arch/sgi/xbow/odysseyreg.h b/sys/arch/sgi/xbow/odysseyreg.h deleted file mode 100644 index 9bc36378366..00000000000 --- a/sys/arch/sgi/xbow/odysseyreg.h +++ /dev/null @@ -1,43 +0,0 @@ -/* $OpenBSD: odysseyreg.h,v 1.2 2012/04/16 22:17:16 miod Exp $ */ -/* - * Copyright (c) 2009, 2010 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * Register details for the SGI VPro (aka Odyssey) Graphics Card. - */ - -#define ODYSSEY_REG_OFFSET 0x00000000 -#define ODYSSEY_REG_SIZE 0x00410000 - -#define ODYSSEY_STATUS 0x00001064 -#define ODYSSEY_STATUS_CMD_FIFO_HIGH 0x00008000 -#define ODYSSEY_STATUS_CMD_FIFO_LOW 0x00020000 -#define ODYSSEY_DBE_STATUS 0x0000106c - -#define ODYSSEY_CMD_FIFO 0x00110000 -#define ODYSSEY_DATA_FIFO 0x00400000 - -/* - * OpenGL Commands. - */ - -#define OPENGL_BEGIN 0x00014400 -#define OPENGL_END 0x00014001 -#define OPENGL_LOGIC_OP 0x00010422 -#define OPENGL_VERTEX_2I 0x8080c800 -#define OPENGL_COLOR_3UB 0xc580cc08 - -#define OPENGL_QUADS 0x00000007 diff --git a/sys/arch/sgi/xbow/odysseyvar.h b/sys/arch/sgi/xbow/odysseyvar.h deleted file mode 100644 index 7e331156442..00000000000 --- a/sys/arch/sgi/xbow/odysseyvar.h +++ /dev/null @@ -1,19 +0,0 @@ -/* $OpenBSD: odysseyvar.h,v 1.2 2010/04/06 19:12:34 miod Exp $ */ -/* - * Copyright (c) 2010 Joel Sing <jsing@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -int odyssey_cnprobe(void); -int odyssey_cnattach(void); diff --git a/sys/arch/sgi/xbow/widget.h b/sys/arch/sgi/xbow/widget.h deleted file mode 100644 index c88666066e0..00000000000 --- a/sys/arch/sgi/xbow/widget.h +++ /dev/null @@ -1,79 +0,0 @@ -/* $OpenBSD: widget.h,v 1.2 2010/04/06 19:02:57 miod Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#ifndef _WIDGET_H_ -#define _WIDGET_H_ - -/* - * Common Widget Registers. Every widget provides them. - * - * Registers are 32 or 64 bit wide (depending on the particular widget - * or register) on 64 bit boundaries. - * The widget_{read,write}_[48] functions below hide the addressing - * games required to perform 32 bit accesses. - */ - -#define WIDGET_ID 0x0000 -#define WIDGET_ID_REV_MASK 0xf0000000 -#define WIDGET_ID_REV_SHIFT 28 -#define WIDGET_ID_REV(wid) \ - (((wid) & WIDGET_ID_REV_MASK) >> WIDGET_ID_REV_SHIFT) -#define WIDGET_ID_PRODUCT_MASK 0x0ffff000 -#define WIDGET_ID_PRODUCT_SHIFT 12 -#define WIDGET_ID_PRODUCT(wid) \ - (((wid) & WIDGET_ID_PRODUCT_MASK) >> WIDGET_ID_PRODUCT_SHIFT) -#define WIDGET_ID_VENDOR_MASK 0x00000ffe -#define WIDGET_ID_VENDOR_SHIFT 1 -#define WIDGET_ID_VENDOR(wid) \ - (((wid) & WIDGET_ID_VENDOR_MASK) >> WIDGET_ID_VENDOR_SHIFT) -#define WIDGET_STATUS 0x0008 -#define WIDGET_ERR_ADDR_UPPER 0x0010 -#define WIDGET_ERR_ADDR_LOWER 0x0018 -#define WIDGET_CONTROL 0x0020 -#define WIDGET_REQ_TIMEOUT 0x0028 -#define WIDGET_INTDEST_ADDR_UPPER 0x0030 -#define WIDGET_INTDEST_ADDR_LOWER 0x0038 -#define WIDGET_ERR_CMD_WORD 0x0040 -#define WIDGET_LLP_CFG 0x0048 -#define WIDGET_TFLUSH 0x0050 - -/* - * Crossbow Specific Registers. - */ - -#define XBOW_WID_ARB_RELOAD 0x0058 -#define XBOW_PERFCNTR_A 0x0060 -#define XBOW_PERFCNTR_B 0x0068 -#define XBOW_NIC 0x0070 -#define XBOW_WIDGET_LINK(w) (0x0100 + ((w) & 7) * 0x0040) - -/* - * Crossbow Per-widget ``Link'' Register Set. - */ -#define WIDGET_LINK_IBF 0x0000 -#define WIDGET_LINK_CONTROL 0x0008 -#define WIDGET_CONTROL_ALIVE 0x80000000 -#define WIDGET_LINK_STATUS 0x0010 -#define WIDGET_STATUS_ALIVE 0x80000000 -#define WIDGET_LINK_ARB_UPPER 0x0018 -#define WIDGET_LINK_ARB_LOWER 0x0020 -#define WIDGET_LINK_STATUS_CLEAR 0x0028 -#define WIDGET_LINK_RESET 0x0030 -#define WIDGET_LINK_AUX_STATUS 0x0038 - -#endif /* _WIDGET_H_ */ diff --git a/sys/arch/sgi/xbow/xbow.c b/sys/arch/sgi/xbow/xbow.c deleted file mode 100644 index 8545c87c266..00000000000 --- a/sys/arch/sgi/xbow/xbow.c +++ /dev/null @@ -1,727 +0,0 @@ -/* $OpenBSD: xbow.c,v 1.36 2021/03/11 11:17:00 jsg Exp $ */ - -/* - * Copyright (c) 2008, 2009, 2011 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ -/* - * Copyright (c) 2004 Opsycon AB (www.opsycon.se) - * - * 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 ``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 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. - * - */ - -/* - * XBOW is the mux between two nodes and XIO. - * - * A Crossbow (XBOW) connects two nodeboards via their respective - * HUB to up to six different I/O controllers in XIO slots. In a - * multiprocessor system all processors have access to the XIO - * slots but may need to pass traffic via the routers. - * - * To each XIO port on the XBOW a XIO interface is attached. Such - * interfaces can be for example PCI bridges which then add another - * level to the hierarchy. - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/conf.h> -#include <sys/malloc.h> -#include <sys/device.h> -#include <sys/atomic.h> - -#include <mips64/archtype.h> - -#include <machine/autoconf.h> -#include <machine/intr.h> -#include <machine/mnode.h> - -#include <sgi/xbow/hub.h> -#include <sgi/xbow/widget.h> -#include <sgi/xbow/xbow.h> - -#include <sgi/xbow/xbowdevs.h> -#include <sgi/xbow/xbowdevs_data.h> - -int xbowmatch(struct device *, void *, void *); -void xbowattach(struct device *, struct device *, void *); -int xbowprint(void *, const char *); -int xbowsubmatch(struct device *, void *, void *); -int xbow_attach_widget(struct device *, int16_t, int, - int (*)(struct device *, void *, void *), cfprint_t); - -int xbow_kl_search_brd(lboard_t *, void *); -int xbow_kl_search_mplane(klinfo_t *, void *); - -uint32_t xbow_read_4(bus_space_tag_t, bus_space_handle_t, bus_size_t); -uint64_t xbow_read_8(bus_space_tag_t, bus_space_handle_t, bus_size_t); -void xbow_write_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, uint32_t); -void xbow_write_8(bus_space_tag_t, bus_space_handle_t, bus_size_t, uint64_t); -void xbow_read_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void xbow_write_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -void xbow_read_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void xbow_write_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); - -void xbow_space_unmap(bus_space_tag_t, bus_space_handle_t, bus_size_t); -int xbow_space_region(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, bus_space_handle_t *); -void *xbow_space_vaddr(bus_space_tag_t, bus_space_handle_t); -void xbow_space_barrier(bus_space_tag_t, bus_space_handle_t, bus_size_t, - bus_size_t, int); - -const struct xbow_product *xbow_identify(uint32_t, uint32_t); - -struct xbow_softc { - struct device sc_dev; - int16_t sc_nasid; -}; - -const struct cfattach xbow_ca = { - sizeof(struct xbow_softc), xbowmatch, xbowattach -}; - -struct cfdriver xbow_cd = { - NULL, "xbow", DV_DULL -}; - -static const bus_space_t xbowbus_tag = { - (bus_addr_t)0, /* will be modified in widgets bus_space_t */ - NULL, - xbow_read_1, - xbow_write_1, - xbow_read_2, - xbow_write_2, - xbow_read_4, - xbow_write_4, - xbow_read_8, - xbow_write_8, - xbow_read_raw_2, - xbow_write_raw_2, - xbow_read_raw_4, - xbow_write_raw_4, - xbow_read_raw_8, - xbow_write_raw_8, - xbow_space_map, - xbow_space_unmap, - xbow_space_region, - xbow_space_vaddr, - xbow_space_barrier -}; - -/* - * Function pointers to hide widget discovery and mapping differences across - * systems. - */ -paddr_t (*xbow_widget_base)(int16_t, u_int); -paddr_t (*xbow_widget_map)(int16_t, u_int, bus_addr_t *, bus_size_t *); - -int (*xbow_widget_id)(int16_t, u_int, uint32_t *); - -/* - * Attachment glue. - */ - -int -xbowmatch(struct device *parent, void *match, void *aux) -{ - struct mainbus_attach_args *maa = aux; - - if (strcmp(maa->maa_name, xbow_cd.cd_name) != 0) - return (0); - - switch (sys_config.system_type) { - case SGI_IP27: - case SGI_IP35: - case SGI_OCTANE: - return (1); - default: - return (0); - } -} - -const struct xbow_product * -xbow_identify(uint32_t vendor, uint32_t product) -{ - const struct xbow_product *p; - - for (p = xbow_products; p->productname != NULL; p++) - if (p->vendor == vendor && p->product == product) - return p; - - return NULL; -} - -int -xbowprint(void *aux, const char *pnp) -{ - struct xbow_attach_args *xaa = aux; - const struct xbow_product *p; - - p = xbow_identify(xaa->xaa_vendor, xaa->xaa_product); - - if (pnp != NULL) { - if (p != NULL) - printf("\"%s\"", p->productname); - else - printf("vendor %x product %x", - xaa->xaa_vendor, xaa->xaa_product); - printf(" revision %d at %s", - xaa->xaa_revision, pnp); - } - printf(" widget %d", xaa->xaa_widget); - if (pnp == NULL) { - if (p != NULL) - printf(": %s", p->productname); - } - - return (UNCONF); -} - -int -xbowsubmatch(struct device *parent, void *vcf, void *aux) -{ - struct xbow_attach_args *xaa = aux; - struct cfdata *cf = vcf; - - if (cf->cf_loc[0] != -1 && cf->cf_loc[0] != xaa->xaa_widget) - return 0; - if (cf->cf_loc[1] != -1 && cf->cf_loc[1] != xaa->xaa_vendor) - return 0; - if (cf->cf_loc[2] != -1 && cf->cf_loc[2] != xaa->xaa_product) - return 0; - - return (*cf->cf_attach->ca_match)(parent, vcf, aux); -} - -/* - * Widget probe order for various components - */ - -#ifdef TGT_OCTANE -/* Octane: probe Heart first, then onboard devices, then other slots */ -const uint8_t xbow_probe_octane[] = - { 0x08, 0x0f, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0 }; -#endif -#ifdef TGT_ORIGIN -/* Origin 200: probe onboard devices, and there is nothing more */ -const uint8_t xbow_probe_singlebridge[] = - { 0x08, 0 }; -/* Base I/O board: probe onboard devices, then other slots in ascending order */ -const uint8_t xbow_probe_baseio[] = - { 0x0f, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0 }; -/* I-Brick: probe PCI buses first (starting with the onboard devices) */ -const uint8_t xbow_probe_ibrick[] = - { 0x0f, 0x0e, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0 }; -/* P-Brick: all widgets are PCI buses, probe in recommended order */ -const uint8_t xbow_probe_pbrick[] = - { 0x09, 0x08, 0x0f, 0x0e, 0x0c, 0x0d, 0x0a, 0x0b, 0 }; -/* X-Brick: all widgets are XIO devices, probe in recommended order */ -const uint8_t xbow_probe_xbrick[] = - { 0x08, 0x09, 0x0c, 0x0d, 0x0a, 0x0b, 0x0e, 0x0f, 0 }; -#endif - -/* - * Structures used to carry information between KL and attachment code. - */ - -struct xbow_config { - int valid; - int widgets[WIDGET_MAX + 1 - WIDGET_MIN]; -}; - -struct xbow_kl_config { - const uint8_t *probe_order; - struct xbow_config *cfg; -}; - -void -xbowattach(struct device *parent, struct device *self, void *aux) -{ - struct xbow_softc *sc = (struct xbow_softc *)self; - struct mainbus_attach_args *maa = aux; - int16_t nasid = maa->maa_nasid; - uint32_t wid, vendor, product; - const struct xbow_product *p; -#ifdef TGT_ORIGIN - struct xbow_config cfg; -#endif - struct xbow_kl_config klcfg; - uint widget; - - sc->sc_nasid = nasid; - - /* - * This assumes widget 0 is the XBow itself (or an XXBow). - * If it isn't - feel free to haunt my bedroom at night. - */ - if (xbow_widget_id(nasid, 0, &wid) != 0) - panic("no xbow"); - vendor = WIDGET_ID_VENDOR(wid); - product = WIDGET_ID_PRODUCT(wid); - p = xbow_identify(vendor, product); - if (p == NULL) - printf(": unknown xbow (vendor %x product %x)", - vendor, product); - else - printf(": %s", p->productname); - printf(" revision %d\n", WIDGET_ID_REV(wid)); - - switch (sys_config.system_type) { - default: -#ifdef TGT_ORIGIN - memset(&cfg, 0, sizeof cfg); - klcfg.cfg = &cfg; - - /* - * If widget 0 reports itself as a bridge, this is not a - * complete XBow, but only a limited topology. This is - * found on at least the Origin 200. - */ - if (vendor == XBOW_VENDOR_SGI4 && - product == XBOW_PRODUCT_SGI4_BRIDGE) { - klcfg.probe_order = xbow_probe_singlebridge; - } else { - /* - * Get crossbow information from the KL configuration. - */ - klcfg.probe_order = NULL; - kl_scan_node(nasid, KLBRD_ANY, xbow_kl_search_brd, - &klcfg); - if (klcfg.probe_order == NULL) - klcfg.probe_order = xbow_probe_baseio; - - /* should not happen, but I can't help being paranoid */ - if (cfg.valid == 0) { - printf("%s: no hub\n", self->dv_xname); - return; - } - } - break; -#endif -#ifdef TGT_OCTANE - case SGI_OCTANE: - klcfg.probe_order = xbow_probe_octane; - break; -#endif - } - - for (; *klcfg.probe_order != 0; klcfg.probe_order++) { - widget = *klcfg.probe_order; -#ifdef TGT_ORIGIN - if (cfg.valid != 0 && - !ISSET(cfg.widgets[widget - WIDGET_MIN], XBOW_PORT_ENABLE)) - continue; -#endif - (void)xbow_attach_widget(self, nasid, widget, xbowsubmatch, - xbowprint); - } -} - -int -xbow_attach_widget(struct device *self, int16_t nasid, int widget, - int (*sm)(struct device *, void *, void *), cfprint_t print) -{ - struct xbow_attach_args xaa; - uint32_t wid; - struct mips_bus_space bs; - int rc; - - if ((rc = xbow_widget_id(nasid, widget, &wid)) != 0) - return rc; - - /* - * Build a bus_space_t suitable for this widget. - */ - xbow_build_bus_space(&bs, nasid, widget); - - xaa.xaa_nasid = nasid; - xaa.xaa_widget = widget; - xaa.xaa_vendor = WIDGET_ID_VENDOR(wid); - xaa.xaa_product = WIDGET_ID_PRODUCT(wid); - xaa.xaa_revision = WIDGET_ID_REV(wid); - xaa.xaa_iot = &bs; - - if (config_found_sm(self, &xaa, print, sm) == NULL) - return ENOENT; - - return 0; -} - -#ifdef TGT_ORIGIN - -/* - * These two functions try to figure out the configuration of the XBow - * on this node. - * - * We are looking for two pieces of information: - * - the Hub widget, to which memory is attached and interrupts are routed. - * - what kind of Brick we are. - * - * The first information can be obtained easily by looking for a MPLANE type - * board. However there is no easy way to figure the second part, except for - * checking what kind of boards are reported. - * - * A BaseIO board will report itself once, as a single widget. Bricks, on the - * other hand, appear for each of the widgets they provide. - */ - -int -xbow_kl_search_brd(lboard_t *brd, void *arg) -{ - struct xbow_kl_config *cfg = arg; - - switch (brd->brd_type & IP27_BC_MASK) { - case IP27_BC_MPLANE: - if (cfg->cfg->valid == 0) - kl_scan_board(brd, KLSTRUCT_XBOW, xbow_kl_search_mplane, - cfg->cfg); - break; - case IP27_BC_IO: - if (cfg->probe_order == NULL) - cfg->probe_order = xbow_probe_baseio; - break; - case IP27_BC_BRICK: - if (cfg->probe_order == NULL) - switch (brd->brd_type) { - case IP27_BRD_IBRICK: - case IP27_BRD_IXBRICK: - cfg->probe_order = xbow_probe_ibrick; - break; - case IP27_BRD_PBRICK: - case IP27_BRD_PXBRICK: - cfg->probe_order = xbow_probe_pbrick; - break; - case IP27_BRD_XBRICK: - cfg->probe_order = xbow_probe_xbrick; - break; - default: - /* other brick */ - break; - } - break; - } - - if (cfg->cfg->valid != 0 && cfg->probe_order != NULL) - return 1; /* stop enumeration */ - - return 0; -} - -int -xbow_kl_search_mplane(klinfo_t *c, void *arg) -{ - klxbow_t *xbow = (klxbow_t *)c; - struct xbow_config *cfg = arg; - uint w; - - cfg->valid = 1; - for (w = WIDGET_MIN; w <= WIDGET_MAX; w++) - cfg->widgets[w - WIDGET_MIN] = - xbow->xbow_port_info[w - WIDGET_MIN].port_flag; - - return 1; -} - -#endif - -/* - * Bus access primitives. - */ - -void -xbow_build_bus_space(struct mips_bus_space *bs, int nasid, int widget) -{ - bcopy(&xbowbus_tag, bs, sizeof (*bs)); - bs->bus_base = (*xbow_widget_base)(nasid, widget); -} - -uint8_t -xbow_read_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint8_t *)(h + o); -} - -uint16_t -xbow_read_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint16_t *)(h + o); -} - -uint32_t -xbow_read_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint32_t *)(h + o); -} - -uint64_t -xbow_read_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint64_t *)(h + o); -} - -void -xbow_write_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint8_t v) -{ - *(volatile uint8_t *)(h + o) = v; -} - -void -xbow_write_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint16_t v) -{ - *(volatile uint16_t *)(h + o) = v; -} - -void -xbow_write_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint32_t v) -{ - *(volatile uint32_t *)(h + o) = v; -} - -void -xbow_write_8(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, uint64_t v) -{ - *(volatile uint64_t *)(h + o) = v; -} - -void -xbow_read_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)(h + o); - len >>= 1; - while (len-- != 0) { - *(uint16_t *)buf = *addr; - buf += 2; - } -} - -void -xbow_write_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)(h + o); - len >>= 1; - while (len-- != 0) { - *addr = *(uint16_t *)buf; - buf += 2; - } -} - -void -xbow_read_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *(uint32_t *)buf = *addr; - buf += 4; - } -} - -void -xbow_write_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *addr = *(uint32_t *)buf; - buf += 4; - } -} - -void -xbow_read_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *(uint64_t *)buf = *addr; - buf += 8; - } -} - -void -xbow_write_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *addr = *(uint64_t *)buf; - buf += 8; - } -} - -int -xbow_space_map(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ - bus_addr_t bpa; - - bpa = t->bus_base + offs; - -#ifdef DIAGNOSTIC - /* check that this does not overflow the window */ - if (((bpa + size - 1) >> 24) != (t->bus_base >> 24)) - return (EINVAL); -#endif - - *bshp = bpa; - return 0; -} - -void -xbow_space_unmap(bus_space_tag_t t, bus_space_handle_t bsh, bus_size_t size) -{ -} - -int -xbow_space_region(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ -#ifdef DIAGNOSTIC - bus_addr_t bpa; - - bpa = (bus_addr_t)bsh - t->bus_base; - /* check that this does not overflow the window */ - if (((bpa + offset) >> 24) != (t->bus_base >> 24)) - return (EINVAL); -#endif - - *nbshp = bsh + offset; - return 0; -} - -void * -xbow_space_vaddr(bus_space_tag_t t, bus_space_handle_t h) -{ - return (void *)h; -} - -void -xbow_space_barrier(bus_space_tag_t t, bus_space_handle_t h, bus_size_t offs, - bus_size_t len, int flags) -{ - mips_sync(); -} - -/* - * Interrupt handling code. - * - * Interrupt handling should be done at the Heart/Hub driver level, we only - * act as a proxy here. - * - * Note that, for the time being, interrupt handling is implicitly done at - * the master nasid; other nodes do not handle interrupts. - */ - -uint64_t xbow_intr_address; - -int (*xbow_intr_widget_intr_register)(int, int, int *) = NULL; -int (*xbow_intr_widget_intr_establish)(int (*)(void *), void *, int, int, - const char *, struct intrhand *) = NULL; -void (*xbow_intr_widget_intr_disestablish)(int) = NULL; -void (*xbow_intr_widget_intr_set)(int) = NULL; -void (*xbow_intr_widget_intr_clear)(int) = NULL; - -int -xbow_intr_register(int widget, int level, int *intrbit) -{ - if (xbow_intr_widget_intr_register == NULL) - return EINVAL; - - return (*xbow_intr_widget_intr_register)(widget, level, intrbit); -} - -int -xbow_intr_establish(int (*func)(void *), void *arg, int intrbit, int level, - const char *name, struct intrhand *ihstore) -{ - if (xbow_intr_widget_intr_establish == NULL) - return EINVAL; - - return (*xbow_intr_widget_intr_establish)(func, arg, intrbit, level, - name, ihstore); -} - -void -xbow_intr_disestablish(int intrbit) -{ - if (xbow_intr_widget_intr_disestablish == NULL) - return; - - (*xbow_intr_widget_intr_disestablish)(intrbit); -} - -void -xbow_intr_clear(int intrbit) -{ - if (xbow_intr_widget_intr_clear == NULL) - return; - - (*xbow_intr_widget_intr_clear)(intrbit); -} - -void -xbow_intr_set(int intrbit) -{ - if (xbow_intr_widget_intr_set == NULL) - return; - - (*xbow_intr_widget_intr_set)(intrbit); -} - -/* - * Widget mapping code. - */ - -paddr_t -xbow_widget_map_space(struct device *dev, u_int widget, bus_addr_t *offs, - bus_size_t *len) -{ - struct xbow_softc *sc = (struct xbow_softc *)dev; - - if (xbow_widget_map == NULL) - return 0UL; - - return (*xbow_widget_map)(sc->sc_nasid, widget, offs, len); -} diff --git a/sys/arch/sgi/xbow/xbow.h b/sys/arch/sgi/xbow/xbow.h deleted file mode 100644 index 6d921cb2d3b..00000000000 --- a/sys/arch/sgi/xbow/xbow.h +++ /dev/null @@ -1,132 +0,0 @@ -/* $OpenBSD: xbow.h,v 1.12 2011/04/17 17:44:24 miod Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#ifndef _XBOW_H_ -#define _XBOW_H_ - -/* - * Devices connected to the XBow are called ``widgets'' and are - * identified by a common widget memory area at the beginning of their - * memory space. - * - * Each widget has its own memory space. The lowest 16MB are always - * accessible as a so-called ``short window''. Other `views' of the - * widget are possible, depending on the system (the whole widget - * address space is always visible on Octane, while Origin family - * systems can only map a few ``large windows'', which are a scarce - * resource). - * - * Apart from the crossbow itself being widget #0, the widgets are divided - * in two groups: widgets #8 to #b are the ``upper'' widgets, while widgets - * #c to #f are the ``lower'' widgets. - * - * Widgets are uniquely identified with their widget number on the XBow - * bus. However, the way they are mapped and accessed will depend on the - * processor (well, the processor board node) requesting access. Hence the - * two parameters needed to map a widget. - */ - -extern paddr_t (*xbow_widget_base)(int16_t, u_int); -extern paddr_t (*xbow_widget_map)(int16_t, u_int, bus_addr_t *, bus_size_t *); - -extern int (*xbow_widget_id)(int16_t, u_int, uint32_t *); - -extern int (*xbow_intr_widget_intr_register)(int, int, int *); -extern int (*xbow_intr_widget_intr_establish)(int (*)(void *), void *, - int, int, const char *, struct intrhand *); -extern void (*xbow_intr_widget_intr_disestablish)(int); - -extern void (*xbow_intr_widget_intr_set)(int); -extern void (*xbow_intr_widget_intr_clear)(int); - -/* - * Valid widget values - */ - -#define WIDGET_MIN 8 -#define WIDGET_MAX 15 - -/* interrupt register address on the master hub */ -extern uint64_t xbow_intr_address; - -struct xbow_attach_args { - int16_t xaa_nasid; - int xaa_widget; - - uint32_t xaa_vendor; - uint32_t xaa_product; - uint32_t xaa_revision; - - bus_space_tag_t xaa_iot; - /* - * WARNING! xaa_iot points to memory allocated on the stack, - * drivers need to make a copy of it. - */ -}; - -void xbow_build_bus_space(struct mips_bus_space *, int, int); -int xbow_intr_register(int, int, int *); -int xbow_intr_establish(int (*)(void *), void *, int, int, const char *, - struct intrhand *); -void xbow_intr_disestablish(int); -void xbow_intr_clear(int); -void xbow_intr_set(int); - -paddr_t xbow_widget_map_space(struct device *, u_int, - bus_addr_t *, bus_size_t *); - -int xbow_space_map(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -uint8_t xbow_read_1(bus_space_tag_t, bus_space_handle_t, bus_size_t); -uint16_t xbow_read_2(bus_space_tag_t, bus_space_handle_t, bus_size_t); -void xbow_read_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void xbow_write_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, uint8_t); -void xbow_write_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, - uint16_t); -void xbow_write_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); - -/* - * Widget register access routines hiding addressing games depending upon - * the access width. - */ -static __inline__ uint32_t -widget_read_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a) -{ - return bus_space_read_4(t, h, a | 4); -} -static __inline__ uint64_t -widget_read_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a) -{ - return bus_space_read_8(t, h, a); -} -static __inline__ void -widget_write_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a, - uint32_t v) -{ - bus_space_write_4(t, h, a | 4, v); -} -static __inline__ void -widget_write_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a, - uint64_t v) -{ - bus_space_write_8(t, h, a, v); -} - -#endif /* _XBOW_H_ */ diff --git a/sys/arch/sgi/xbow/xbowdevs b/sys/arch/sgi/xbow/xbowdevs deleted file mode 100644 index be568290122..00000000000 --- a/sys/arch/sgi/xbow/xbowdevs +++ /dev/null @@ -1,80 +0,0 @@ -$OpenBSD: xbowdevs,v 1.6 2009/10/15 23:42:43 miod Exp $ -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -vendor SGI 0x0000 -vendor SGI2 0x0023 -vendor SGI3 0x0024 -vendor SGI4 0x0036 -vendor SGI5 0x02aa - -/* - * List of known products. Grouped by type. - */ - -/* - * Crossbows - */ - -product SGI XBOW 0x0000 XBow -product SGI XXBOW 0xd000 XXBow -product SGI PXBOW 0xd100 PXBow - -/* - * Frame buffers and graphics related devices - */ - -product SGI5 IMPACT 0xc003 ImpactSR -product SGI2 ODYSSEY 0xc013 Odyssey -product SGI5 KONA 0xc102 Kona -product SGI3 TPU 0xc202 TPU - -/* - * Non-XIO bus bridges - */ - -product SGI4 BRIDGE 0xc002 Bridge -product SGI3 XBRIDGE 0xd002 XBridge -/* - * PIC is really a single chip but with two widgets headers, and 4 PCI-X - * slots per widget. - * The second widget register set uses 0xd112 as the product id. - */ -product SGI3 PIC 0xd102 PIC -/* - * TIO apparently is a next-generation XIO framework; TIO:CP being a TIO - * variant of PIC with two PCI-X buses, and TIO:CA an AGP bridge. - * Unlike PIC, the two heads of TIO:CP would appear as two distinct TIO - * widgets. - * TIO widgets are supposedly only found on SN2 systems onwards (i.e. - * ia64-based Altix systems), but in case there is a way to connect TIO - * nodes to XIO nodes, better identify them properly. - */ -product SGI3 TIOCP0 0xe000 TIO:CP -product SGI3 TIOCP1 0xe010 TIO:CP -product SGI3 TIOCA 0xe020 TIO:CA - -/* - * Octane HEART memory and interrupt controller - */ -product SGI4 HEART 0xc001 Heart - -/* - * Miscellaneous widgets - */ - -product SGI4 HUB 0xc101 Hub -product SGI4 BEDROCK 0xc110 Bedrock diff --git a/sys/arch/sgi/xbow/xbowdevs.h b/sys/arch/sgi/xbow/xbowdevs.h deleted file mode 100644 index c2d6b3a4189..00000000000 --- a/sys/arch/sgi/xbow/xbowdevs.h +++ /dev/null @@ -1,85 +0,0 @@ -/* - * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT. - * - * generated from: - * OpenBSD: xbowdevs,v 1.6 2009/10/15 23:42:43 miod Exp - */ -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#define XBOW_VENDOR_SGI 0x0000 -#define XBOW_VENDOR_SGI2 0x0023 -#define XBOW_VENDOR_SGI3 0x0024 -#define XBOW_VENDOR_SGI4 0x0036 -#define XBOW_VENDOR_SGI5 0x02aa - -/* - * List of known products. Grouped by type. - */ - -/* - * Crossbows - */ - -#define XBOW_PRODUCT_SGI_XBOW 0x0000 /* XBow */ -#define XBOW_PRODUCT_SGI_XXBOW 0xd000 /* XXBow */ -#define XBOW_PRODUCT_SGI_PXBOW 0xd100 /* PXBow */ - -/* - * Frame buffers and graphics related devices - */ - -#define XBOW_PRODUCT_SGI5_IMPACT 0xc003 /* ImpactSR */ -#define XBOW_PRODUCT_SGI2_ODYSSEY 0xc013 /* Odyssey */ -#define XBOW_PRODUCT_SGI5_KONA 0xc102 /* Kona */ -#define XBOW_PRODUCT_SGI3_TPU 0xc202 /* TPU */ - -/* - * Non-XIO bus bridges - */ - -#define XBOW_PRODUCT_SGI4_BRIDGE 0xc002 /* Bridge */ -#define XBOW_PRODUCT_SGI3_XBRIDGE 0xd002 /* XBridge */ -/* - * PIC is really a single chip but with two widgets headers, and 4 PCI-X - * slots per widget. - * The second widget register set uses 0xd112 as the product id. - */ -#define XBOW_PRODUCT_SGI3_PIC 0xd102 /* PIC */ -/* - * TIO apparently is a next-generation XIO framework; TIO:CP being a TIO - * variant of PIC with two PCI-X buses, and TIO:CA an AGP bridge. - * Unlike PIC, the two heads of TIO:CP would appear as two distinct TIO - * widgets. - * TIO widgets are supposedly only found on SN2 systems onwards (i.e. - * ia64-based Altix systems), but in case there is a way to connect TIO - * nodes to XIO nodes, better identify them properly. - */ -#define XBOW_PRODUCT_SGI3_TIOCP0 0xe000 /* TIO:CP */ -#define XBOW_PRODUCT_SGI3_TIOCP1 0xe010 /* TIO:CP */ -#define XBOW_PRODUCT_SGI3_TIOCA 0xe020 /* TIO:CA */ - -/* - * Octane HEART memory and interrupt controller - */ -#define XBOW_PRODUCT_SGI4_HEART 0xc001 /* Heart */ - -/* - * Miscellaneous widgets - */ - -#define XBOW_PRODUCT_SGI4_HUB 0xc101 /* Hub */ -#define XBOW_PRODUCT_SGI4_BEDROCK 0xc110 /* Bedrock */ diff --git a/sys/arch/sgi/xbow/xbowdevs_data.h b/sys/arch/sgi/xbow/xbowdevs_data.h deleted file mode 100644 index a6553a06856..00000000000 --- a/sys/arch/sgi/xbow/xbowdevs_data.h +++ /dev/null @@ -1,99 +0,0 @@ -/* - * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT. - * - * generated from: - * OpenBSD: xbowdevs,v 1.6 2009/10/15 23:42:43 miod Exp - */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - - -/* Descriptions of known devices. */ -struct xbow_product { - uint32_t vendor; - uint32_t product; - const char *productname; -}; - -static const struct xbow_product xbow_products[] = { - { - XBOW_VENDOR_SGI, XBOW_PRODUCT_SGI_XBOW, - "XBow", - }, - { - XBOW_VENDOR_SGI, XBOW_PRODUCT_SGI_XXBOW, - "XXBow", - }, - { - XBOW_VENDOR_SGI, XBOW_PRODUCT_SGI_PXBOW, - "PXBow", - }, - { - XBOW_VENDOR_SGI5, XBOW_PRODUCT_SGI5_IMPACT, - "ImpactSR", - }, - { - XBOW_VENDOR_SGI2, XBOW_PRODUCT_SGI2_ODYSSEY, - "Odyssey", - }, - { - XBOW_VENDOR_SGI5, XBOW_PRODUCT_SGI5_KONA, - "Kona", - }, - { - XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_TPU, - "TPU", - }, - { - XBOW_VENDOR_SGI4, XBOW_PRODUCT_SGI4_BRIDGE, - "Bridge", - }, - { - XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_XBRIDGE, - "XBridge", - }, - { - XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_PIC, - "PIC", - }, - { - XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_TIOCP0, - "TIO:CP", - }, - { - XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_TIOCP1, - "TIO:CP", - }, - { - XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_TIOCA, - "TIO:CA", - }, - { - XBOW_VENDOR_SGI4, XBOW_PRODUCT_SGI4_HEART, - "Heart", - }, - { - XBOW_VENDOR_SGI4, XBOW_PRODUCT_SGI4_HUB, - "Hub", - }, - { - XBOW_VENDOR_SGI4, XBOW_PRODUCT_SGI4_BEDROCK, - "Bedrock", - }, - { 0, 0, NULL, } -}; - diff --git a/sys/arch/sgi/xbow/xbridge.c b/sys/arch/sgi/xbow/xbridge.c deleted file mode 100644 index 3782fd740b7..00000000000 --- a/sys/arch/sgi/xbow/xbridge.c +++ /dev/null @@ -1,3596 +0,0 @@ -/* $OpenBSD: xbridge.c,v 1.104 2021/03/21 14:18:37 visa Exp $ */ - -/* - * Copyright (c) 2008, 2009, 2011 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * XBow Bridge (as well as XBridge and PIC) Widget driver. - */ - -/* - * IMPORTANT AUTHOR'S NOTE: I did not write any of this code under the - * influence of drugs. Looking back at that particular piece of hardware, - * I wonder if this hasn't been a terrible mistake. - */ - -/* - - xbridge 101 - =========== - - There are three ASIC using this model: - - - Bridge, used on Octane and maybe early Origin 200 and 2000 systems. - - XBridge, used on later Origin 200/2000 and Origin 300/3000 systems. - - PIC, used on Origin 350/3500 systems. - - (for the record, Fuel is Origin 300 like and Tezro is Origin 350 like). - - Bridge and XBridge each appear as a single widget, supporting 8 PCI devices, - while PIC appears as two contiguous widgets, each supporting 2 PCI-X devices. - -- - address space - - Each widget has a 36-bit address space. xbridge widgets only use 33 bits - though. - - On Octane systems, the whole 36 bit address space is fully available. On - all other systems, the low 16MB (24 bit) address space is always available, - and access to arbitrary areas of the address space can be achieved by - programming the Crossbow's IOTTE (I/O Translation Table Entries). - - IMPORTANT! there is a limited number of IOTTE per Crossbow: 7, of which the - seventh is used to workaround a hardware bug, leaving only 6 entries - available across all widgets. - - Each IOTTE opens a contiguous window of 28 or 29 bits, depending on the - particular system model and configuration. On Origin 300/3000 and 350/3500, - this will always be 29 bit (512MB), while on Origin 200/2000 systems, this - depends on the ``M mode vs N mode'' configuration. Most systems run in M - mode (which is the default) which also allows for 29 bit; systems in N mode - (allowing more than 64 nodes to be connected) can only provide 28 bit IOTTE - windows (256MB). - - The widget address space is as follows: - - offset size description - 0##0000##0000 0##0003##0000 registers - 0##4000##0000 0##4000##0000 PCI memory space - 1##0000##0000 1##0000##0000 PCI I/O space - - Note the PCI memory space is limited to 30 bit; this is supposedly hardware - enforced, i.e. one may set the top two bits of 32-bit memory BAR and they - would be ignored. The xbridge driver doesn't try this though (-: - - IMPORTANT! On Bridge (not XBridge) revision up to 3, the I/O space is not - available (apparently this would be because of a hardware issue in the - byteswap logic, causing it to return unpredictable values when accessing - this address range). - -- - PCI resource mapping - - Each BAR value is an offset within the memory or I/O space (with the memory - space being limited to 30 bits, or 1GB), *EXCEPT* when the value fits in one - of the ``devio'' slots. - - So now is a good time to introduce the devio. - - There are 8 devio registers, one per device; these registers contain various - device-global flags (such as byte swapping and coherency), as well as the - location of a ``devio window'' in one of the address spaces, selected on a - per-devio basis. - - The devio register only programs the upper 12 bits of the 32 window base - address, the low 20 bits being zero; the window size are fixed and depend on - the given device: devices 0 and 1 have ``large'' windows of 2MB (0020##0000), - while devices 2 to 7 have ``small'' windows of 1MB (0010##0000). - - Apparently there are some hidden rules about the upper 12 bits, though, and - the rules differ on Octane vs Origin systems. - - This is why the address space, from the pci driver point of view, is split - in three parts: there is the ``devio black hole'' where we must make sure - that no BAR allocation crosses a devio boundary, and the rest of the address - space (under the devio zone and above it). - - I am slowly moving away from the devio mappings the PROM leaves us in, and - eventually I expect to be able to have more flexibility in their position. - However there is the console uart mapping I don't want to change now, and - - of course - we inherit it from the prom as a devio register for the IOC3 or - IOC4 device. - - So currently, the extents I provide the MI code with span the 0->ffff##ffff - address space, with only the following areas available: - - each devio range, if configured for the given address space - - on Octane, the whole memory or I/O space minus the 16MB area in which all - devio mappings take place - - on Origin, if we have an IOTTE mapping a part of the memory or I/O address - space, the whole window minus the 16MB area in which all devio mappings - take place. - - Now I need to make sure that the MI code will never allocate mappings - crossing devio ranges. So during the Bridge setup, I am initializing - ALL BAR on a device-by-device basis, working with smaller extents: - - if the device can have all its resources of a given type (I/O or mem) - fitting in a devio area, I configure a devio, and make it allocate from - an extent spanning only the devio range. - - if there are not enough devio (because the device might need two devio - ranges, one for I/O resources and one for memory resources, and there are - only 8 devio, and if the bus is populated there might not be enough unused - devio slots to hijack), then allocation is done on the larger address space - (granted on Octane, or provided with an IOTTE window on Origin), using an - extent covering this area minus the 16MB area in which all devio mappings - take place. - So in either case, I am now sure that there are no resources crossing the - devio boundaries, which are invisible to the MI code. - - This also explains why I am making sure that the devio ranges are close to - each other - it makes the creation of the temporary resource extents simpler - (bear in mind that a device might need resources from the IOTTE window before - all devio ranges are set up). - - And of course to make things even less simple, the IOTTE allocation may fail - (e.g. on a P-Brick with 6 XBridge chips on the same Crossbow), and if we are - using an old revision Bridge, all I/O resources need to be allocated with - devio (so we can't decide to get rid of them anyway). - - So, when it's time to configure further devices (for ppb and pccbb), I need - the same trick to prevent resource allocation to cross devio boundaries. - - Actually, as far as pccbb is concerned, I give up entirely on resources if - all I have is a devio to map within - at least for now, because the devio do - not cover the 0000..ffff range in I/O space needed for pcmcia. So for the - I/O resources, I give rbus the low 16 bits of the I/O extent (if available); - as for the memory resources, I need to exclude the devio area, and since rbus - currently only supports a single contiguous area, I give it the area starting - after the devio range (which is, by far, the largest part of the - at-least-256MB region). - - Do you need aspirin yet? - -- - DMA - - Device DMA addresses can be constructed in three ways: - - direct 64 bit address - - 32 bit address within a programmable 31 bit ``direct DMA'' window - - 32 bit translated address using ATE (Address Translation Entries) - - direct 64 bit address: - These are easy to construct (pick your memory address, set bit 56, and - you're done), but these can only work with pci devices aware of 64 bit - addresses. - - direct DMA window: - There is a Bridge global register to define the base address of the window, - and then we have 2GB available. This is what I am currently using, and - convenient for PCI devices unable to use 64 bit DMA addresses. - - translated DMA: - There is another 2GB window in which accesses are indirected through ATE, - which can point anywhere in memory. - - ATE are IOMMU translation entries. PCI addresses in the translated window - transparently map to the address their ATE point to. - - Bridge chip have 128 so-called `internal' entries, and can use their - optional `external' SSRAM to provide more (up to 65536 entries with 512KB - SSRAM). However, due to chip bugs, those `external' entries can not be - updated while there is DMA in progress using external entries, even if the - updated entries are not related to those used by the DMA transfer. - - XBridge chip extend the internal entries to 1024, but do not provide - support for external entries. - - All ATE share the same page size, which is configurable as 4KB or 16KB. - - Due to the small number of ATE entries, and since you can not use part of - the system's RAM to add entries as you need them (unlike hppa or sparc64), - the driver no longer uses them, as there is nothing we can do when we run - out of ATE. - -- - interrupts - - This is easy, for a change. There are 8 interrupt sources, one per device; - pins A and C map of devices 0-7 map to interrupt sources 0-7, and pins B and - D of devices 0-7 map to interrupt sources 4-7 then 0-3 (i.e. device# ^ 4). - - All interrupts occurring on the Bridge cause an XIO interrupt packet to be - sent to the XIO interrupt address programmed at Bridge initialization time; - packets can be configured as self-clearing or not on an interrupt source - basis. - - Due to silicon bugs, interrupts can be lost if two interrupt sources - interrupt within a too short interval; there is a documented workaround for - this which consists of recognizing this situation and self-inflicting - ourselves the lost interrupt (see details in xbridge_intr_handler() ). - -- - endianness - - Endianness control is quite finegrained and quite complex at first glance: - - memory and I/O accesses not occurring within devio ranges have their - endianness controlled by the endianness flags in the (global) Bridge - configuration register... - - ... to which adds the per-device endianness flag in the device devio - register... - - and accesses occurring through devio register only use the - per-device devio register mentioned above, even if the devio - range is defined in a different register! - - i.e. - - devio 0 = endianness control C0, devio range R0 - devio 1 = endianness control C1, devio range R1 - global Bridge = endianness control C2 - - 1. access from device 0 to R0 uses C2^C0 - 2. access from device 0 to R1 uses C2^C0 - 3. access from device 0 outside R0 and R1 uses C2 - 4. access from device 1 to R0 uses C2^C1 - 5. access from device 1 to R1 uses C2^C1 - 6. access from device 1 outside R0 and R1 uses C1 - - (note that, the way I set up devio registers, cases 2 and 4 can never - occur if both device 0 and device 1 are present) - - Now for DMA: - - i don't remember what 64 bit DMA uses - - direct DMA (within the 2GB window) uses a per-device bit in devio - - translated DMA (using ATE) uses a per-device bit in devio if the - chip is a Bridge, while XBridge and PIC use different DMA addresses - (i.e. with a given ATE, there is one address pointing to it in - non-swapped mode, and another address pointing to it in swapped - mode). - - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/evcount.h> -#include <sys/malloc.h> -#include <sys/proc.h> -#include <sys/extent.h> -#include <sys/mbuf.h> -#include <sys/mutex.h> -#include <sys/queue.h> -#include <sys/atomic.h> - -#include <machine/autoconf.h> -#include <machine/bus.h> -#include <machine/cpu.h> -#include <machine/intr.h> -#include <machine/mnode.h> - -#include <uvm/uvm_extern.h> - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcivar.h> -#include <dev/pci/pcidevs.h> -#include <dev/pci/ppbreg.h> - -#include <dev/cardbus/rbus.h> - -#include <mips64/archtype.h> -#include <sgi/xbow/xbow.h> -#include <sgi/xbow/xbowdevs.h> - -#include <sgi/xbow/widget.h> -#include <sgi/xbow/xbridgereg.h> - -#ifdef TGT_OCTANE -#include <sgi/sgi/ip30.h> -#endif - -#include "cardbus.h" - -int xbridge_match(struct device *, void *, void *); -void xbridge_attach(struct device *, struct device *, void *); -int xbridge_print(void *, const char *); -int xbridge_submatch(struct device *, void *, void *); -int xbpci_match(struct device *, void *, void *); -void xbpci_attach(struct device *, struct device *, void *); -int xbpci_print(void *, const char *); - -struct xbridge_intr; - -struct xbpci_attach_args { - uint xaa_busno; - - int xaa_flags; - int16_t xaa_nasid; - int xaa_widget; - uint xaa_devio_skew; - int xaa_revision; - - bus_space_tag_t xaa_regt; - bus_addr_t xaa_offset; -}; - -struct xbpci_softc { - struct device xb_dev; - struct device *xb_bow; - - /* - * Bridge register accessors. - * Due to hardware bugs, PIC registers can only be accessed - * with 64 bit operations, although the hardware was supposed - * to be directly compatible with XBridge on that aspect. - */ - uint64_t (*xb_read_reg)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t); - void (*xb_write_reg)(bus_space_tag_t, bus_space_handle_t, - bus_addr_t, uint64_t); - - uint xb_busno; - uint xb_nslots; - - int xb_flags; -#define XF_XBRIDGE 0x01 /* is either PIC or XBridge */ -#define XF_PIC 0x02 /* is PIC */ -#define XF_NO_DIRECT_IO 0x04 /* no direct I/O mapping */ -#define XF_PCIX 0x08 /* bus in PCIX mode */ - int16_t xb_nasid; - int xb_widget; - uint xb_devio_skew; /* upper bits of devio ARCS mappings */ - int xb_revision; - - struct mips_pci_chipset xb_pc; - - bus_space_tag_t xb_regt; - bus_space_handle_t xb_regh; - - struct mips_bus_space *xb_mem_bus_space; - struct mips_bus_space *xb_mem_bus_space_sw; - struct mips_bus_space *xb_io_bus_space; - struct mips_bus_space *xb_io_bus_space_sw; - struct machine_bus_dma_tag *xb_dmat; - - struct xbridge_intr *xb_intr[BRIDGE_NINTRS]; - char xb_intrstr[BRIDGE_NINTRS][sizeof("irq #, xbow irq ###")]; - - int xb_err_intrsrc; - int (*xb_pci_intr_handler)(void *); - - uint64_t xb_ier; /* copy of BRIDGE_IER value */ - - /* - * Device information. - */ - struct { - pcireg_t id; - uint32_t devio; - } xb_devices[MAX_SLOTS]; - uint xb_devio_usemask; - - /* - * Large resource view sizes - */ - bus_addr_t xb_iostart, xb_ioend; - bus_addr_t xb_memstart, xb_memend; - - /* - * Resource extents for the large resource views, used during - * resource setup, then cleaned up for the MI code. - */ - char xb_ioexname[32]; - struct extent *xb_ioex; - char xb_memexname[32]; - struct extent *xb_memex; -}; - -struct xbridge_softc { - struct device sc_dev; - uint sc_nbuses; - - struct mips_bus_space sc_regt; -}; - -#define DEVNAME(xb) ((xb)->xb_dev.dv_xname) - -#define PCI_ID_EMPTY PCI_ID_CODE(PCI_VENDOR_INVALID, 0xffff); -#define SLOT_EMPTY(xb,dev) \ - (PCI_VENDOR((xb)->xb_devices[dev].id) == PCI_VENDOR_INVALID || \ - PCI_VENDOR((xb)->xb_devices[dev].id) == 0) - -const struct cfattach xbridge_ca = { - sizeof(struct xbridge_softc), xbridge_match, xbridge_attach -}; - -struct cfdriver xbridge_cd = { - NULL, "xbridge", DV_DULL -}; - -const struct cfattach xbpci_ca = { - sizeof(struct xbpci_softc), xbpci_match, xbpci_attach -}; - -struct cfdriver xbpci_cd = { - NULL, "xbpci", DV_DULL -}; - -void xbridge_attach_hook(struct device *, struct device *, - struct pcibus_attach_args *); -int xbridge_bus_maxdevs(void *, int); -pcitag_t xbridge_make_tag(void *, int, int, int); -void xbridge_decompose_tag(void *, pcitag_t, int *, int *, int *); -int xbridge_conf_size(void *, pcitag_t); -pcireg_t xbridge_conf_read(void *, pcitag_t, int); -void xbridge_conf_write(void *, pcitag_t, int, pcireg_t); -int xbridge_intr_map(struct pci_attach_args *, pci_intr_handle_t *); -const char *xbridge_intr_string(void *, pci_intr_handle_t); -void *xbridge_intr_establish(void *, pci_intr_handle_t, int, - int (*func)(void *), void *, const char *); -void xbridge_intr_disestablish(void *, void *); -int xbridge_intr_line(void *, pci_intr_handle_t); -int xbridge_ppb_setup(void *, pcitag_t, bus_addr_t *, bus_addr_t *, - bus_addr_t *, bus_addr_t *); -int xbridge_probe_device_hook(void *, struct pci_attach_args *); -void *xbridge_rbus_parent_io(struct pci_attach_args *); -void *xbridge_rbus_parent_mem(struct pci_attach_args *); -int xbridge_get_widget(void *); -int xbridge_get_dl(void *, pcitag_t, struct sgi_device_location *); - -int xbridge_pci_intr_handler(void *); -int xbridge_picv1_pci_intr_handler(void *); -int xbridge_err_intr_handler(void *); - -uint8_t xbridge_read_1(bus_space_tag_t, bus_space_handle_t, bus_size_t); -uint16_t xbridge_read_2(bus_space_tag_t, bus_space_handle_t, bus_size_t); -void xbridge_write_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, - uint8_t); -void xbridge_write_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, - uint16_t); -void xbridge_read_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void xbridge_write_raw_2(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -void xbridge_read_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void xbridge_write_raw_4(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); -void xbridge_read_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint8_t *, bus_size_t); -void xbridge_write_raw_8(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - const uint8_t *, bus_size_t); - -int xbridge_space_map_devio(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -int xbridge_space_map_io(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -int xbridge_space_map_mem(bus_space_tag_t, bus_addr_t, bus_size_t, int, - bus_space_handle_t *); -int xbridge_space_region_devio(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_size_t, bus_space_handle_t *); -int xbridge_space_region_io(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_size_t, bus_space_handle_t *); -int xbridge_space_region_mem(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_size_t, bus_space_handle_t *); - -void xbridge_space_barrier(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_size_t, int); - -bus_addr_t xbridge_pa_to_device(paddr_t, int); - -int xbridge_rbus_space_map(bus_space_tag_t, bus_addr_t, bus_size_t, - int, bus_space_handle_t *); -void xbridge_rbus_space_unmap(bus_space_tag_t, bus_space_handle_t, - bus_size_t, bus_addr_t *); - -void xbridge_err_clear(struct xbpci_softc *, uint64_t); -void xbridge_err_handle(struct xbpci_softc *, uint64_t); - -int xbridge_allocate_devio(struct xbpci_softc *, int, int); -void xbridge_set_devio(struct xbpci_softc *, int, uint32_t, int); - -int xbridge_resource_explore(struct xbpci_softc *, pcitag_t, - struct extent *, struct extent *); -void xbridge_resource_manage(struct xbpci_softc *, pcitag_t, - struct extent *, struct extent *); - -void xbridge_device_setup(struct xbpci_softc *, int, int, uint32_t); -int xbridge_extent_chomp(struct xbpci_softc *, struct extent *); -void xbridge_extent_setup(struct xbpci_softc *); -struct extent * - xbridge_mapping_setup(struct xbpci_softc *, int); -void xbridge_resource_setup(struct xbpci_softc *); -void xbridge_rrb_setup(struct xbpci_softc *, int); -const char * - xbridge_setup(struct xbpci_softc *); - -uint64_t bridge_read_reg(bus_space_tag_t, bus_space_handle_t, bus_addr_t); -void bridge_write_reg(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint64_t); -uint64_t pic_read_reg(bus_space_tag_t, bus_space_handle_t, bus_addr_t); -void pic_write_reg(bus_space_tag_t, bus_space_handle_t, bus_addr_t, - uint64_t); - -static __inline__ uint64_t -xbridge_read_reg(struct xbpci_softc *xb, bus_addr_t a) -{ - return (*xb->xb_read_reg)(xb->xb_regt, xb->xb_regh, a); -} -static __inline__ void -xbridge_write_reg(struct xbpci_softc *xb, bus_addr_t a, uint64_t v) -{ - (*xb->xb_write_reg)(xb->xb_regt, xb->xb_regh, a, v); -} - -static __inline__ void -xbridge_wbflush(struct xbpci_softc *xb, uint d) -{ - while (xbridge_read_reg(xb, BRIDGE_DEVICE_WBFLUSH(d)) != 0) ; -} - -static const struct machine_bus_dma_tag xbridge_dma_tag = { - NULL, /* _cookie */ - _dmamap_create, - _dmamap_destroy, - _dmamap_load, - _dmamap_load_mbuf, - _dmamap_load_uio, - _dmamap_load_raw, - _dmamap_load_buffer, - _dmamap_unload, - _dmamap_sync, - _dmamem_alloc, - _dmamem_free, - _dmamem_map, - _dmamem_unmap, - _dmamem_mmap, - xbridge_pa_to_device, - BRIDGE_DMA_DIRECT_LENGTH - 1 -}; - -static const struct mips_pci_chipset xbridge_pci_chipset = { - .pc_attach_hook = xbridge_attach_hook, - .pc_bus_maxdevs = xbridge_bus_maxdevs, - .pc_make_tag = xbridge_make_tag, - .pc_decompose_tag = xbridge_decompose_tag, - .pc_conf_size = xbridge_conf_size, - .pc_conf_read = xbridge_conf_read, - .pc_conf_write = xbridge_conf_write, - .pc_probe_device_hook = xbridge_probe_device_hook, - .pc_get_widget = xbridge_get_widget, - .pc_get_dl = xbridge_get_dl, - .pc_intr_map = xbridge_intr_map, - .pc_intr_string = xbridge_intr_string, - .pc_intr_establish = xbridge_intr_establish, - .pc_intr_disestablish = xbridge_intr_disestablish, - .pc_intr_line = xbridge_intr_line, - .pc_ppb_setup = xbridge_ppb_setup, -#if NCARDBUS > 0 - .pc_rbus_parent_io = xbridge_rbus_parent_io, - .pc_rbus_parent_mem = xbridge_rbus_parent_mem -#endif -}; - -/* - ********************* Autoconf glue. - */ - -static const struct { - uint32_t vendor; - uint32_t product; - int flags; -} xbridge_devices[] = { - /* original Bridge */ - { XBOW_VENDOR_SGI4, XBOW_PRODUCT_SGI4_BRIDGE, 0 }, - /* XBridge */ - { XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_XBRIDGE, XF_XBRIDGE }, - /* PIC */ - { XBOW_VENDOR_SGI3, XBOW_PRODUCT_SGI3_PIC, XF_PIC } -}; - -int -xbridge_match(struct device *parent, void *match, void *aux) -{ - struct xbow_attach_args *xaa = aux; - uint i; - - for (i = 0; i < nitems(xbridge_devices); i++) - if (xaa->xaa_vendor == xbridge_devices[i].vendor && - xaa->xaa_product == xbridge_devices[i].product) - return 1; - - return 0; -} - -void -xbridge_attach(struct device *parent, struct device *self, void *aux) -{ - struct xbridge_softc *sc = (struct xbridge_softc *)self; - struct xbow_attach_args *xaa = aux; - struct xbpci_attach_args xbpa; - int flags; - uint devio_skew; - uint i; - - printf(" revision %d\n", xaa->xaa_revision); - - for (i = 0; i < nitems(xbridge_devices); i++) - if (xaa->xaa_vendor == xbridge_devices[i].vendor && - xaa->xaa_product == xbridge_devices[i].product) { - flags = xbridge_devices[i].flags; - break; - } - - /* PICs are XBridges without an I/O window */ - if (ISSET(flags, XF_PIC)) - SET(flags, XF_XBRIDGE | XF_NO_DIRECT_IO); - /* Bridge < D lacks an I/O window */ - if (!ISSET(flags, XF_XBRIDGE) && xaa->xaa_revision < 4) - SET(flags, XF_NO_DIRECT_IO); - - /* - * Figure out where the ARCS devio mappings will go. - * ARCS configures all the devio in a contiguous 16MB area - * (i.e. the upper 8 bits of the DEVIO_BASE field of the - * devio registers are the same). - * - * In order to make our life simpler, on widgets where we may - * want to keep some of the ARCS mappings (because that's where - * our console device lives), we will use the same 16MB area. - * - * Otherwise, we can use whatever values we want; to keep the - * code simpler, we will nevertheless use a 16MB area as well, - * making sure it does not start at zero so that pcmcia bridges - * can be used. - * - * On Octane, the upper bits of ARCS mappings are zero, and thus - * point to the start of the widget. On Origin, they match the - * widget number. - */ -#ifdef TGT_OCTANE - if (sys_config.system_type == SGI_OCTANE && - xaa->xaa_widget == IP30_BRIDGE_WIDGET) - devio_skew = 0; - else -#endif - devio_skew = xaa->xaa_widget; - - sc->sc_nbuses = ISSET(flags, XF_PIC) ? PIC_NBUSES : BRIDGE_NBUSES; - - /* make a permanent copy of the on-stack bus_space_tag */ - bcopy(xaa->xaa_iot, &sc->sc_regt, sizeof(struct mips_bus_space)); - - /* configure and attach PCI buses */ - for (i = 0; i < sc->sc_nbuses; i++) { - xbpa.xaa_busno = i; - xbpa.xaa_flags = flags; - xbpa.xaa_nasid = xaa->xaa_nasid; - xbpa.xaa_widget = xaa->xaa_widget; - xbpa.xaa_devio_skew = devio_skew; - xbpa.xaa_revision = xaa->xaa_revision; - xbpa.xaa_regt = &sc->sc_regt; - xbpa.xaa_offset = i != 0 ? BRIDGE_BUS_OFFSET : 0; - - config_found_sm(&sc->sc_dev, &xbpa, xbridge_print, - xbridge_submatch); - } -} - -int -xbridge_submatch(struct device *parent, void *vcf, void *aux) -{ - struct cfdata *cf = vcf; - struct xbpci_attach_args *xaa = aux; - - if (cf->cf_loc[0] != -1 && cf->cf_loc[0] != xaa->xaa_busno) - return 0; - - return (*cf->cf_attach->ca_match)(parent, vcf, aux); -} - -int -xbridge_print(void *aux, const char *pnp) -{ - struct xbpci_attach_args *xaa = aux; - - if (pnp) - printf("xbpci at %s", pnp); - printf(" bus %d", xaa->xaa_busno); - - return UNCONF; -} - -int -xbpci_match(struct device *parent, void *vcf, void *aux) -{ - return 1; -} - -void -xbpci_attach(struct device *parent, struct device *self, void *aux) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)self; - struct xbpci_attach_args *xaa = (struct xbpci_attach_args *)aux; - struct pcibus_attach_args pba; - const char *errmsg = NULL; - - printf(": "); - - /* xbow -> xbridge -> xbpci: xbow device is our grandfather */ - xb->xb_bow = parent->dv_parent; - xb->xb_busno = xaa->xaa_busno; - xb->xb_flags = xaa->xaa_flags; - xb->xb_nasid = xaa->xaa_nasid; - xb->xb_widget = xaa->xaa_widget; - xb->xb_devio_skew = xaa->xaa_devio_skew; - xb->xb_revision = xaa->xaa_revision; - - if (ISSET(xb->xb_flags, XF_PIC)) { - xb->xb_nslots = PIC_NSLOTS; - - xb->xb_read_reg = pic_read_reg; - xb->xb_write_reg = pic_write_reg; - } else { - xb->xb_nslots = BRIDGE_NSLOTS; - - xb->xb_read_reg = bridge_read_reg; - xb->xb_write_reg = bridge_write_reg; - } - - /* - * Revision 1 of PIC requires a wrapper around - * xbridge_pci_intr_handler(). - */ - if (ISSET(xb->xb_flags, XF_PIC) && xb->xb_revision <= 1) - xb->xb_pci_intr_handler = xbridge_picv1_pci_intr_handler; - else - xb->xb_pci_intr_handler = xbridge_pci_intr_handler; - - /* - * Map Bridge registers. - */ - - xb->xb_regt = xaa->xaa_regt; - if (bus_space_map(xaa->xaa_regt, xaa->xaa_offset, - BRIDGE_REGISTERS_SIZE, 0, &xb->xb_regh)) { - printf("unable to map control registers\n"); - return; - } - - /* - * Create bus_space accessors... we inherit them from xbow, but - * need to overwrite mapping routines, and set up byteswapping - * versions. - */ - - xb->xb_mem_bus_space = malloc(sizeof (*xb->xb_mem_bus_space), - M_DEVBUF, M_NOWAIT); - xb->xb_mem_bus_space_sw = malloc(sizeof (*xb->xb_mem_bus_space_sw), - M_DEVBUF, M_NOWAIT); - xb->xb_io_bus_space = malloc(sizeof (*xb->xb_io_bus_space), - M_DEVBUF, M_NOWAIT); - xb->xb_io_bus_space_sw = malloc(sizeof (*xb->xb_io_bus_space_sw), - M_DEVBUF, M_NOWAIT); - if (xb->xb_mem_bus_space == NULL || xb->xb_mem_bus_space_sw == NULL || - xb->xb_io_bus_space == NULL || xb->xb_io_bus_space_sw == NULL) - goto fail1; - - bcopy(xb->xb_regt, xb->xb_mem_bus_space, sizeof(*xb->xb_mem_bus_space)); - xb->xb_mem_bus_space->bus_private = xb; - xb->xb_mem_bus_space->_space_map = xbridge_space_map_devio; - xb->xb_mem_bus_space->_space_subregion = xbridge_space_region_devio; - xb->xb_mem_bus_space->_space_barrier = xbridge_space_barrier; - - bcopy(xb->xb_mem_bus_space, xb->xb_mem_bus_space_sw, - sizeof(*xb->xb_mem_bus_space)); - xb->xb_mem_bus_space_sw->_space_read_1 = xbridge_read_1; - xb->xb_mem_bus_space_sw->_space_write_1 = xbridge_write_1; - xb->xb_mem_bus_space_sw->_space_read_2 = xbridge_read_2; - xb->xb_mem_bus_space_sw->_space_write_2 = xbridge_write_2; - xb->xb_mem_bus_space_sw->_space_read_raw_2 = xbridge_read_raw_2; - xb->xb_mem_bus_space_sw->_space_write_raw_2 = xbridge_write_raw_2; - xb->xb_mem_bus_space_sw->_space_read_raw_4 = xbridge_read_raw_4; - xb->xb_mem_bus_space_sw->_space_write_raw_4 = xbridge_write_raw_4; - xb->xb_mem_bus_space_sw->_space_read_raw_8 = xbridge_read_raw_8; - xb->xb_mem_bus_space_sw->_space_write_raw_8 = xbridge_write_raw_8; - - bcopy(xb->xb_regt, xb->xb_io_bus_space, sizeof(*xb->xb_io_bus_space)); - xb->xb_io_bus_space->bus_private = xb; - xb->xb_io_bus_space->_space_map = xbridge_space_map_devio; - xb->xb_io_bus_space->_space_subregion = xbridge_space_region_devio; - xb->xb_io_bus_space->_space_barrier = xbridge_space_barrier; - - bcopy(xb->xb_io_bus_space, xb->xb_io_bus_space_sw, - sizeof(*xb->xb_io_bus_space)); - xb->xb_io_bus_space_sw->_space_read_1 = xbridge_read_1; - xb->xb_io_bus_space_sw->_space_write_1 = xbridge_write_1; - xb->xb_io_bus_space_sw->_space_read_2 = xbridge_read_2; - xb->xb_io_bus_space_sw->_space_write_2 = xbridge_write_2; - xb->xb_io_bus_space_sw->_space_read_raw_2 = xbridge_read_raw_2; - xb->xb_io_bus_space_sw->_space_write_raw_2 = xbridge_write_raw_2; - xb->xb_io_bus_space_sw->_space_read_raw_4 = xbridge_read_raw_4; - xb->xb_io_bus_space_sw->_space_write_raw_4 = xbridge_write_raw_4; - xb->xb_io_bus_space_sw->_space_read_raw_8 = xbridge_read_raw_8; - xb->xb_io_bus_space_sw->_space_write_raw_8 = xbridge_write_raw_8; - - xb->xb_dmat = malloc(sizeof (*xb->xb_dmat), M_DEVBUF, M_NOWAIT); - if (xb->xb_dmat == NULL) - goto fail1; - memcpy(xb->xb_dmat, &xbridge_dma_tag, sizeof(*xb->xb_dmat)); - xb->xb_dmat->_cookie = xb; - - /* - * Initialize PCI methods. - */ - - bcopy(&xbridge_pci_chipset, &xb->xb_pc, sizeof(xbridge_pci_chipset)); - xb->xb_pc.pc_conf_v = xb; - xb->xb_pc.pc_intr_v = xb; - - /* - * Configure Bridge for proper operation (DMA, I/O mappings, - * RRB allocation, etc). - */ - - if ((errmsg = xbridge_setup(xb)) != NULL) - goto fail2; - printf("\n"); - - /* - * Attach children. - */ - - xbridge_extent_setup(xb); - - bzero(&pba, sizeof(pba)); - pba.pba_busname = "pci"; - /* - * XXX pba_iot and pba_memt ought to be irrelevant, since we - * XXX return the tags a device needs in probe_device_hook(); - * XXX however the pci(4) device needs a valid pba_memt for the - * XXX PCIOCGETROM* ioctls. - * XXX - * XXX Since most devices will need the byteswap tags, and those - * XXX which don't do not have PCI roms, let's pass the byteswap - * XXX versions by default. - */ - pba.pba_iot = xb->xb_io_bus_space_sw; - pba.pba_memt = xb->xb_mem_bus_space_sw; - pba.pba_dmat = xb->xb_dmat; - pba.pba_ioex = xb->xb_ioex; - pba.pba_memex = xb->xb_memex; -#ifdef DEBUG - if (xb->xb_ioex != NULL) - extent_print(xb->xb_ioex); - if (xb->xb_memex != NULL) - extent_print(xb->xb_memex); -#endif - pba.pba_pc = &xb->xb_pc; - pba.pba_domain = pci_ndomains++; - pba.pba_bus = 0; - - config_found(self, &pba, xbpci_print); - return; - -fail2: - free(xb->xb_dmat, M_DEVBUF, 0); -fail1: - free(xb->xb_io_bus_space_sw, M_DEVBUF, - sizeof (*xb->xb_io_bus_space_sw)); - free(xb->xb_io_bus_space, M_DEVBUF, sizeof (*xb->xb_io_bus_space)); - free(xb->xb_mem_bus_space_sw, M_DEVBUF, - sizeof (*xb->xb_mem_bus_space_sw)); - free(xb->xb_mem_bus_space, M_DEVBUF, sizeof (*xb->xb_mem_bus_space)); - if (errmsg == NULL) - errmsg = "not enough memory to build bus access structures"; - printf("%s\n", errmsg); -} - -int -xbpci_print(void *aux, const char *pnp) -{ - struct pcibus_attach_args *pba = aux; - - if (pnp) - printf("%s at %s", pba->pba_busname, pnp); - printf(" bus %d", pba->pba_bus); - - return UNCONF; -} - -/* - ********************* PCI glue. - */ - -void -xbridge_attach_hook(struct device *parent, struct device *self, - struct pcibus_attach_args *pba) -{ -} - -pcitag_t -xbridge_make_tag(void *cookie, int bus, int dev, int func) -{ - return (bus << 16) | (dev << 11) | (func << 8); -} - -void -xbridge_decompose_tag(void *cookie, pcitag_t tag, int *busp, int *devp, - int *funcp) -{ - if (busp != NULL) - *busp = (tag >> 16) & 0xff; - if (devp != NULL) - *devp = (tag >> 11) & 0x1f; - if (funcp != NULL) - *funcp = (tag >> 8) & 0x7; -} - -int -xbridge_bus_maxdevs(void *cookie, int busno) -{ - struct xbpci_softc *xb = cookie; - - return busno == 0 ? xb->xb_nslots : 32; -} - -int -xbridge_conf_size(void *cookie, pcitag_t tag) -{ -#if 0 - struct xbpci_softc *xb = cookie; - int bus, dev, fn; - - xbridge_decompose_tag(cookie, tag, &bus, &dev, &fn); - - /* - * IOC3 devices only implement a subset of the PCI configuration - * registers. Although xbridge_conf_{read,write} correctly - * handle the unimplemented registers, better provide a limited - * configuration space to userland. - */ - - if (bus == 0 && xb->xb_devices[dev].id == - PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3)) - return PCI_INTERRUPT_REG + 4; -#endif - - return PCI_CONFIG_SPACE_SIZE; -} - -pcireg_t -xbridge_conf_read(void *cookie, pcitag_t tag, int offset) -{ - struct xbpci_softc *xb = cookie; - pcireg_t data; - int bus, dev, fn; - paddr_t pa; - int skip; - int s; - - xbridge_decompose_tag(cookie, tag, &bus, &dev, &fn); - - /* - * IOC3 devices only implement a subset of the PCI configuration - * registers (supposedly only the first 0x20 bytes, however - * writing to the second BAR also writes to the first). - * - * Depending on which particular model we encounter, things may - * seem to work, or write access to nonexisting registers would - * completely freeze the machine. - * - * We thus check for the device type here, and handle the non - * existing registers ourselves. - */ - - skip = 0; - if (bus == 0 && xb->xb_devices[dev].id == - PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3)) { - switch (offset) { - case PCI_ID_REG: - case PCI_COMMAND_STATUS_REG: - case PCI_CLASS_REG: - case PCI_BHLC_REG: - case PCI_MAPREG_START: - /* These registers are implemented. Go ahead. */ - break; - case PCI_INTERRUPT_REG: - /* This register is not implemented. Fake it. */ - data = (PCI_INTERRUPT_PIN_A << - PCI_INTERRUPT_PIN_SHIFT) | - (dev << PCI_INTERRUPT_LINE_SHIFT); - skip = 1; - break; - default: - /* These registers are not implemented. */ - data = 0; - skip = 1; - break; - } - } - - if (skip == 0) { - /* - * Disable interrupts on this bridge (especially error - * interrupts). - */ - s = splhigh(); - xbridge_write_reg(xb, BRIDGE_IER, 0); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - - if (bus != 0) { - xbridge_write_reg(xb, BRIDGE_PCI_CFG, - (bus << 16) | (dev << 11)); - pa = xb->xb_regh + BRIDGE_PCI_CFG1_SPACE; - } else { - /* - * On PIC, device 0 in configuration space is the - * PIC itself, device slots are offset by one. - */ - if (ISSET(xb->xb_flags, XF_PIC)) - dev++; - pa = xb->xb_regh + BRIDGE_PCI_CFG_SPACE + (dev << 12); - } - - pa += (fn << 8) + offset; - if (guarded_read_4(pa, &data) != 0) - data = 0xffffffff; - - xbridge_write_reg(xb, BRIDGE_IER, xb->xb_ier); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - splx(s); - } - - return data; -} - -void -xbridge_conf_write(void *cookie, pcitag_t tag, int offset, pcireg_t data) -{ - struct xbpci_softc *xb = cookie; - int bus, dev, fn; - paddr_t pa; - int skip; - int s; - - xbridge_decompose_tag(cookie, tag, &bus, &dev, &fn); - - /* - * IOC3 devices only implement a subset of the PCI configuration - * registers. - * Depending on which particular model we encounter, things may - * seem to work, or write access to nonexisting registers would - * completely freeze the machine. - * - * We thus check for the device type here, and handle the non - * existing registers ourselves. - */ - - skip = 0; - if (bus == 0 && xb->xb_devices[dev].id == - PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3)) { - switch (offset) { - case PCI_COMMAND_STATUS_REG: - /* - * Some IOC3 models do not support having this bit - * cleared (which is what pci_mapreg_probe() will - * do), so we set it unconditionally. - */ - data |= PCI_COMMAND_MEM_ENABLE; - /* FALLTHROUGH */ - case PCI_ID_REG: - case PCI_CLASS_REG: - case PCI_BHLC_REG: - case PCI_MAPREG_START: - /* These registers are implemented. Go ahead. */ - break; - default: - /* These registers are not implemented. */ - skip = 1; - break; - } - } - - if (skip == 0) { - /* - * Disable interrupts on this bridge (especially error - * interrupts). - */ - s = splhigh(); - xbridge_write_reg(xb, BRIDGE_IER, 0); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - - if (bus != 0) { - xbridge_write_reg(xb, BRIDGE_PCI_CFG, - (bus << 16) | (dev << 11)); - pa = xb->xb_regh + BRIDGE_PCI_CFG1_SPACE; - } else { - /* - * On PIC, device 0 in configuration space is the - * PIC itself, device slots are offset by one. - */ - if (ISSET(xb->xb_flags, XF_PIC)) - dev++; - pa = xb->xb_regh + BRIDGE_PCI_CFG_SPACE + (dev << 12); - } - - pa += (fn << 8) + offset; - guarded_write_4(pa, data); - - xbridge_write_reg(xb, BRIDGE_IER, xb->xb_ier); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - splx(s); - } -} - -int -xbridge_probe_device_hook(void *cookie, struct pci_attach_args *pa) -{ - struct xbpci_softc *xb = cookie; - - /* - * Check for the hardware byteswap setting of the device we are - * interested in, and pick bus_space_tag accordingly. - * Note that the device list here must match xbridge_resource_setup(). - */ - if (pa->pa_id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3) || - pa->pa_id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC4) || - pa->pa_id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_RAD1)) { - pa->pa_iot = xb->xb_io_bus_space; - pa->pa_memt = xb->xb_mem_bus_space; - } else { - pa->pa_iot = xb->xb_io_bus_space_sw; - pa->pa_memt = xb->xb_mem_bus_space_sw; - } - - return 0; -} - -int -xbridge_get_widget(void *cookie) -{ - struct xbpci_softc *xb = cookie; - - return xb->xb_widget; -} - -int -xbridge_get_dl(void *cookie, pcitag_t tag, struct sgi_device_location *sdl) -{ - int bus, device, fn; - struct xbpci_softc *xb = cookie; - - xbridge_decompose_tag(cookie, tag, &bus, &device, &fn); - if (bus != 0) - return 0; - - sdl->nasid = xb->xb_nasid; - sdl->widget = xb->xb_widget; - - sdl->bus = xb->xb_busno; - sdl->device = device; - sdl->fn = fn; - - return 1; -} - -/* - ********************* Interrupt handling. - */ - -/* - * We map each slot to its own interrupt bit, which will in turn be routed to - * the Heart or Hub widget in charge of interrupt processing. - */ - -struct xbridge_intrhandler { - LIST_ENTRY(xbridge_intrhandler) xih_nxt; - struct xbridge_intr *xih_main; - int (*xih_func)(void *); - void *xih_arg; - struct evcount xih_count; - int xih_flags; -#define XIH_MPSAFE 0x01 - int xih_level; - int xih_device; /* device slot number */ -}; - -struct xbridge_intr { - struct xbpci_softc *xi_bus; - int xi_intrsrc; /* interrupt source on interrupt widget */ - int xi_intrbit; /* interrupt source on BRIDGE */ - LIST_HEAD(, xbridge_intrhandler) xi_handlers; -}; - -/* how our pci_intr_handle_t are constructed... */ -#define XBRIDGE_INTR_VALID 0x100 -#define XBRIDGE_INTR_HANDLE(d,b) (XBRIDGE_INTR_VALID | ((d) << 3) | (b)) -#define XBRIDGE_INTR_DEVICE(h) (((h) >> 3) & 07) -#define XBRIDGE_INTR_BIT(h) ((h) & 07) - -int -xbridge_intr_map(struct pci_attach_args *pa, pci_intr_handle_t *ihp) -{ - struct xbpci_softc *xb = pa->pa_pc->pc_conf_v; - int bus, device, intr; - int pin; - - *ihp = 0; - - if (pa->pa_intrpin == 0) { - /* No IRQ used. */ - return 1; - } - -#ifdef DIAGNOSTIC - if (pa->pa_intrpin > 4) { - printf("%s: bad interrupt pin %d\n", __func__, pa->pa_intrpin); - return 1; - } -#endif - - pci_decompose_tag(pa->pa_pc, pa->pa_tag, &bus, &device, NULL); - - if (pa->pa_bridgetag) { - pin = PPB_INTERRUPT_SWIZZLE(pa->pa_rawintrpin, device); - if (!ISSET(pa->pa_bridgeih[pin - 1], XBRIDGE_INTR_VALID)) - return 0; - intr = XBRIDGE_INTR_BIT(pa->pa_bridgeih[pin - 1]); - } else { - /* - * For IOC3 devices, pin A is always the regular PCI interrupt, - * but wiring of interrupt pin B may vary. - * We rely upon ioc(4) being able to figure out whether it's - * an onboard chip or not, and to require interrupt pin D - * instead of B in the former case. - */ - intr = -1; - if (xb->xb_devices[device].id == - PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3)) { - - switch (pa->pa_intrpin) { - case PCI_INTERRUPT_PIN_A: - case PCI_INTERRUPT_PIN_B: - break; - case PCI_INTERRUPT_PIN_D: - /* - * If this device is an onboard IOC3, - * interrupt pin B is wired as pin A of - * the first empty PCI slot... - */ - for (intr = 0; intr < MAX_SLOTS; intr++) - if (SLOT_EMPTY(xb, intr)) - break; - /* should not happen, but fallback anyway */ - if (intr >= MAX_SLOTS) - intr = -1; - break; - default: - return 1; - } - } - if (intr < 0) { - if (pa->pa_intrpin & 1) - intr = device; - else - intr = device ^ 4; - } - } - - *ihp = XBRIDGE_INTR_HANDLE(device, intr); - - return 0; -} - -const char * -xbridge_intr_string(void *cookie, pci_intr_handle_t ih) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)cookie; - int intrbit = XBRIDGE_INTR_BIT(ih); - - if (xb->xb_intrstr[intrbit][0] == '\0') - snprintf(xb->xb_intrstr[intrbit], - sizeof xb->xb_intrstr[intrbit], "irq %ld", ih); - return xb->xb_intrstr[intrbit]; -} - -void * -xbridge_intr_establish(void *cookie, pci_intr_handle_t ih, int level, - int (*func)(void *), void *arg, const char *name) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)cookie; - struct xbridge_intr *xi; - struct xbridge_intrhandler *xih; - uint64_t int_addr; - int device = XBRIDGE_INTR_DEVICE(ih); - int intrbit = XBRIDGE_INTR_BIT(ih); - int flags; - int intrsrc; - int new; - - flags = (level & IPL_MPSAFE) ? XIH_MPSAFE : 0; - level &= ~IPL_MPSAFE; - - /* - * Allocate bookkeeping structure if this is the - * first time we're using this interrupt source. - */ - if ((xi = xb->xb_intr[intrbit]) == NULL) { - xi = (struct xbridge_intr *) - malloc(sizeof(*xi), M_DEVBUF, M_NOWAIT); - if (xi == NULL) - return NULL; - - xi->xi_bus = xb; - xi->xi_intrbit = intrbit; - LIST_INIT(&xi->xi_handlers); - - if (xbow_intr_register(xb->xb_widget, level, &intrsrc) != 0) { - free(xi, M_DEVBUF, sizeof *xi); - return NULL; - } - - xi->xi_intrsrc = intrsrc; - xb->xb_intr[intrbit] = xi; - snprintf(xb->xb_intrstr[intrbit], - sizeof xb->xb_intrstr[intrbit], - "irq %d, xbow irq %d", intrbit, intrsrc); - } else - intrsrc = xi->xi_intrsrc; - - /* - * Register the interrupt at the Heart or Hub level if this is the - * first time we're using this interrupt source. - */ - new = LIST_EMPTY(&xi->xi_handlers); - if (new) { - /* - * XXX The interrupt dispatcher is always registered - * XXX at IPL_BIO, in case the interrupt will be shared - * XXX between devices of different levels. - */ - if (xbow_intr_establish(xb->xb_pci_intr_handler, xi, intrsrc, - IPL_BIO | IPL_MPSAFE, NULL, NULL)) { - printf("%s: unable to register interrupt handler\n", - DEVNAME(xb)); - return NULL; - } - } - - xih = (struct xbridge_intrhandler *) - malloc(sizeof(*xih), M_DEVBUF, M_NOWAIT); - if (xih == NULL) - return NULL; - - xih->xih_main = xi; - xih->xih_func = func; - xih->xih_arg = arg; - xih->xih_flags = flags; - xih->xih_level = level; - xih->xih_device = device; - evcount_attach(&xih->xih_count, name, &xi->xi_intrsrc); - LIST_INSERT_HEAD(&xi->xi_handlers, xih, xih_nxt); - - if (new) { - /* - * Note that, while PIC uses a complete XIO address, - * Bridge will only store the interrupt source and high - * bits of the address, and will reuse the widget interrupt - * address for the low 38 bits of the XIO address. - */ - if (ISSET(xb->xb_flags, XF_PIC)) - int_addr = ((uint64_t)intrsrc << 48) | - (xbow_intr_address & ((1UL << 48) - 1)); - else - int_addr = ((xbow_intr_address >> 30) & - 0x0003ff00) | intrsrc; - xb->xb_ier |= 1L << intrbit; - - xbridge_write_reg(xb, BRIDGE_INT_ADDR(intrbit), int_addr); - xbridge_write_reg(xb, BRIDGE_IER, xb->xb_ier); - /* - * INT_MODE register controls which interrupt pins cause - * ``interrupt clear'' packets to be sent for high->low - * transition. - * We enable such packets to be sent in order not to have to - * clear interrupts ourselves. - */ - xbridge_write_reg(xb, BRIDGE_INT_MODE, - xbridge_read_reg(xb, BRIDGE_INT_MODE) | (1 << intrbit)); - xbridge_write_reg(xb, BRIDGE_INT_DEV, - xbridge_read_reg(xb, BRIDGE_INT_DEV) | - (device << (intrbit * 3))); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - } - - return (void *)xih; -} - -void -xbridge_intr_disestablish(void *cookie, void *vih) -{ - struct xbpci_softc *xb = cookie; - struct xbridge_intrhandler *xih = (struct xbridge_intrhandler *)vih; - struct xbridge_intr *xi = xih->xih_main; - int intrbit = xi->xi_intrbit; - - evcount_detach(&xih->xih_count); - LIST_REMOVE(xih, xih_nxt); - - if (LIST_EMPTY(&xi->xi_handlers)) { - xb->xb_ier &= ~(1 << intrbit); - xbridge_write_reg(xb, BRIDGE_INT_ADDR(intrbit), 0); - xbridge_write_reg(xb, BRIDGE_IER, xb->xb_ier); - xbridge_write_reg(xb, BRIDGE_INT_MODE, - xbridge_read_reg(xb, BRIDGE_INT_MODE) & ~(1 << intrbit)); - xbridge_write_reg(xb, BRIDGE_INT_DEV, - xbridge_read_reg(xb, BRIDGE_INT_DEV) & - ~(7 << (intrbit * 3))); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - - xbow_intr_disestablish(xi->xi_intrsrc); - /* - * Note we could free xb->xb_intr[intrbit] at this point, - * but it's not really worth doing. - */ - } - - free(xih, M_DEVBUF, sizeof *xih); -} - -int -xbridge_intr_line(void *cookie, pci_intr_handle_t ih) -{ - return XBRIDGE_INTR_BIT(ih); -} - -int -xbridge_err_intr_handler(void *v) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)v; - uint64_t isr; - - isr = xbridge_read_reg(xb, BRIDGE_ISR) & ~BRIDGE_ISR_HWINTR_MASK; - xbridge_err_handle(xb, isr); - - xbow_intr_clear(xb->xb_err_intrsrc); - - return 1; -} - -int -xbridge_pci_intr_handler(void *v) -{ - struct xbridge_intr *xi = (struct xbridge_intr *)v; - struct xbpci_softc *xb = xi->xi_bus; - struct xbridge_intrhandler *xih; - uint64_t isr; - int rc; -#ifdef MULTIPROCESSOR - int need_lock; -#endif - - /* XXX shouldn't happen, and assumes interrupt is not shared */ - if (LIST_EMPTY(&xi->xi_handlers)) { - printf("%s: spurious irq %d\n", DEVNAME(xb), xi->xi_intrbit); - return 0; - } - - /* - * Flush PCI write buffers before servicing the interrupt. - */ - LIST_FOREACH(xih, &xi->xi_handlers, xih_nxt) - xbridge_wbflush(xb, xih->xih_device); - - isr = xbridge_read_reg(xb, BRIDGE_ISR); - if ((isr & ~BRIDGE_ISR_HWINTR_MASK) != 0) { - /* - * This is an error interrupt triggered by a particular - * device. - */ - xbridge_err_handle(xb, isr & ~BRIDGE_ISR_HWINTR_MASK); - if ((isr &= BRIDGE_ISR_HWINTR_MASK) == 0) - return 1; - } - - if ((isr & (1L << xi->xi_intrbit)) == 0) { - /* - * May be a result of the lost interrupt workaround (see - * near the end of this function); don't complain in that - * case. - */ - rc = -1; -#ifdef DEBUG - printf("%s: irq %d but not pending in ISR %08llx\n", - DEVNAME(xb), xi->xi_intrbit, isr); -#endif - } else { - rc = 0; - LIST_FOREACH(xih, &xi->xi_handlers, xih_nxt) { - splraise(xih->xih_level); -#ifdef MULTIPROCESSOR - if (ISSET(xih->xih_flags, XIH_MPSAFE)) - need_lock = 0; - else - need_lock = xih->xih_flags < IPL_CLOCK; - if (need_lock) - __mp_lock(&kernel_lock); -#endif - if ((*xih->xih_func)(xih->xih_arg) != 0) { - xih->xih_count.ec_count++; - rc = 1; - } -#ifdef MULTIPROCESSOR - if (need_lock) - __mp_unlock(&kernel_lock); -#endif - /* - * No need to lower spl here, as our caller will - * lower spl upon our return. - * However that splraise() is necessary so that - * interrupt handler code calling splx() will not - * cause our interrupt source to be unmasked. - */ - } - /* XXX assumes interrupt is not shared */ - if (rc == 0) - printf("%s: spurious irq %d\n", - DEVNAME(xb), xi->xi_intrbit); - } - - /* - * There is a known BRIDGE race in which, if two interrupts - * on two different pins occur within 60nS of each other, - * further interrupts on the first pin do not cause an - * interrupt to be sent. - * - * The workaround against this is to check if our interrupt - * source is still active (i.e. another interrupt is pending), - * in which case we force an interrupt anyway. - * - * The XBridge even has a nice facility to do this, where we - * do not even have to check if our interrupt is pending. - */ - - if (ISSET(xb->xb_flags, XF_XBRIDGE)) { - xbridge_write_reg(xb, BRIDGE_INT_FORCE_PIN(xi->xi_intrbit), 1); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - } else { - if (xbridge_read_reg(xb, BRIDGE_ISR) & (1 << xi->xi_intrbit)) - xbow_intr_set(xi->xi_intrsrc); - } - - return rc; -} - -int -xbridge_picv1_pci_intr_handler(void *v) -{ - struct xbridge_intr *xi = (struct xbridge_intr *)v; - struct xbpci_softc *xb = xi->xi_bus; - - /* - * Revision 1 of PIC is supposed to need the interrupt enable bit - * to be toggled to prevent loss of interrupt. - */ - xbridge_write_reg(xb, BRIDGE_IER, xb->xb_ier & ~(1L << xi->xi_intrbit)); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - xbridge_write_reg(xb, BRIDGE_IER, xb->xb_ier); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - - return xbridge_pci_intr_handler(v); -} - -/* - ********************* chip register access. - */ - -uint64_t -bridge_read_reg(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a) -{ - return (uint64_t)widget_read_4(t, h, a); -} -void -bridge_write_reg(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a, - uint64_t v) -{ - widget_write_4(t, h, a, (uint32_t)v); -} - -uint64_t -pic_read_reg(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a) -{ - return widget_read_8(t, h, a); -} - -void -pic_write_reg(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t a, - uint64_t v) -{ - widget_write_8(t, h, a, v); -} - -/* - ********************* bus_space glue. - */ - -uint8_t -xbridge_read_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint8_t *)((h + o) ^ 3); -} - -uint16_t -xbridge_read_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o) -{ - return *(volatile uint16_t *)((h + o) ^ 2); -} - -void -xbridge_write_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, - uint8_t v) -{ - *(volatile uint8_t *)((h + o) ^ 3) = v; -} - -void -xbridge_write_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, - uint16_t v) -{ - *(volatile uint16_t *)((h + o) ^ 2) = v; -} - -void -xbridge_read_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)((h + o) ^ 2); - len >>= 1; - while (len-- != 0) { - *(uint16_t *)buf = letoh16(*addr); - buf += 2; - } -} - -void -xbridge_write_raw_2(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint16_t *addr = (volatile uint16_t *)((h + o) ^ 2); - len >>= 1; - while (len-- != 0) { - *addr = htole16(*(uint16_t *)buf); - buf += 2; - } -} - -void -xbridge_read_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *(uint32_t *)buf = letoh32(*addr); - buf += 4; - } -} - -void -xbridge_write_raw_4(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint32_t *addr = (volatile uint32_t *)(h + o); - len >>= 2; - while (len-- != 0) { - *addr = htole32(*(uint32_t *)buf); - buf += 4; - } -} - -void -xbridge_read_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *(uint64_t *)buf = letoh64(*addr); - buf += 8; - } -} - -void -xbridge_write_raw_8(bus_space_tag_t t, bus_space_handle_t h, bus_addr_t o, - const uint8_t *buf, bus_size_t len) -{ - volatile uint64_t *addr = (volatile uint64_t *)(h + o); - len >>= 3; - while (len-- != 0) { - *addr = htole64(*(uint64_t *)buf); - buf += 8; - } -} - -int -xbridge_space_map_devio(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)t->bus_private; - bus_addr_t bpa; -#ifdef DIAGNOSTIC - bus_addr_t start, end; - uint d; -#endif - - if ((offs >> 24) != xb->xb_devio_skew) - return EINVAL; /* not a devio mapping */ - - /* - * Figure out which devio `slot' we are using, and make sure - * we do not overrun it. - */ - bpa = offs & ((1UL << 24) - 1); -#ifdef DIAGNOSTIC - for (d = 0; d < xb->xb_nslots; d++) { - start = PIC_DEVIO_OFFS(xb->xb_busno, d); - end = start + BRIDGE_DEVIO_SIZE(d); - if (bpa >= start && bpa < end) { - if (bpa + size > end) - return EINVAL; - else - break; - } - } - if (d == xb->xb_nslots) - return EINVAL; -#endif - - /* - * Note we can not use our own bus_base because it might not point - * to our small window. Instead, use the one used by the xbridge - * driver itself, which _always_ points to the short window. - */ - *bshp = xb->xb_regt->bus_base + bpa; - return 0; -} - -int -xbridge_space_map_io(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)t->bus_private; - - /* - * Base address is either within the devio area, or our direct - * window. - */ - - if ((offs >> 24) == xb->xb_devio_skew) - return xbridge_space_map_devio(t, offs, size, flags, bshp); - -#ifdef DIAGNOSTIC - /* check that this does not overflow the mapping */ - if (offs < xb->xb_iostart || offs + size - 1 > xb->xb_ioend) - return EINVAL; -#endif - - *bshp = (t->bus_base + offs); - return 0; -} - -int -xbridge_space_map_mem(bus_space_tag_t t, bus_addr_t offs, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ -#if defined(TGT_ORIGIN) || defined(DIAGNOSTIC) - struct xbpci_softc *xb = (struct xbpci_softc *)t->bus_private; -#endif - - /* - * Base address is either within the devio area, or our direct - * window. Except on Octane where we never setup devio memory - * mappings, because the large mapping is always available. - */ - -#ifdef TGT_ORIGIN - if (sys_config.system_type != SGI_OCTANE && - (offs >> 24) == xb->xb_devio_skew) - return xbridge_space_map_devio(t, offs, size, flags, bshp); -#endif - -#ifdef DIAGNOSTIC - /* check that this does not overflow the mapping */ - if (offs < xb->xb_memstart || offs + size - 1 > xb->xb_memend) - return EINVAL; -#endif - - *bshp = (t->bus_base + offs); - return 0; -} - -int -xbridge_space_region_devio(bus_space_tag_t t , bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ -#ifdef DIAGNOSTIC - struct xbpci_softc *xb = (struct xbpci_softc *)t->bus_private; - bus_addr_t bpa; - bus_addr_t start, end; - uint d; -#endif - -#ifdef DIAGNOSTIC - /* - * Note we can not use our own bus_base because it might not point - * to our small window. Instead, use the one used by the xbridge - * driver itself, which _always_ points to the short window. - */ - bpa = (bus_addr_t)bsh - xb->xb_regt->bus_base; - - if ((bpa >> 24) != 0) - return EINVAL; /* not a devio mapping */ - - /* - * Figure out which devio `slot' we are using, and make sure - * we do not overrun it. - */ - for (d = 0; d < xb->xb_nslots; d++) { - start = PIC_DEVIO_OFFS(xb->xb_busno, d); - end = start + BRIDGE_DEVIO_SIZE(d); - if (bpa >= start && bpa < end) { - if (bpa + offset + size > end) - return EINVAL; - else - break; - } - } - if (d == xb->xb_nslots) - return EINVAL; -#endif - - *nbshp = bsh + offset; - return 0; -} - -int -xbridge_space_region_io(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)t->bus_private; - bus_addr_t bpa; - - /* - * Note we can not use our own bus_base because it might not point - * to our small window. Instead, use the one used by the xbridge - * driver itself, which _always_ points to the short window. - */ - bpa = (bus_addr_t)bsh - xb->xb_regt->bus_base; - - if ((bpa >> 24) == 0) - return xbridge_space_region_devio(t, bsh, offset, size, nbshp); - -#ifdef DIAGNOSTIC - /* check that this does not overflow the mapping */ - bpa = (bus_addr_t)bsh - t->bus_base; - if (bpa + offset + size - 1 > xb->xb_ioend) - return EINVAL; -#endif - - *nbshp = bsh + offset; - return 0; -} - -int -xbridge_space_region_mem(bus_space_tag_t t, bus_space_handle_t bsh, - bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) -{ -#if defined(TGT_ORIGIN) || defined(DIAGNOSTIC) - struct xbpci_softc *xb = (struct xbpci_softc *)t->bus_private; - bus_addr_t bpa; -#endif - - /* - * Base address is either within the devio area, or our direct - * window. Except on Octane where we never setup devio memory - * mappings, because the large mapping is always available. - */ - -#ifdef TGT_ORIGIN - if (sys_config.system_type != SGI_OCTANE) { - /* - * Note we can not use our own bus_base because it might not - * point to our small window. Instead, use the one used by - * the xbridge driver itself, which _always_ points to the - * short window. - */ - bpa = (bus_addr_t)bsh - xb->xb_regt->bus_base; - - if ((bpa >> 24) == 0) - return xbridge_space_region_devio(t, bsh, offset, size, - nbshp); - } -#endif - -#ifdef DIAGNOSTIC - /* check that this does not overflow the mapping */ - bpa = (bus_addr_t)bsh - t->bus_base; - if (bpa + offset + size - 1 > xb->xb_memend) - return EINVAL; -#endif - - *nbshp = bsh + offset; - return 0; -} - -void -xbridge_space_barrier(bus_space_tag_t t, bus_space_handle_t h, bus_size_t offs, - bus_size_t len, int flags) -{ - struct xbpci_softc *xb = (struct xbpci_softc *)t->bus_private; - bus_addr_t bpa, start, end; - uint d, devmin, devmax; - - mips_sync(); - - if (flags & BUS_SPACE_BARRIER_WRITE) { - /* - * Try to figure out which device we are working for, and - * flush its PCI write buffer. - * This is ugly; we really need to be able to provide a - * different bus_space_tag_t to each slot, to be able - * to tell them apart. - */ - if (t->_space_map == xbridge_space_map_devio) { - bpa = (bus_addr_t)h - xb->xb_regt->bus_base; - for (d = 0; d < xb->xb_nslots; d++) { - start = PIC_DEVIO_OFFS(xb->xb_busno, d); - end = start + BRIDGE_DEVIO_SIZE(d); - if (bpa >= start && bpa < end) - break; - } - devmin = d; - devmax = d + 1; - /* should not happen */ - if (d == xb->xb_nslots) { - devmin = 0; - devmax = xb->xb_nslots; - } - } else { - /* nothing better came up my sleeve... */ - devmin = 0; - devmax = xb->xb_nslots; - } - for (d = devmin; d < devmax; d++) - xbridge_wbflush(xb, d); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - } -} - -/* - ********************* bus_dma helpers - */ - -/* - * Since the common bus_dma code makes sure DMA-able memory is allocated - * within the dma_constraint limits, which are set to the direct DMA - * window, we do not need to check for addresses outside this range here. - */ - -bus_addr_t -xbridge_pa_to_device(paddr_t pa, int flags) -{ - KASSERTMSG(pa - dma_constraint.ucr_low < BRIDGE_DMA_DIRECT_LENGTH, - "pa 0x%lx not in dma constraint range! (0x%lx-0x%lx)", - pa, dma_constraint.ucr_low, dma_constraint.ucr_high); - return (pa - dma_constraint.ucr_low) + BRIDGE_DMA_DIRECT_BASE; -} - -/* - ********************* Bridge configuration code. - */ - -const char * -xbridge_setup(struct xbpci_softc *xb) -{ - bus_addr_t ba; - paddr_t pa; - uint64_t status, ctrl, int_addr, dirmap; - int mode, speed, dev; - - status = xbridge_read_reg(xb, WIDGET_STATUS); - ctrl = xbridge_read_reg(xb, WIDGET_CONTROL); - - /* - * Print bus mode and speed. - */ - - mode = ISSET(xb->xb_flags, XF_PIC) && - ISSET(status, PIC_WIDGET_STATUS_PCIX_MODE); - if (mode != 0) { - SET(xb->xb_flags, XF_PCIX); - speed = (status & PIC_WIDGET_STATUS_PCIX_SPEED_MASK) >> - PIC_WIDGET_STATUS_PCIX_SPEED_SHIFT; - } else if (ISSET(xb->xb_flags, XF_XBRIDGE)) { - speed = (ctrl & BRIDGE_WIDGET_CONTROL_SPEED_MASK) >> - BRIDGE_WIDGET_CONTROL_SPEED_SHIFT; - } else - speed = 0; - /* 0 = 33 MHz, 1 = 66 MHz, 2 = 100 MHz, 3 = 133 MHz */ - speed = (speed & 2 ? 100 : 33) + (speed & 1 ? 33 : 0); - printf("%d MHz %s bus", speed, mode ? "PCIX" : "PCI"); - - /* - * Gather device identification for all slots. - * We need this to be able to allocate RRBs correctly, and also - * to be able to check quickly whether a given device is an IOC3. - */ - - for (dev = 0; dev < xb->xb_nslots; dev++) { - if (ISSET(xb->xb_flags, XF_PIC)) - pa = xb->xb_regh + BRIDGE_PCI_CFG_SPACE + - ((dev + 1) << 12) + PCI_ID_REG; - else - pa = xb->xb_regh + BRIDGE_PCI_CFG_SPACE + - (dev << 12) + PCI_ID_REG; - if (guarded_read_4(pa, &xb->xb_devices[dev].id) != 0) - xb->xb_devices[dev].id = PCI_ID_EMPTY; - } - - /* - * Configure the direct DMA window to access the 2GB memory - * window selected as our DMA memory range. - */ - dirmap = (dma_constraint.ucr_low >> BRIDGE_DIRMAP_BASE_SHIFT) & - BRIDGE_DIRMAP_BASE_MASK; - switch (sys_config.system_type) { - default: -#ifdef TGT_ORIGIN - dirmap |= kl_hub_widget[ - IP27_PHYS_TO_NODE(dma_constraint.ucr_low)] << - BRIDGE_DIRMAP_WIDGET_SHIFT; - break; -#endif -#ifdef TGT_OCTANE - case SGI_OCTANE: - dirmap |= IP30_HEART_WIDGET << BRIDGE_DIRMAP_WIDGET_SHIFT; - break; -#endif - } - xbridge_write_reg(xb, BRIDGE_DIR_MAP, dirmap); - - /* - * Allocate RRB for the existing devices. - */ - - xbridge_rrb_setup(xb, 0); - xbridge_rrb_setup(xb, 1); - - /* - * Enable(?) snooping and disable relaxed order on PIC. - */ - - if (ISSET(xb->xb_flags, XF_PIC)) { - ctrl &= ~PIC_WIDGET_CONTROL_NO_SNOOP; - ctrl &= ~PIC_WIDGET_CONTROL_RELAX_ORDER; - } - - /* - * Disable byteswapping on PIO accesses through the large window - * (we handle this at the bus_space level). It should not have - * been enabled by ARCS, since IOC serial console relies on this, - * but better enforce this anyway. - */ - - ctrl &= ~BRIDGE_WIDGET_CONTROL_IO_SWAP; - ctrl &= ~BRIDGE_WIDGET_CONTROL_MEM_SWAP; - xbridge_write_reg(xb, WIDGET_CONTROL, ctrl); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - - /* - * The PROM will only configure the onboard devices. Set up - * any other device we might encounter. - */ - - xbridge_resource_setup(xb); - - /* - * Older Bridge chips needs to run with pci timeouts - * disabled. - */ - - if (!ISSET(xb->xb_flags, XF_XBRIDGE) && xb->xb_revision < 4) { - xbridge_write_reg(xb, BRIDGE_BUS_TIMEOUT, - xbridge_read_reg(xb, BRIDGE_BUS_TIMEOUT) & - ~BRIDGE_BUS_PCI_RETRY_CNT_MASK); - } - - /* - * AT&T/Lucent USS-302 and USS-312 USB controllers require - * a larger PCI retry hold interval for proper operation. - */ - - for (dev = 0; dev < xb->xb_nslots; dev++) { - if (xb->xb_devices[dev].id == - PCI_ID_CODE(PCI_VENDOR_LUCENT, PCI_PRODUCT_LUCENT_USBHC) || - xb->xb_devices[dev].id == - PCI_ID_CODE(PCI_VENDOR_LUCENT, PCI_PRODUCT_LUCENT_USBHC2)) { - ctrl = xbridge_read_reg(xb, BRIDGE_BUS_TIMEOUT); - ctrl &= ~BRIDGE_BUS_PCI_RETRY_HOLD_MASK; - ctrl |= (4 << BRIDGE_BUS_PCI_RETRY_HOLD_SHIFT); - xbridge_write_reg(xb, BRIDGE_BUS_TIMEOUT, ctrl); - - break; - } - } - - /* - * Clear the write request memory in PIC, to avoid risking - * spurious parity errors if it is not clean. - */ - if (ISSET(xb->xb_flags, XF_PIC)) { - for (ba = PIC_WR_REQ_LOWER(0); - ba != PIC_WR_REQ_LOWER(PIC_WR_REQ_ENTRIES); ba += 8) - xbridge_write_reg(xb, ba, 0ULL); - for (ba = PIC_WR_REQ_UPPER(0); - ba != PIC_WR_REQ_UPPER(PIC_WR_REQ_ENTRIES); ba += 8) - xbridge_write_reg(xb, ba, 0ULL); - for (ba = PIC_WR_REQ_PARITY(0); - ba != PIC_WR_REQ_PARITY(PIC_WR_REQ_ENTRIES); ba += 8) - xbridge_write_reg(xb, ba, 0ULL); - } - - /* - * Setup interrupt handling. - * - * Note that, on PIC, the `lower address' register is a 64 bit - * register and thus need to be initialized with the whole 64 bit - * address; the `upper address' register is hardwired to zero and - * ignores writes, so we can use the same logic on Bridge and PIC. - * - * Also, on Octane, we need to keep otherwise unused interrupt source - * #6 enabled on the obio widget, as it controls routing of the - * power button interrupt (and to make things more complicated than - * necessary, this pin is wired to a particular Heart interrupt - * register bit, so interrupts on this pin will never be seen at the - * Bridge level). - */ - -#ifdef TGT_OCTANE - if (sys_config.system_type == SGI_OCTANE && - xb->xb_widget == IP30_BRIDGE_WIDGET) - xb->xb_ier = 1L << 6; - else -#endif - xb->xb_ier = 0; - xbridge_write_reg(xb, BRIDGE_IER, 0); - xbridge_write_reg(xb, BRIDGE_INT_MODE, 0); - xbridge_write_reg(xb, BRIDGE_INT_DEV, 0); - int_addr = xbow_intr_address & ((1UL << 48) - 1); - switch (sys_config.system_type) { - default: -#ifdef TGT_ORIGIN - int_addr |= (uint64_t)kl_hub_widget[masternasid] << 48; - break; -#endif -#ifdef TGT_OCTANE - case SGI_OCTANE: - int_addr |= (uint64_t)IP30_HEART_WIDGET << 48; - break; -#endif - } - xbridge_write_reg(xb, WIDGET_INTDEST_ADDR_LOWER, int_addr); - xbridge_write_reg(xb, WIDGET_INTDEST_ADDR_UPPER, int_addr >> 32); - - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - - /* - * Register an error interrupt handler. - */ - - if (xbow_intr_register(xb->xb_widget, IPL_HIGH, - &xb->xb_err_intrsrc) != 0) - return "can't allocate error interrupt source"; - if (xbow_intr_establish(xbridge_err_intr_handler, xb, - xb->xb_err_intrsrc, IPL_HIGH, DEVNAME(xb), NULL)) - return "unable to register error interrupt handler"; - - xbridge_err_clear(xb, 0); - xbridge_write_reg(xb, BRIDGE_INT_HOST_ERR, xb->xb_err_intrsrc); - - /* - * Enable as many error interrupt sources as possible; older - * Bridge chips need to have a few of them kept masked to - * avoid hitting hardware issues. - */ - xb->xb_ier |= (ISSET(xb->xb_flags, XF_PIC) ? - PIC_ISR_ERRMASK : BRIDGE_ISR_ERRMASK) & - ~(BRIDGE_ISR_MULTIPLE_ERR | BRIDGE_ISR_SSRAM_PERR | - BRIDGE_ISR_GIO_BENABLE_ERR); - if (xb->xb_busno != 0) { - /* xtalk errors will only show up on bus #0 */ - xb->xb_ier &= ~(BRIDGE_ISR_UNSUPPORTED_XOP | - BRIDGE_ISR_LLP_REC_SNERR | BRIDGE_ISR_LLP_REC_CBERR | - BRIDGE_ISR_LLP_RCTY | BRIDGE_ISR_LLP_TX_RETRY | - BRIDGE_ISR_LLP_TCTY); - } - if (!ISSET(xb->xb_flags, XF_XBRIDGE)) { - if (xb->xb_revision < 2) - xb->xb_ier &= ~(BRIDGE_ISR_UNEXPECTED_RESP | - BRIDGE_ISR_PCI_MASTER_TMO | - BRIDGE_ISR_RESP_XTALK_ERR | - BRIDGE_ISR_LLP_TX_RETRY | BRIDGE_ISR_XREAD_REQ_TMO); - if (xb->xb_revision < 3) - xb->xb_ier &= ~BRIDGE_ISR_BAD_XRESP_PACKET; - } - - xbridge_write_reg(xb, BRIDGE_IER, xb->xb_ier); - - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - - return NULL; -} - -/* - * Handle PCI errors. - */ -void -xbridge_err_handle(struct xbpci_softc *xb, uint64_t isr) -{ - uint64_t pci_err, wid_err, resp_err; - - wid_err = xbridge_read_reg(xb, WIDGET_ERR_ADDR_LOWER); - if (!ISSET(xb->xb_flags, XF_PIC)) - wid_err |= xbridge_read_reg(xb, WIDGET_ERR_ADDR_UPPER) << 32; - pci_err = xbridge_read_reg(xb, BRIDGE_PCI_ERR_LOWER); - if (!ISSET(xb->xb_flags, XF_PIC)) - pci_err |= xbridge_read_reg(xb, BRIDGE_PCI_ERR_UPPER) << 32; - resp_err = xbridge_read_reg(xb, BRIDGE_WIDGET_RESP_LOWER); - if (!ISSET(xb->xb_flags, XF_PIC)) - resp_err |= - xbridge_read_reg(xb, BRIDGE_WIDGET_RESP_UPPER) << 32; - - /* XXX give more detailed information */ - printf("%s: error interrupt, isr %llx wid %llx pci %llx resp %llx\n", - DEVNAME(xb), isr, wid_err, pci_err, resp_err); - - xbridge_err_clear(xb, isr); -} - -/* - * Clear any error condition. - */ -void -xbridge_err_clear(struct xbpci_softc *xb, uint64_t isr) -{ - if (ISSET(xb->xb_flags, XF_PIC)) { - if (isr == 0) - isr = xbridge_read_reg(xb, BRIDGE_ISR) & - ~BRIDGE_ISR_HWINTR_MASK; - xbridge_write_reg(xb, BRIDGE_ICR, isr); - } else - xbridge_write_reg(xb, BRIDGE_ICR, BRIDGE_ICR_ALL); - - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); -} - -/* - * Build a not-so-pessimistic RRB allocation register value. - */ -void -xbridge_rrb_setup(struct xbpci_softc *xb, int odd) -{ - uint rrb[MAX_SLOTS / 2]; /* tentative rrb assignment */ - uint total; /* rrb count */ - uint32_t proto; /* proto rrb value */ - int dev, i, j; - - /* - * First, try to allocate as many RRBs per device as possible. - */ - - total = 0; - for (i = 0; i < nitems(rrb); i++) { - dev = (i << 1) + !!odd; - if (dev >= xb->xb_nslots || SLOT_EMPTY(xb, dev)) - rrb[i] = 0; - else { - rrb[i] = 4; /* optimistic value */ - total += 4; - } - } - - /* - * Then, try to reduce greed until we do not claim more than - * the 8 RRBs we can afford. - */ - - if (total > 8) { - /* - * All devices should be able to live with 3 RRBs, so - * reduce their allocation from 4 to 3. - */ - for (i = 0; i < nitems(rrb); i++) { - if (rrb[i] == 4) { - rrb[i]--; - if (--total == 8) - break; - } - } - } - - if (total > 8) { - /* - * There are too many devices for 3 RRBs per device to - * be possible. Attempt to reduce from 3 to 2, except - * for isp(4) devices. - */ - for (i = 0; i < nitems(rrb); i++) { - if (rrb[i] == 3) { - dev = (i << 1) + !!odd; - if (PCI_VENDOR(xb->xb_devices[dev].id) != - PCI_VENDOR_QLOGIC) { - rrb[i]--; - if (--total == 8) - break; - } - } - } - } - - if (total > 8) { - /* - * Too bad, we need to shrink the RRB allocation for - * isp devices too. We'll try to favour the lowest - * slots, though, hence the reversed loop order. - */ - for (i = nitems(rrb) - 1; i >= 0; i--) { - if (rrb[i] == 3) { - rrb[i]--; - if (--total == 8) - break; - } - } - } - - /* - * Now build the RRB register value proper. - */ - - proto = 0; - for (i = 0; i < nitems(rrb); i++) { - for (j = 0; j < rrb[i]; j++) - proto = (proto << RRB_SHIFT) | (RRB_VALID | i); - } - - xbridge_write_reg(xb, odd ? BRIDGE_RRB_ODD : BRIDGE_RRB_EVEN, proto); -} - -/* - * Configure PCI resources for all devices. - */ -void -xbridge_resource_setup(struct xbpci_softc *xb) -{ - pci_chipset_tag_t pc = &xb->xb_pc; - int dev, nfuncs; - pcitag_t tag; - pcireg_t id, bhlcr; - uint32_t devio; - int need_setup; - uint secondary, nppb, npccbb, ppbstride; - const struct pci_quirkdata *qd; - - /* - * On Octane, we will want to map everything through the large - * windows, whenever possible. - * - * Set up these mappings now. - */ - - if (sys_config.system_type == SGI_OCTANE) { - xb->xb_ioex = xbridge_mapping_setup(xb, 1); - xb->xb_memex = xbridge_mapping_setup(xb, 0); - } - - /* - * Configure all regular PCI devices. - */ - -#ifdef DEBUG - for (dev = 0; dev < xb->xb_nslots; dev++) - printf("device %d: devio %08llx\n", - dev, xbridge_read_reg(xb, BRIDGE_DEVICE(dev))); -#endif - nppb = npccbb = 0; - for (dev = 0; dev < xb->xb_nslots; dev++) { - if (SLOT_EMPTY(xb, dev)) - continue; - - /* - * Count ppb and pccbb devices, we will need their number later. - */ - - tag = pci_make_tag(pc, 0, dev, 0); - bhlcr = pci_conf_read(pc, tag, PCI_BHLC_REG); - if (PCI_HDRTYPE_TYPE(bhlcr) == 1) - nppb++; - if (PCI_HDRTYPE_TYPE(bhlcr) == 2) - npccbb++; - - /* - * We want to avoid changing mapping configuration for - * devices which have been setup by ARCS. - * - * On Octane, the whole on-board I/O widget has been - * set up, with direct mappings into widget space. - * - * On Origin, since direct mappings are expensive, - * everything set up by ARCS has a valid devio - * mapping; those can be identified as they sport the - * widget number in the high address bits. - * - * We will only fix the device-global devio flags on - * devices which have been set up by ARCS. Otherwise, - * we'll need to perform proper PCI resource allocation. - */ - - id = xb->xb_devices[dev].id; - devio = xbridge_read_reg(xb, BRIDGE_DEVICE(dev)); - if (id != PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3) && - id != PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC4)) - need_setup = 1; - else - need_setup = xb->xb_busno != 0 || xb->xb_devio_skew != - ((devio & BRIDGE_DEVICE_BASE_MASK) >> - (24 - BRIDGE_DEVICE_BASE_SHIFT)); - - /* - * Enable byte swapping for DMA, except on IOC3, IOC4 and - * RAD1 devices. - */ - if (id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3) || - id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC4) || - id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_RAD1)) - devio &= - ~(BRIDGE_DEVICE_SWAP_PMU | BRIDGE_DEVICE_SWAP_DIR); - else - devio |= - BRIDGE_DEVICE_SWAP_PMU | BRIDGE_DEVICE_SWAP_DIR; - - /* - * Disable write gathering. - */ - devio &= - ~(BRIDGE_DEVICE_WGATHER_PMU | BRIDGE_DEVICE_WGATHER_DIR); - - /* - * Disable prefetching - on-board isp(4) controllers on - * Octane are set up with this, but this confuses the - * driver. - */ - devio &= ~BRIDGE_DEVICE_PREFETCH; - - /* - * Force cache coherency. - */ - devio |= BRIDGE_DEVICE_COHERENT; - - if (need_setup == 0) { - xbridge_set_devio(xb, dev, devio, 1); - continue; - } - - /* - * Clear any residual devio mapping. - */ - devio &= ~BRIDGE_DEVICE_BASE_MASK; - devio &= ~BRIDGE_DEVICE_IO_MEM; - xbridge_set_devio(xb, dev, devio, 0); - - /* - * We now need to perform the resource allocation for this - * device, which has not been setup by ARCS. - */ - - qd = pci_lookup_quirkdata(PCI_VENDOR(id), PCI_PRODUCT(id)); - if (PCI_HDRTYPE_MULTIFN(bhlcr) || - (qd != NULL && (qd->quirks & PCI_QUIRK_MULTIFUNCTION) != 0)) - nfuncs = 8; - else - nfuncs = 1; - - xbridge_device_setup(xb, dev, nfuncs, devio); - } - - /* - * Configure PCI-PCI and PCI-CardBus bridges, if any. - * - * We do this after all the other PCI devices have been configured - * in order to favour them during resource allocation. - */ - - if (npccbb != 0) { - /* - * If there are PCI-CardBus bridges, we really want to be - * able to have large resource spaces... - */ - if (xb->xb_ioex == NULL) - xb->xb_ioex = xbridge_mapping_setup(xb, 1); - if (xb->xb_memex == NULL) - xb->xb_memex = xbridge_mapping_setup(xb, 0); - } - - secondary = 1; - ppbstride = nppb == 0 ? 0 : (255 - npccbb) / nppb; - for (dev = 0; dev < xb->xb_nslots; dev++) { - if (SLOT_EMPTY(xb, dev)) - continue; - - tag = pci_make_tag(pc, 0, dev, 0); - bhlcr = pci_conf_read(pc, tag, PCI_BHLC_REG); - - switch (PCI_HDRTYPE_TYPE(bhlcr)) { - case 1: /* PCI-PCI bridge */ - ppb_initialize(pc, tag, 0, secondary, - secondary + ppbstride - 1); - secondary += ppbstride; - break; - case 2: /* PCI-CardBus bridge */ - /* - * We do not expect cardbus devices to sport - * PCI-PCI bridges themselves, so only one - * PCI bus will do. - */ - pccbb_initialize(pc, tag, 0, secondary, secondary); - secondary++; - break; - } - } - - if (xb->xb_ioex != NULL) { - extent_destroy(xb->xb_ioex); - xb->xb_ioex = NULL; - } - if (xb->xb_memex != NULL) { - extent_destroy(xb->xb_memex); - xb->xb_memex = NULL; - } -} - -/* - * Make the Octane flash area unavailable in the PCI space extents, so - * that we do not try to map devices in its area. - */ -int -xbridge_extent_chomp(struct xbpci_softc *xb, struct extent *ex) -{ -#ifdef TGT_OCTANE - /* - * On Octane, the boot PROM is part of the onboard IOC3 - * device, and is accessible through the PCI memory space - * (and maybe through the PCI I/O space as well). - * - * To avoid undebuggable surprises, make sure we never use - * this space. - */ - if (sys_config.system_type == SGI_OCTANE && - xb->xb_widget == IP30_BRIDGE_WIDGET) { - u_long fmin, fmax; - - /* - * This relies upon the knowledge that both flash bases - * are contiguous, to perform only one extent operation. - * I don't think we need to be pedantic to the point of - * doing this in two steps, really -- miod - */ - fmin = max(IP30_FLASH_BASE, ex->ex_start); - fmax = min(IP30_FLASH_ALT + IP30_FLASH_SIZE - 1, ex->ex_end); - if (fmax >= fmin) - return extent_alloc_region(ex, fmin, fmax + 1 - fmin, - EX_NOWAIT | EX_MALLOCOK); - } -#endif - - return 0; -} - -/* - * Build resource extents for the MI PCI code to play with. - * These extents cover the configured devio areas, and the large resource - * views, if applicable. - */ -void -xbridge_extent_setup(struct xbpci_softc *xb) -{ - int dev; - int errors; - bus_addr_t start, end; - uint32_t devio; - - snprintf(xb->xb_ioexname, sizeof(xb->xb_ioexname), "%s_io", - DEVNAME(xb)); - xb->xb_ioex = extent_create(xb->xb_ioexname, 0, 0xffffffff, - M_DEVBUF, NULL, 0, EX_NOWAIT | EX_FILLED); - - if (xb->xb_ioex != NULL) { - errors = 0; - /* make all configured devio ranges available... */ - for (dev = 0; dev < xb->xb_nslots; dev++) { - devio = xb->xb_devices[dev].devio; - if (devio == 0 || ISSET(devio, BRIDGE_DEVICE_IO_MEM)) - continue; - start = (devio & BRIDGE_DEVICE_BASE_MASK) << - BRIDGE_DEVICE_BASE_SHIFT; - if (start == 0) - continue; - if (extent_free(xb->xb_ioex, start, - BRIDGE_DEVIO_SIZE(dev), EX_NOWAIT) != 0) { - errors++; - break; - } - } - /* ...as well as the large views, if any */ - if (xb->xb_ioend != 0) { - start = xb->xb_iostart; - if (start == 0) - start = 1; - end = xb->xb_devio_skew << 24; - if (start < end) - if (extent_free(xb->xb_ioex, start, - end, EX_NOWAIT) != 0) - errors++; - - start = (xb->xb_devio_skew + 1) << 24; - if (start < xb->xb_iostart) - start = xb->xb_iostart; - if (extent_free(xb->xb_ioex, start, - xb->xb_ioend + 1 - start, EX_NOWAIT) != 0) - errors++; - } - - if (xbridge_extent_chomp(xb, xb->xb_ioex) != 0) - errors++; - - if (errors != 0) { - extent_destroy(xb->xb_ioex); - xb->xb_ioex = NULL; - } - } - - snprintf(xb->xb_memexname, sizeof(xb->xb_memexname), "%s_mem", - DEVNAME(xb)); - xb->xb_memex = extent_create(xb->xb_memexname, 0, 0xffffffff, - M_DEVBUF, NULL, 0, EX_NOWAIT | EX_FILLED); - - if (xb->xb_memex != NULL) { - errors = 0; - /* make all configured devio ranges available... */ - for (dev = 0; dev < xb->xb_nslots; dev++) { - devio = xb->xb_devices[dev].devio; - if (devio == 0 || !ISSET(devio, BRIDGE_DEVICE_IO_MEM)) - continue; - start = (devio & BRIDGE_DEVICE_BASE_MASK) << - BRIDGE_DEVICE_BASE_SHIFT; - if (start == 0) - continue; - if (extent_free(xb->xb_memex, start, - BRIDGE_DEVIO_SIZE(dev), EX_NOWAIT) != 0) { - errors++; - break; - } - } - /* ...as well as the large views, if any */ - if (xb->xb_memend != 0) { - start = xb->xb_memstart; - if (start == 0) - start = 1; - end = xb->xb_devio_skew << 24; - if (start < end) - if (extent_free(xb->xb_memex, start, - end, EX_NOWAIT) != 0) - errors++; - - start = (xb->xb_devio_skew + 1) << 24; - if (start < xb->xb_memstart) - start = xb->xb_memstart; - if (extent_free(xb->xb_memex, start, - xb->xb_memend + 1 - start, EX_NOWAIT) != 0) - errors++; - } - - if (xbridge_extent_chomp(xb, xb->xb_memex) != 0) - errors++; - - if (errors != 0) { - extent_destroy(xb->xb_memex); - xb->xb_memex = NULL; - } - } -} - -struct extent * -xbridge_mapping_setup(struct xbpci_softc *xb, int io) -{ - bus_addr_t membase, offs; - bus_size_t len; - paddr_t base; - u_long start, end; - struct extent *ex = NULL; - - if (io) { - /* - * I/O mappings are available in the widget at offset - * BRIDGE_PCI_IO_SPACE_BASE onwards, but weren't working - * correctly until Bridge revision 4 (apparently, what - * didn't work was the byteswap logic). - * - * Also, this direct I/O space is not supported on PIC - * widgets. - */ - - if (!ISSET(xb->xb_flags, XF_NO_DIRECT_IO)) { - offs = BRIDGE_PCI_IO_SPACE_BASE; - len = BRIDGE_PCI_IO_SPACE_LENGTH; - base = xbow_widget_map_space(xb->xb_bow, - xb->xb_widget, &offs, &len); - } else - base = 0; - - if (base != 0) { - if (offs + len > BRIDGE_PCI_IO_SPACE_BASE + - BRIDGE_PCI_IO_SPACE_LENGTH) - len = BRIDGE_PCI_IO_SPACE_BASE + - BRIDGE_PCI_IO_SPACE_LENGTH - offs; - -#ifdef DEBUG - printf("direct io %#lx-%#lx base %#lx\n", - offs, offs + len - 1, base); -#endif - offs -= BRIDGE_PCI_IO_SPACE_BASE; - - ex = extent_create("xbridge_direct_io", - offs == 0 ? 1 : offs, offs + len - 1, - M_DEVBUF, NULL, 0, EX_NOWAIT); - - /* - * Note that we do not need to invoke - * xbridge_extent_chomp() here since we will - * reserve the whole devio area. - */ - - if (ex != NULL) { - xb->xb_io_bus_space->bus_base = base - offs; - xb->xb_io_bus_space->_space_map = - xbridge_space_map_io; - xb->xb_io_bus_space->_space_subregion = - xbridge_space_region_io; - - xb->xb_io_bus_space_sw->bus_base = base - offs; - xb->xb_io_bus_space_sw->_space_map = - xbridge_space_map_io; - xb->xb_io_bus_space_sw->_space_subregion = - xbridge_space_region_io; - - xb->xb_iostart = offs; - xb->xb_ioend = offs + len - 1; - } - } - } else { - /* - * Memory mappings are available in the widget at offset - * BRIDGE_PCI#_MEM_SPACE_BASE onwards. - */ - - membase = xb->xb_busno == 0 ? BRIDGE_PCI0_MEM_SPACE_BASE : - BRIDGE_PCI1_MEM_SPACE_BASE; - offs = membase; - len = BRIDGE_PCI_MEM_SPACE_LENGTH; - base = xbow_widget_map_space(xb->xb_bow, - xb->xb_widget, &offs, &len); - - if (base != 0) { - /* - * Only the low 30 bits of memory BAR are honoured - * by the hardware, thus restricting memory mappings - * to 1GB. - */ - if (offs + len > membase + BRIDGE_PCI_MEM_SPACE_LENGTH) - len = membase + BRIDGE_PCI_MEM_SPACE_LENGTH - - offs; - -#ifdef DEBUG - printf("direct mem %#lx-%#lx base %#lx\n", - offs, offs + len - 1, base); -#endif - offs -= membase; - - ex = extent_create("xbridge_direct_mem", - offs == 0 ? 1 : offs, offs + len - 1, - M_DEVBUF, NULL, 0, EX_NOWAIT); - - /* - * Note that we do not need to invoke - * xbridge_extent_chomp() here since we will - * reserve the whole devio area. - */ - - if (ex != NULL) { - xb->xb_mem_bus_space->bus_base = base - offs; - xb->xb_mem_bus_space->_space_map = - xbridge_space_map_mem; - xb->xb_mem_bus_space->_space_subregion = - xbridge_space_region_mem; - - xb->xb_mem_bus_space_sw->bus_base = base - offs; - xb->xb_mem_bus_space_sw->_space_map = - xbridge_space_map_mem; - xb->xb_mem_bus_space_sw->_space_subregion = - xbridge_space_region_mem; - - xb->xb_memstart = offs; - xb->xb_memend = offs + len - 1; - } - } - } - - if (ex != NULL) { - /* - * Remove the devio mapping range from the extent - * to avoid ambiguous mappings. - * - * Note that xbow_widget_map_space() may have returned - * a range in which the devio area does not appear. - */ - start = xb->xb_devio_skew << 24; - end = (xb->xb_devio_skew + 1) << 24; - - if (end >= ex->ex_start && start <= ex->ex_end) { - if (start < ex->ex_start) - start = ex->ex_start; - if (end > ex->ex_end + 1) - end = ex->ex_end + 1; - if (extent_alloc_region(ex, start, end - start, - EX_NOWAIT | EX_MALLOCOK) != 0) { - printf("%s: failed to expurge devio range" - " from %s large extent\n", - DEVNAME(xb), io ? "i/o" : "mem"); - extent_destroy(ex); - ex = NULL; - } - } - } - - return ex; -} - -/* - * Flags returned by xbridge_resource_explore() - */ -#define XR_IO 0x01 /* needs I/O mappings */ -#define XR_MEM 0x02 /* needs memory mappings */ -#define XR_IO_OFLOW_S 0x04 /* can't fit I/O in a short devio */ -#define XR_MEM_OFLOW_S 0x08 /* can't fit memory in a short devio */ -#define XR_IO_OFLOW 0x10 /* can't fit I/O in a large devio */ -#define XR_MEM_OFLOW 0x20 /* can't fit memory in a large devio */ - -int -xbridge_resource_explore(struct xbpci_softc *xb, pcitag_t tag, - struct extent *ioex, struct extent *memex) -{ - pci_chipset_tag_t pc = &xb->xb_pc; - pcireg_t bhlc, type, addr, mask; - bus_addr_t base; - bus_size_t size; - int reg, reg_start, reg_end, reg_rom; - int rc = 0; - - bhlc = pci_conf_read(pc, tag, PCI_BHLC_REG); - switch (PCI_HDRTYPE_TYPE(bhlc)) { - case 0: - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_END; - reg_rom = PCI_ROM_REG; - break; - case 1: /* PCI-PCI bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PPB_END; - reg_rom = 0; /* 0x38 */ - break; - case 2: /* PCI-CardBus bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PCB_END; - reg_rom = 0; - break; - default: - return rc; - } - - for (reg = reg_start; reg < reg_end; reg += 4) { - if (pci_mapreg_probe(pc, tag, reg, &type) == 0) - continue; - - if (pci_mapreg_info(pc, tag, reg, type, NULL, &size, NULL)) - continue; - - switch (type) { - case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT: - reg += 4; - /* FALLTHROUGH */ - case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_32BIT: - rc |= XR_MEM; - if (memex != NULL) { - if (size > memex->ex_end - memex->ex_start) - rc |= XR_MEM_OFLOW | XR_MEM_OFLOW_S; - else if (extent_alloc(memex, size, size, - 0, 0, 0, &base) != 0) - rc |= XR_MEM_OFLOW | XR_MEM_OFLOW_S; - else if (base >= BRIDGE_DEVIO_SHORT) - rc |= XR_MEM_OFLOW_S; - } else - rc |= XR_MEM_OFLOW | XR_MEM_OFLOW_S; - break; - case PCI_MAPREG_TYPE_IO: - rc |= XR_IO; - if (ioex != NULL) { - if (size > ioex->ex_end - ioex->ex_start) - rc |= XR_IO_OFLOW | XR_IO_OFLOW_S; - else if (extent_alloc(ioex, size, size, - 0, 0, 0, &base) != 0) - rc |= XR_IO_OFLOW | XR_IO_OFLOW_S; - else if (base >= BRIDGE_DEVIO_SHORT) - rc |= XR_IO_OFLOW_S; - } else - rc |= XR_IO_OFLOW | XR_IO_OFLOW_S; - break; - } - } - - if (reg_rom != 0) { - addr = pci_conf_read(pc, tag, reg_rom); - pci_conf_write(pc, tag, reg_rom, ~PCI_ROM_ENABLE); - mask = pci_conf_read(pc, tag, reg_rom); - pci_conf_write(pc, tag, reg_rom, addr); - size = PCI_ROM_SIZE(mask); - - if (size != 0) { - rc |= XR_MEM; - if (memex != NULL) { - if (size > memex->ex_end - memex->ex_start) - rc |= XR_MEM_OFLOW | XR_MEM_OFLOW_S; - else if (extent_alloc(memex, size, size, - 0, 0, 0, &base) != 0) - rc |= XR_MEM_OFLOW | XR_MEM_OFLOW_S; - else if (base >= BRIDGE_DEVIO_SHORT) - rc |= XR_MEM_OFLOW_S; - } else - rc |= XR_MEM_OFLOW | XR_MEM_OFLOW_S; - } - } - - return rc; -} - -void -xbridge_resource_manage(struct xbpci_softc *xb, pcitag_t tag, - struct extent *ioex, struct extent *memex) -{ - pci_chipset_tag_t pc = &xb->xb_pc; - pcireg_t bhlc, type, mask; - bus_addr_t base; - bus_size_t size; - int reg, reg_start, reg_end, reg_rom; - - bhlc = pci_conf_read(pc, tag, PCI_BHLC_REG); - switch (PCI_HDRTYPE_TYPE(bhlc)) { - case 0: - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_END; - reg_rom = PCI_ROM_REG; - break; - case 1: /* PCI-PCI bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PPB_END; - reg_rom = 0; /* 0x38 */ - break; - case 2: /* PCI-CardBus bridge */ - reg_start = PCI_MAPREG_START; - reg_end = PCI_MAPREG_PCB_END; - reg_rom = 0; - break; - default: - return; - } - - for (reg = reg_start; reg < reg_end; reg += 4) { - if (pci_mapreg_probe(pc, tag, reg, &type) == 0) - continue; - - if (pci_mapreg_info(pc, tag, reg, type, &base, &size, NULL)) - continue; - - /* - * Note that we do not care about the existing BAR values, - * since these devices either have not been setup by ARCS - * or do not matter for early system setup (such as - * optional IOC3 PCI boards, which will get setup by - * ARCS but can be reinitialized as we see fit). - */ -#ifdef DEBUG - printf("tag %04lx bar %02x type %d base %#lx size %#lx", - tag, reg, type, base, size); -#endif - switch (type) { - case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT: - /* - * Since our mapping ranges are restricted to - * at most 30 bits, the upper part of the 64 bit - * BAR registers is always zero. - */ - pci_conf_write(pc, tag, reg + 4, 0); - /* FALLTHROUGH */ - case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_32BIT: - if (memex != NULL) { - if (extent_alloc(memex, size, size, 0, 0, 0, - &base) != 0) - base = 0; - } else - base = 0; - break; - case PCI_MAPREG_TYPE_IO: - if (ioex != NULL) { - if (extent_alloc(ioex, size, size, 0, 0, 0, - &base) != 0) - base = 0; - } else - base = 0; - break; - } - -#ifdef DEBUG - printf(" setup at %#lx\n", base); -#endif - pci_conf_write(pc, tag, reg, base); - - if (type == (PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT)) - reg += 4; - } - - if (reg_rom != 0) { - base = (bus_addr_t)pci_conf_read(pc, tag, reg_rom); - pci_conf_write(pc, tag, reg_rom, ~PCI_ROM_ENABLE); - mask = pci_conf_read(pc, tag, reg_rom); - size = PCI_ROM_SIZE(mask); - - if (size != 0) { -#ifdef DEBUG - printf("bar %02x type rom base %#lx size %#lx", - reg_rom, base, size); -#endif - if (memex != NULL) { - if (extent_alloc(memex, size, size, 0, 0, 0, - &base) != 0) - base = 0; - } else - base = 0; -#ifdef DEBUG - printf(" setup at %#lx\n", base); -#endif - } else - base = 0; - - /* ROM intentionally left disabled */ - pci_conf_write(pc, tag, reg_rom, base); - } -} - -void -xbridge_device_setup(struct xbpci_softc *xb, int dev, int nfuncs, - uint32_t devio) -{ - pci_chipset_tag_t pc = &xb->xb_pc; - int function; - pcitag_t tag; - pcireg_t id, csr; - uint32_t baseio; - int resources; - int io_devio, mem_devio; - struct extent *ioex, *memex; - - /* - * In a first step, we enumerate all the requested resources, - * and check if they could fit within devio mappings. - * - * If devio can't afford us the mappings we need, we'll - * try and allocate a large window. - */ - - /* - * Allocate extents to use for devio mappings if necessary. - * This can fail; in that case we'll try to use a large mapping - * whenever possible, or silently fail to configure the device. - */ - if (xb->xb_ioex != NULL) - ioex = NULL; - else { - ioex = extent_create("xbridge_io", - 0, BRIDGE_DEVIO_LARGE - 1, - M_DEVBUF, NULL, 0, EX_NOWAIT); -#ifdef DEBUG - if (ioex == NULL) - printf("%s: ioex extent_create failed\n", __func__); -#endif - } - if (xb->xb_memex != NULL) - memex = NULL; - else { - memex = extent_create("xbridge_mem", - 0, BRIDGE_DEVIO_LARGE - 1, - M_DEVBUF, NULL, 0, EX_NOWAIT); -#ifdef DEBUG - if (memex == NULL) - printf("%s: memex extent_create failed\n", __func__); -#endif - } - - resources = 0; - for (function = 0; function < nfuncs; function++) { - tag = pci_make_tag(pc, 0, dev, function); - id = pci_conf_read(pc, tag, PCI_ID_REG); - - if (PCI_VENDOR(id) == PCI_VENDOR_INVALID || - PCI_VENDOR(id) == 0) - continue; - - csr = pci_conf_read(pc, tag, PCI_COMMAND_STATUS_REG); - pci_conf_write(pc, tag, PCI_COMMAND_STATUS_REG, csr & - ~(PCI_COMMAND_IO_ENABLE | PCI_COMMAND_MEM_ENABLE)); - - resources |= xbridge_resource_explore(xb, tag, ioex, memex); - } -#ifdef DEBUG - printf("resources mask: %02x\n", resources); -#endif - - if (memex != NULL) { - extent_destroy(memex); - memex = NULL; - } - if (ioex != NULL) { - extent_destroy(ioex); - ioex = NULL; - } - - /* - * In a second step, if resources can be mapped using devio slots, - * allocate them. Otherwise, or if we can't get a devio slot - * big enough for the resources we need to map, we'll need - * to get a large window mapping. - * - * Note that, on Octane, we try to avoid using devio whenever - * possible. - */ - - io_devio = -1; - if (ISSET(resources, XR_IO)) { - if (!ISSET(resources, XR_IO_OFLOW) && - (sys_config.system_type != SGI_OCTANE || - xb->xb_ioex == NULL)) - io_devio = xbridge_allocate_devio(xb, dev, - ISSET(resources, XR_IO_OFLOW_S)); - if (io_devio >= 0) { - baseio = (xb->xb_devio_skew << 24) | - PIC_DEVIO_OFFS(xb->xb_busno, io_devio); - xbridge_set_devio(xb, io_devio, devio | - (baseio >> BRIDGE_DEVICE_BASE_SHIFT), 1); - - ioex = extent_create("xbridge_io", baseio, - baseio + BRIDGE_DEVIO_SIZE(io_devio) - 1, - M_DEVBUF, NULL, 0, EX_NOWAIT); - } else { - /* - * Try to get a large window mapping if we don't - * have one already. - */ - if (xb->xb_ioex == NULL) - xb->xb_ioex = xbridge_mapping_setup(xb, 1); - } - } - - mem_devio = -1; - if (ISSET(resources, XR_MEM)) { - if (!ISSET(resources, XR_MEM_OFLOW) && - sys_config.system_type != SGI_OCTANE) - mem_devio = xbridge_allocate_devio(xb, dev, - ISSET(resources, XR_MEM_OFLOW_S)); - if (mem_devio >= 0) { - baseio = (xb->xb_devio_skew << 24) | - PIC_DEVIO_OFFS(xb->xb_busno, mem_devio); - xbridge_set_devio(xb, mem_devio, devio | - BRIDGE_DEVICE_IO_MEM | - (baseio >> BRIDGE_DEVICE_BASE_SHIFT), 1); - - memex = extent_create("xbridge_mem", baseio, - baseio + BRIDGE_DEVIO_SIZE(mem_devio) - 1, - M_DEVBUF, NULL, 0, EX_NOWAIT); - } else { - /* - * Try to get a large window mapping if we don't - * have one already. - */ - if (xb->xb_memex == NULL) - xb->xb_memex = xbridge_mapping_setup(xb, 0); - } - } - - /* - * Finally allocate the resources proper and update the - * device BARs accordingly. - */ - - for (function = 0; function < nfuncs; function++) { - tag = pci_make_tag(pc, 0, dev, function); - id = pci_conf_read(pc, tag, PCI_ID_REG); - - if (PCI_VENDOR(id) == PCI_VENDOR_INVALID || - PCI_VENDOR(id) == 0) - continue; - - xbridge_resource_manage(xb, tag, - ioex != NULL ? ioex : xb->xb_ioex, - memex != NULL ? memex : xb->xb_memex); - } - - if (memex != NULL) - extent_destroy(memex); - if (ioex != NULL) - extent_destroy(ioex); -} - -int -xbridge_ppb_setup(void *cookie, pcitag_t tag, bus_addr_t *iostart, - bus_addr_t *ioend, bus_addr_t *memstart, bus_addr_t *memend) -{ - struct xbpci_softc *xb = cookie; - pci_chipset_tag_t pc = &xb->xb_pc; - uint32_t base, devio; - bus_size_t exsize; - u_long exstart; - int dev, devio_idx, tries; - - pci_decompose_tag(pc, tag, NULL, &dev, NULL); - devio = xbridge_read_reg(xb, BRIDGE_DEVICE(dev)); - - /* - * Since our caller computes resource needs starting at zero, we - * can ignore the start values when computing the amount of - * resources we'll need. - */ - - /* - * Try and allocate I/O resources first, as we may not be able - * to use a large I/O mapping, in which case we want to use our - * reserved devio for this purpose. - */ - - exsize = *ioend; - *iostart = 0xffffffff; - *ioend = 0; - if (exsize++ != 0) { - /* try to allocate through a devio slot whenever possible... */ - if (exsize < BRIDGE_DEVIO_SHORT) - devio_idx = xbridge_allocate_devio(xb, dev, 0); - else if (exsize < BRIDGE_DEVIO_LARGE) - devio_idx = xbridge_allocate_devio(xb, dev, 1); - else - devio_idx = -1; - - /* ...if it fails, try the large view.... */ - if (devio_idx < 0 && xb->xb_ioex == NULL) - xb->xb_ioex = xbridge_mapping_setup(xb, 1); - - /* ...if it is not available, try to get a devio slot anyway. */ - if (devio_idx < 0 && xb->xb_ioex == NULL) { - if (exsize > BRIDGE_DEVIO_SHORT) - devio_idx = xbridge_allocate_devio(xb, dev, 1); - if (devio_idx < 0) - devio_idx = xbridge_allocate_devio(xb, dev, 0); - } - - if (devio_idx >= 0) { - base = (xb->xb_devio_skew << 24) | - PIC_DEVIO_OFFS(xb->xb_busno, devio_idx); - xbridge_set_devio(xb, devio_idx, devio | - (base >> BRIDGE_DEVICE_BASE_SHIFT), 1); - *iostart = base; - *ioend = base + BRIDGE_DEVIO_SIZE(devio_idx) - 1; - } else if (xb->xb_ioex != NULL) { - /* - * We know that the direct I/O resource range fits - * within the 32 bit address space, so our allocation, - * if successful, will work as a 32 bit i/o range. - */ - if (exsize < 1UL << 12) - exsize = 1UL << 12; - for (tries = 0; tries < 5; tries++) { - if (extent_alloc(xb->xb_ioex, exsize, - 1UL << 12, 0, 0, EX_NOWAIT | EX_MALLOCOK, - &exstart) == 0) { - *iostart = exstart; - *ioend = exstart + exsize - 1; - break; - } - exsize >>= 1; - if (exsize < 1UL << 12) - break; - } - } - } - - exsize = *memend; - *memstart = 0xffffffff; - *memend = 0; - if (exsize++ != 0) { - /* try to allocate through a devio slot whenever possible... */ - if (exsize < BRIDGE_DEVIO_SHORT) - devio_idx = xbridge_allocate_devio(xb, dev, 0); - else if (exsize < BRIDGE_DEVIO_LARGE) - devio_idx = xbridge_allocate_devio(xb, dev, 1); - else - devio_idx = -1; - - /* ...if it fails, try the large view.... */ - if (devio_idx < 0 && xb->xb_memex == NULL) - xb->xb_memex = xbridge_mapping_setup(xb, 0); - - /* ...if it is not available, try to get a devio slot anyway. */ - if (devio_idx < 0 && xb->xb_memex == NULL) { - if (exsize > BRIDGE_DEVIO_SHORT) - devio_idx = xbridge_allocate_devio(xb, dev, 1); - if (devio_idx < 0) - devio_idx = xbridge_allocate_devio(xb, dev, 0); - } - - if (devio_idx >= 0) { - base = (xb->xb_devio_skew << 24) | - PIC_DEVIO_OFFS(xb->xb_busno, devio_idx); - xbridge_set_devio(xb, devio_idx, devio | - BRIDGE_DEVICE_IO_MEM | - (base >> BRIDGE_DEVICE_BASE_SHIFT), 1); - *memstart = base; - *memend = base + BRIDGE_DEVIO_SIZE(devio_idx) - 1; - } else if (xb->xb_memex != NULL) { - /* - * We know that the direct memory resource range fits - * within the 32 bit address space, and is limited to - * 30 bits, so our allocation, if successful, will - * work as a 32 bit memory range. - */ - if (exsize < 1UL << 20) - exsize = 1UL << 20; - for (tries = 0; tries < 5; tries++) { - if (extent_alloc(xb->xb_memex, exsize, - 1UL << 20, 0, 0, EX_NOWAIT | EX_MALLOCOK, - &exstart) == 0) { - *memstart = exstart; - *memend = exstart + exsize - 1; - break; - } - exsize >>= 1; - if (exsize < 1UL << 20) - break; - } - } - } - - return 0; -} - -#if NCARDBUS > 0 - -static struct rb_md_fnptr xbridge_rb_md_fn = { - xbridge_rbus_space_map, - xbridge_rbus_space_unmap -}; - -int -xbridge_rbus_space_map(bus_space_tag_t t, bus_addr_t addr, bus_size_t size, - int flags, bus_space_handle_t *bshp) -{ - return bus_space_map(t, addr, size, flags, bshp); -} - -void -xbridge_rbus_space_unmap(bus_space_tag_t t, bus_space_handle_t h, - bus_size_t size, bus_addr_t *addrp) -{ - bus_space_unmap(t, h, size); - *addrp = h - t->bus_base; -} - -void * -xbridge_rbus_parent_io(struct pci_attach_args *pa) -{ - struct extent *ex = pa->pa_ioex; - bus_addr_t start, end; - rbus_tag_t rb = NULL; - - /* - * We want to force I/O mappings to lie in the low 16 bits - * area. This is mandatory for 16-bit pcmcia devices; and - * although 32-bit cardbus devices could use a larger range, - * the pccbb driver doesn't enable the large I/O windows. - */ - if (ex != NULL) { - start = 0; - end = 0x10000; - if (start < ex->ex_start) - start = ex->ex_start; - if (end > ex->ex_end) - end = ex->ex_end; - - if (start < end) { - rb = rbus_new_root_share(pa->pa_iot, ex, - start, end - start); - if (rb != NULL) - rb->rb_md = &xbridge_rb_md_fn; - } - } - - /* - * We are not allowed to return NULL. If we can't provide - * resources, return a valid body which will fail requests. - */ - if (rb == NULL) - rb = rbus_new_body(pa->pa_iot, NULL, 0, 0, RBUS_SPACE_INVALID); - - return rb; -} - -void * -xbridge_rbus_parent_mem(struct pci_attach_args *pa) -{ - struct xbpci_softc *xb = pa->pa_pc->pc_conf_v; - struct extent *ex = pa->pa_memex; - bus_addr_t start; - rbus_tag_t rb = NULL; - - /* - * There is no restriction for the memory mappings, - * however we need to make sure these won't hit the - * devio range (for md_space_unmap to work correctly). - */ - if (ex != NULL) { - start = (xb->xb_devio_skew + 1) << 24; - if (start < ex->ex_start) - start = ex->ex_start; - - if (start < ex->ex_end) { - rb = rbus_new_root_share(pa->pa_memt, ex, - start, ex->ex_end - start); - if (rb != NULL) - rb->rb_md = &xbridge_rb_md_fn; - } - } - - /* - * We are not allowed to return NULL. If we can't provide - * resources, return a valid body which will fail requests. - */ - if (rb == NULL) - rb = rbus_new_body(pa->pa_iot, NULL, 0, 0, RBUS_SPACE_INVALID); - - return rb; -} - -#endif /* NCARDBUS > 0 */ - -int -xbridge_allocate_devio(struct xbpci_softc *xb, int dev, int wantlarge) -{ -#ifdef DEBUG - int orig_dev = dev; -#endif - - /* - * If the preferred slot is available and matches the size requested, - * use it. - */ - - if (!ISSET(xb->xb_devio_usemask, 1 << dev)) { - if (BRIDGE_DEVIO_SIZE(dev) >= - (wantlarge ? BRIDGE_DEVIO_LARGE : BRIDGE_DEVIO_SHORT)) { -#ifdef DEBUG - printf("%s(%d,%d): using reserved entry\n", - __func__, dev, wantlarge); -#endif - return dev; - } - } - - /* - * Otherwise pick the smallest available devio matching our size - * request. - */ - - for (dev = 0; dev < xb->xb_nslots; dev++) { - if (ISSET(xb->xb_devio_usemask, 1 << dev)) - continue; /* devio in use */ - - if (!SLOT_EMPTY(xb, dev)) - continue; /* devio to be used soon */ - - if (BRIDGE_DEVIO_SIZE(dev) >= - (wantlarge ? BRIDGE_DEVIO_LARGE : BRIDGE_DEVIO_SHORT)) { -#ifdef DEBUG - printf("%s(%d,%d): using unused entry %d\n", - __func__, orig_dev, wantlarge, dev); -#endif - return dev; - } - } - -#ifdef DEBUG - printf("%s(%d,%d): no entry available\n", - __func__, orig_dev, wantlarge); -#endif - return -1; -} - -void -xbridge_set_devio(struct xbpci_softc *xb, int dev, uint32_t devio, int final) -{ - xbridge_write_reg(xb, BRIDGE_DEVICE(dev), devio); - (void)xbridge_read_reg(xb, WIDGET_TFLUSH); - xb->xb_devices[dev].devio = devio; - if (final) - SET(xb->xb_devio_usemask, 1 << dev); -#ifdef DEBUG - printf("device %d: new %sdevio %08x\n", - dev, final ? "final " : "", devio); -#endif -} - -#ifdef DDB -void xbridge_ddb(void); -void -xbridge_ddb() -{ - struct xbpci_softc *xb; - unsigned int n, intrbit; - - for (n = 0; n < xbpci_cd.cd_ndevs; n++) { - xb = xbpci_cd.cd_devs[n]; - if (xb == NULL) - continue; - - printf("%s: ISR %p IER %p xb_ier %p\n", - xb->xb_dev.dv_xname, - (void *)xbridge_read_reg(xb, BRIDGE_ISR), - (void *)xbridge_read_reg(xb, BRIDGE_IER), - (void *)xb->xb_ier); - - printf("mode %p dev %p\n", - (void *)xbridge_read_reg(xb, BRIDGE_INT_MODE), - (void *)xbridge_read_reg(xb, BRIDGE_INT_DEV)); - - for (intrbit = 0; intrbit < 8; intrbit++) - printf("IRQ%u to %p\n", intrbit, - (void *)xbridge_read_reg(xb, - BRIDGE_INT_ADDR(intrbit))); - - printf("%s: PCICFG %08llx ERR %08llx:%08llx\n", - xb->xb_dev.dv_xname, - xbridge_read_reg(xb, BRIDGE_PCI_CFG), - xbridge_read_reg(xb, BRIDGE_PCI_ERR_UPPER), - xbridge_read_reg(xb, BRIDGE_PCI_ERR_LOWER)); - } -} -#endif diff --git a/sys/arch/sgi/xbow/xbridgereg.h b/sys/arch/sgi/xbow/xbridgereg.h deleted file mode 100644 index c473f2b3cdb..00000000000 --- a/sys/arch/sgi/xbow/xbridgereg.h +++ /dev/null @@ -1,340 +0,0 @@ -/* $OpenBSD: xbridgereg.h,v 1.16 2021/03/11 11:17:00 jsg Exp $ */ - -/* - * Copyright (c) 2008, 2009 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * IP27/IP30/IP35 Bridge and XBridge Registers - * IP35 PIC Registers - */ - -#define BRIDGE_REGISTERS_SIZE 0x00030000 -#define BRIDGE_BUS_OFFSET 0x00800000 - -#define BRIDGE_NBUSES 1 -#define PIC_NBUSES 2 - -#define BRIDGE_NSLOTS 8 -#define PIC_NSLOTS 4 -#define MAX_SLOTS BRIDGE_NSLOTS - -#define BRIDGE_NINTRS 8 - -#define PIC_WIDGET_STATUS_PCIX_SPEED_MASK 0x0000000c00000000UL -#define PIC_WIDGET_STATUS_PCIX_SPEED_SHIFT 34 -#define PIC_WIDGET_STATUS_PCIX_MODE 0x0000000200000000UL - -#define PIC_WIDGET_CONTROL_NO_SNOOP 0x4000000000000000UL -#define PIC_WIDGET_CONTROL_RELAX_ORDER 0x2000000000000000UL -#define BRIDGE_WIDGET_CONTROL_IO_SWAP 0x00800000 -#define BRIDGE_WIDGET_CONTROL_MEM_SWAP 0x00400000 -#define BRIDGE_WIDGET_CONTROL_LARGE_PAGES 0x00200000 -#define BRIDGE_WIDGET_CONTROL_SPEED_MASK 0x00000030 -#define BRIDGE_WIDGET_CONTROL_SPEED_SHIFT 4 - -/* Response Buffer Address */ -#define BRIDGE_WIDGET_RESP_UPPER 0x00000060 -#define BRIDGE_WIDGET_RESP_LOWER 0x00000068 - -/* - * DMA Direct Window - * - * The direct map register allows the 2GB direct window to map to - * a given widget address space. The upper bits of the XIO address, - * identifying the node to access, are provided in the low-order - * bits of the register. - */ - -#define BRIDGE_DIR_MAP 0x00000080 - -#define BRIDGE_DIRMAP_WIDGET_SHIFT 20 -#define BRIDGE_DIRMAP_ADD_512MB 0x00020000 /* add 512MB */ -#define BRIDGE_DIRMAP_BASE_MASK 0x0001ffff -#define BRIDGE_DIRMAP_BASE_SHIFT 31 - -#define BRIDGE_PCI0_MEM_SPACE_BASE 0x0000000040000000ULL -#define BRIDGE_PCI_MEM_SPACE_LENGTH 0x0000000040000000ULL -#define BRIDGE_PCI1_MEM_SPACE_BASE 0x00000000c0000000ULL -#define BRIDGE_PCI_IO_SPACE_BASE 0x0000000100000000ULL -#define BRIDGE_PCI_IO_SPACE_LENGTH 0x0000000100000000ULL - -#define BRIDGE_NIC 0x000000b0 - -#define BRIDGE_BUS_TIMEOUT 0x000000c0 -#define BRIDGE_BUS_PCI_RETRY_CNT_SHIFT 0 -#define BRIDGE_BUS_PCI_RETRY_CNT_MASK 0x000003ff -#define BRIDGE_BUS_GIO_TIMEOUT 0x00001000 -#define BRIDGE_BUS_PCI_RETRY_HOLD_SHIFT 16 -#define BRIDGE_BUS_PCI_RETRY_HOLD_MASK 0x001f0000 - -#define BRIDGE_PCI_CFG 0x000000c8 -#define BRIDGE_PCI_ERR_UPPER 0x000000d0 -#define BRIDGE_PCI_ERR_LOWER 0x000000d8 - -/* - * Interrupt handling - */ - -#define BRIDGE_ISR 0x00000100 -#define BRIDGE_IER 0x00000108 -#define BRIDGE_ICR 0x00000110 -#define BRIDGE_INT_MODE 0x00000118 -#define BRIDGE_INT_DEV 0x00000120 -#define BRIDGE_INT_HOST_ERR 0x00000128 -#define BRIDGE_INT_ADDR(d) (0x00000130 + 8 * (d)) -/* the following two are XBridge-only */ -#define BRIDGE_INT_FORCE_ALWAYS(d) (0x00000180 + 8 * (d)) -#define BRIDGE_INT_FORCE_PIN(d) (0x000001c0 + 8 * (d)) - -/* - * BRIDGE_ISR bits (bits 32 and beyond are PIC only) - */ - -/* PCI-X split completion message parity error */ -#define BRIDGE_ISR_PCIX_SPLIT_MSG_PARITY 0x0000200000000000ULL -/* PCI-X split completion error message */ -#define BRIDGE_ISR_PCIX_SPLIT_EMSG 0x0000100000000000ULL -/* PCI-X split completion timeout */ -#define BRIDGE_ISR_PCIX_SPLIT_TO 0x0000080000000000ULL -/* PCI-X unexpected completion cycle */ -#define BRIDGE_ISR_PCIX_UNEX_COMP 0x0000040000000000ULL -/* internal RAM parity error */ -#define BRIDGE_ISR_INT_RAM_PERR 0x0000020000000000ULL -/* PCI/PCI-X arbitration error */ -#define BRIDGE_ISR_PCIX_ARB_ERR 0x0000010000000000ULL -/* PCI-X read request timeout */ -#define BRIDGE_ISR_PCIX_REQ_TMO 0x0000008000000000ULL -/* PCI-X target abort */ -#define BRIDGE_ISR_PCIX_TABORT 0x0000004000000000ULL -/* PCI-X PERR */ -#define BRIDGE_ISR_PCIX_PERR 0x0000002000000000ULL -/* PCI-X SERR */ -#define BRIDGE_ISR_PCIX_SERR 0x0000001000000000ULL -/* PCI-X PIO retry counter exceeded */ -#define BRIDGE_ISR_PCIX_MRETRY 0x0000000800000000ULL -/* PCI-X master timeout */ -#define BRIDGE_ISR_PCIX_MTMO 0x0000000400000000ULL -/* PCI-X data cycle parity error */ -#define BRIDGE_ISR_PCIX_D_PARITY 0x0000000200000000ULL -/* PCI-X address or attribute cycle parity error */ -#define BRIDGE_ISR_PCIX_A_PARITY 0x0000000100000000ULL -/* multiple errors occurred - bridge only */ -#define BRIDGE_ISR_MULTIPLE_ERR 0x0000000080000000ULL -/* PMU access fault */ -#define BRIDGE_ISR_PMU_ESIZE_FAULT 0x0000000040000000ULL -/* unexpected xtalk incoming response */ -#define BRIDGE_ISR_UNEXPECTED_RESP 0x0000000020000000ULL -/* xtalk incoming response framing error */ -#define BRIDGE_ISR_BAD_XRESP_PACKET 0x0000000010000000ULL -/* xtalk incoming request framing error */ -#define BRIDGE_ISR_BAD_XREQ_PACKET 0x0000000008000000ULL -/* xtalk incoming response command word error bit set */ -#define BRIDGE_ISR_RESP_XTALK_ERR 0x0000000004000000ULL -/* xtalk incoming request command word error bit set */ -#define BRIDGE_ISR_REQ_XTALK_ERR 0x0000000002000000ULL -/* request packet has invalid address for this widget */ -#define BRIDGE_ISR_INVALID_ADDRESS 0x0000000001000000ULL -/* request operation not supported by the bridge */ -#define BRIDGE_ISR_UNSUPPORTED_XOP 0x0000000000800000ULL -/* request packet overflow */ -#define BRIDGE_ISR_XREQ_FIFO_OFLOW 0x0000000000400000ULL -/* LLP receiver sequence number error */ -#define BRIDGE_ISR_LLP_REC_SNERR 0x0000000000200000ULL -/* LLP receiver check bit error */ -#define BRIDGE_ISR_LLP_REC_CBERR 0x0000000000100000ULL -/* LLP receiver retry count exceeded */ -#define BRIDGE_ISR_LLP_RCTY 0x0000000000080000ULL -/* LLP transmitter side required retry */ -#define BRIDGE_ISR_LLP_TX_RETRY 0x0000000000040000ULL -/* LLP transmitter retry count exceeded */ -#define BRIDGE_ISR_LLP_TCTY 0x0000000000020000ULL -/* (ATE) SSRAM parity error - bridge only */ -#define BRIDGE_ISR_SSRAM_PERR 0x0000000000010000ULL -/* PCI abort condition */ -#define BRIDGE_ISR_PCI_ABORT 0x0000000000008000ULL -/* PCI bridge detected parity error */ -#define BRIDGE_ISR_PCI_PARITY 0x0000000000004000ULL -/* PCI address or command parity error */ -#define BRIDGE_ISR_PCI_SERR 0x0000000000002000ULL -/* PCI device parity error */ -#define BRIDGE_ISR_PCI_PERR 0x0000000000001000ULL -/* PCI device selection timeout */ -#define BRIDGE_ISR_PCI_MASTER_TMO 0x0000000000000800ULL -/* PCI retry count exceeded */ -#define BRIDGE_ISR_PCI_RETRY_CNT 0x0000000000000400ULL -/* PCI to xtalk read request timeout */ -#define BRIDGE_ISR_XREAD_REQ_TMO 0x0000000000000200ULL -/* GIO non-contiguous byte enable in xtalk packet - bridge only */ -#define BRIDGE_ISR_GIO_BENABLE_ERR 0x0000000000000100ULL -#define BRIDGE_ISR_HWINTR_MASK 0x00000000000000ffULL - -#define BRIDGE_ISR_ERRMASK 0x00000000fffffe00ULL -#define PIC_ISR_ERRMASK 0x00003fff7ffffe00ULL - -/* - * BRIDGE_ICR bits, for Bridge and XBridge chips only (error interrupts - * being cleared in groups) - */ - -#define BRIDGE_ICR_MULTIPLE 0x00000040 -#define BRIDGE_ICR_CRP 0x00000020 -#define BRIDGE_ICR_RESP_BUF 0x00000010 -#define BRIDGE_ICR_REQ_DSP 0x00000008 -#define BRIDGE_ICR_LLP 0x00000004 -#define BRIDGE_ICR_SSRAM 0x00000002 -#define BRIDGE_ICR_PCI 0x00000001 -#define BRIDGE_ICR_ALL 0x0000007f - -/* - * PCI Resource Mapping control - * - * There are three ways to map a given device: - * - memory mapping in the long window, at BRIDGE_PCI_MEM_SPACE_BASE, - * shared by all devices. - * - I/O mapping in the long window, at BRIDGE_PCI_IO_SPACE_BASE, - * shared by all devices, but only on widget revision 4 or later. - * - programmable memory or I/O mapping at a selectable place in the - * short window, with an 1MB granularity. The size of this - * window is 2MB for the windows at 2MB and 4MB, and 1MB onwards. - * - * ARCBios will setup mappings in the short window for us, and - * the selected address will match BAR0. - */ - -#define BRIDGE_DEVICE(d) (0x00000200 + 8 * (d)) -/* flags applying to the device itself */ -/* enable write gathering through ATE */ -#define BRIDGE_DEVICE_WGATHER_PMU 0x01000000 -/* enable write gathering through the direct window */ -#define BRIDGE_DEVICE_WGATHER_DIR 0x00800000 -/* byteswap DMA done through ATE */ -#define BRIDGE_DEVICE_SWAP_PMU 0x00100000 -/* byteswap DMA done through the direct window */ -#define BRIDGE_DEVICE_SWAP_DIR 0x00080000 -/* flags applying to the mapping in this devio register */ -#define BRIDGE_DEVICE_PREFETCH 0x00040000 -#define BRIDGE_DEVICE_PRECISE 0x00020000 -#define BRIDGE_DEVICE_COHERENT 0x00010000 -#define BRIDGE_DEVICE_BARRIER 0x00008000 -/* byteswap PIO */ -#define BRIDGE_DEVICE_SWAP 0x00002000 -/* set if memory space, clear if I/O space */ -#define BRIDGE_DEVICE_IO_MEM 0x00001000 -#define BRIDGE_DEVICE_BASE_MASK 0x00000fff -#define BRIDGE_DEVICE_BASE_SHIFT 20 - -#define BRIDGE_DEVIO_BASE 0x00200000 -#define BRIDGE_DEVIO_LARGE 0x00200000 -#define BRIDGE_DEVIO_SHORT 0x00100000 - -#define BRIDGE_DEVIO_OFFS(d) \ - (BRIDGE_DEVIO_BASE + \ - BRIDGE_DEVIO_LARGE * ((d) < 2 ? (d) : 2) + \ - BRIDGE_DEVIO_SHORT * ((d) < 2 ? 0 : (d) - 2)) -#define BRIDGE_DEVIO_SIZE(d) \ - ((d) < 2 ? BRIDGE_DEVIO_LARGE : BRIDGE_DEVIO_SHORT) -#define PIC_DEVIO_OFFS(bus,d) \ - (BRIDGE_DEVIO_OFFS(d) + ((bus) != 0 ? BRIDGE_BUS_OFFSET : 0)) - - -#define BRIDGE_DEVICE_WBFLUSH(d) (0x00000240 + 8 * (d)) - -/* - * Read Response Buffer configuration registers - * - * There are 16 RRB, which are shared among the PCI devices. - * The following registers provide four bits per RRB, describing - * their RRB assignment. - * - * Since these four bits only assign two bits to map to a PCI slot, - * the low-order bit is implied by the RRB register: one controls the - * even-numbered PCI slots, while the other controls the odd-numbered - * PCI slots. - */ - -#define BRIDGE_RRB_EVEN 0x00000280 -#define BRIDGE_RRB_ODD 0x00000288 - -#define RRB_VALID 0x8 -#define RRB_VCHAN 0x4 -#define RRB_DEVICE_MASK 0x3 -#define RRB_SHIFT 4 - -/* - * Address Translation Entries - */ - -#define BRIDGE_INTERNAL_ATE 128 -#define XBRIDGE_INTERNAL_ATE 1024 - -#define BRIDGE_ATE_SSHIFT 12 /* 4KB */ -#define BRIDGE_ATE_LSHIFT 14 /* 16KB */ -#define BRIDGE_ATE_SSIZE (1ULL << BRIDGE_ATE_SSHIFT) -#define BRIDGE_ATE_LSIZE (1ULL << BRIDGE_ATE_LSHIFT) -#define BRIDGE_ATE_SMASK (BRIDGE_ATE_SSIZE - 1) -#define BRIDGE_ATE_LMASK (BRIDGE_ATE_LSIZE - 1) - -#define BRIDGE_ATE(a) (0x00010000 + (a) * 8) - -#define ATE_NV 0x0000000000000000ULL -#define ATE_V 0x0000000000000001ULL -#define ATE_COH 0x0000000000000002ULL -#define ATE_PRECISE 0x0000000000000004ULL -#define ATE_PREFETCH 0x0000000000000008ULL -#define ATE_BARRIER 0x0000000000000010ULL -#define ATE_BSWAP 0x0000000000000020ULL /* XB */ -#define ATE_WIDGET_MASK 0x0000000000000f00ULL -#define ATE_WIDGET_SHIFT 8 -#define ATE_ADDRESS_MASK 0x0000fffffffff000ULL -#define ATE_RMF_MASK 0x00ff000000000000ULL /* BR */ - -/* - * PIC Write Request memory - */ - -#define PIC_WR_REQ_LOWER(a) (0x00018000 + (a) * 8) -#define PIC_WR_REQ_UPPER(a) (0x00018800 + (a) * 8) -#define PIC_WR_REQ_PARITY(a) (0x00019000 + (a) * 8) - -#define PIC_WR_REQ_ENTRIES 0x100 - -/* - * Configuration space - * - * Access to the first bus is done in the first area, sorted by - * device number and function number. - * Access to other buses is done in the second area, after programming - * BRIDGE_PCI_CFG to the appropriate bus and slot number. - */ - -#define BRIDGE_PCI_CFG_SPACE 0x00020000 -#define BRIDGE_PCI_CFG1_SPACE 0x00028000 - -/* - * DMA addresses - * The Bridge can do DMA either through a direct 2GB window, or through - * a 1GB translated window, using its ATE memory. - */ - -#define BRIDGE_DMA_TRANSLATED_BASE 0x40000000ULL -#define XBRIDGE_DMA_TRANSLATED_SWAP 0x20000000ULL -#define ATE_ADDRESS(a,s) \ - (BRIDGE_DMA_TRANSLATED_BASE + ((a) << (s))) -#define ATE_INDEX(a,s) \ - (((a) - BRIDGE_DMA_TRANSLATED_BASE) >> (s)) - -#define BRIDGE_DMA_DIRECT_BASE 0x80000000ULL -#define BRIDGE_DMA_DIRECT_LENGTH 0x80000000ULL diff --git a/sys/arch/sgi/xbow/xheart.c b/sys/arch/sgi/xbow/xheart.c deleted file mode 100644 index be5a244a5ae..00000000000 --- a/sys/arch/sgi/xbow/xheart.c +++ /dev/null @@ -1,487 +0,0 @@ -/* $OpenBSD: xheart.c,v 1.33 2020/07/06 13:33:08 pirofti Exp $ */ - -/* - * Copyright (c) 2008 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * IP30 Heart Widget - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/device.h> -#include <sys/evcount.h> -#include <sys/malloc.h> -#include <sys/timetc.h> -#include <sys/atomic.h> - -#include <machine/autoconf.h> -#include <machine/cpu.h> -#include <mips64/mips_cpu.h> -#include <machine/intr.h> - -#include <sgi/xbow/xbow.h> -#include <sgi/xbow/xbowdevs.h> -#include <sgi/xbow/xheartreg.h> - -#include <dev/onewire/onewirereg.h> -#include <dev/onewire/onewirevar.h> - -struct xheart_softc { - struct device sc_dev; - struct onewire_bus sc_bus; -}; - -int xheart_match(struct device *, void *, void *); -void xheart_attach(struct device *, struct device *, void *); - -const struct cfattach xheart_ca = { - sizeof(struct xheart_softc), xheart_match, xheart_attach, -}; - -struct cfdriver xheart_cd = { - NULL, "xheart", DV_DULL, -}; - -int xheart_ow_reset(void *); -int xheart_ow_read_bit(struct xheart_softc *); -int xheart_ow_send_bit(void *, int); -int xheart_ow_read_byte(void *); -int xheart_ow_triplet(void *, int); -int xheart_ow_pulse(struct xheart_softc *, int, int); - -int xheart_intr_register(int, int, int *); -int xheart_intr_establish(int (*)(void *), void *, int, int, const char *, - struct intrhand *); -void xheart_intr_disestablish(int); -void xheart_intr_clear(int); -void xheart_intr_set(int); -uint32_t xheart_intr_handler(uint32_t, struct trapframe *); -void xheart_intr_makemasks(void); -void xheart_setintrmask(int); -void xheart_splx(int); - -u_int xheart_get_timecount(struct timecounter *); - -struct timecounter xheart_timecounter = { - .tc_get_timecount = xheart_get_timecount, - .tc_poll_pps = NULL, - .tc_counter_mask = 0xffffffff, /* truncate 52-bit counter to 32-bit */ - .tc_frequency = 12500000, - .tc_name = "heart", - .tc_quality = 100, - .tc_priv = NULL, - .tc_user = 0, -}; - -extern uint32_t ip30_lights_frob(uint32_t, struct trapframe *); - -/* - * HEART interrupt handling declarations: 64 sources; 5 levels. - */ - -struct intrhand *xheart_intrhand[HEART_NINTS]; - -#ifdef notyet -#define INTPRI_HEART_4 (INTPRI_CLOCK + 1) -#define INTPRI_HEART_3 (INTPRI_HEART_4 + 1) -#define INTPRI_HEART_2 (INTPRI_HEART_3 + 1) -#define INTPRI_HEART_1 (INTPRI_HEART_2 + 1) -#define INTPRI_HEART_0 (INTPRI_HEART_1 + 1) -#else -#define INTPRI_HEART_2 (INTPRI_IPI) -#define INTPRI_HEART_0 (INTPRI_CLOCK + 1) -#endif -#define INTPRI_HEART_LEDS (INTPRI_HEART_0 + 1) - -uint64_t xheart_intem[MAXCPUS]; -uint64_t xheart_imask[MAXCPUS][NIPLS]; - -int -xheart_match(struct device *parent, void *match, void *aux) -{ - struct xbow_attach_args *xaa = aux; - - if (xaa->xaa_vendor == XBOW_VENDOR_SGI4 && - xaa->xaa_product == XBOW_PRODUCT_SGI4_HEART) - return 1; - - return 0; -} - -void -xheart_attach(struct device *parent, struct device *self, void *aux) -{ - struct xbow_attach_args *xaa = aux; - struct xheart_softc *sc = (void *)self; - struct onewirebus_attach_args oba; - paddr_t heart; - - printf(" revision %d\n", xaa->xaa_revision); - - sc->sc_bus.bus_cookie = sc; - sc->sc_bus.bus_reset = xheart_ow_reset; - sc->sc_bus.bus_bit = xheart_ow_send_bit; - sc->sc_bus.bus_read_byte = xheart_ow_read_byte; - sc->sc_bus.bus_write_byte = NULL; /* use default routine */ - sc->sc_bus.bus_read_block = NULL; /* use default routine */ - sc->sc_bus.bus_write_block = NULL; /* use default routine */ - sc->sc_bus.bus_triplet = xheart_ow_triplet; - sc->sc_bus.bus_matchrom = NULL; /* use default routine */ - sc->sc_bus.bus_search = NULL; /* use default routine */ - - oba.oba_bus = &sc->sc_bus; - oba.oba_flags = ONEWIRE_SCAN_NOW | ONEWIRE_NO_PERIODIC_SCAN; - config_found(self, &oba, onewirebus_print); - - xbow_intr_address = 0x80; - xbow_intr_widget_intr_register = xheart_intr_register; - xbow_intr_widget_intr_establish = xheart_intr_establish; - xbow_intr_widget_intr_disestablish = xheart_intr_disestablish; - xbow_intr_widget_intr_clear = xheart_intr_clear; - xbow_intr_widget_intr_set = xheart_intr_set; - - /* - * Acknowledge and disable all interrupts. - */ - heart = PHYS_TO_XKPHYS(HEART_PIU_BASE, CCA_NC); - *(volatile uint64_t*)(heart + HEART_ISR_CLR) = 0xffffffffffffffffUL; - *(volatile uint64_t*)(heart + HEART_IMR(0)) = 0UL; - *(volatile uint64_t*)(heart + HEART_IMR(1)) = 0UL; - *(volatile uint64_t*)(heart + HEART_IMR(2)) = 0UL; - *(volatile uint64_t*)(heart + HEART_IMR(3)) = 0UL; - -#ifdef notyet - set_intr(INTPRI_HEART_4, CR_INT_4, xheart_intr_handler); - set_intr(INTPRI_HEART_3, CR_INT_3, xheart_intr_handler); -#endif - set_intr(INTPRI_HEART_2, CR_INT_2, xheart_intr_handler); -#ifdef notyet - set_intr(INTPRI_HEART_1, CR_INT_1, xheart_intr_handler); -#endif - set_intr(INTPRI_HEART_0, CR_INT_0, xheart_intr_handler); - - set_intr(INTPRI_HEART_LEDS, CR_INT_5, ip30_lights_frob); - - register_splx_handler(xheart_splx); - - tc_init(&xheart_timecounter); -} - -/* - * Number-In-a-Can (1-Wire) interface - */ - -int -xheart_ow_reset(void *v) -{ - struct xheart_softc *sc = v; - return xheart_ow_pulse(sc, 500, 65); -} - -int -xheart_ow_read_bit(struct xheart_softc *sc) -{ - return xheart_ow_pulse(sc, 6, 13); -} - -int -xheart_ow_send_bit(void *v, int bit) -{ - struct xheart_softc *sc = v; - int rc; - - if (bit != 0) - rc = xheart_ow_pulse(sc, 6, 110); - else - rc = xheart_ow_pulse(sc, 80, 30); - return rc; -} - -int -xheart_ow_read_byte(void *v) -{ - struct xheart_softc *sc = v; - unsigned int byte = 0; - int i; - - for (i = 0; i < 8; i++) - byte |= xheart_ow_read_bit(sc) << i; - - return byte; -} - -int -xheart_ow_triplet(void *v, int dir) -{ - struct xheart_softc *sc = v; - int rc; - - rc = xheart_ow_read_bit(sc); - rc <<= 1; - rc |= xheart_ow_read_bit(sc); - - switch (rc) { - case 0x0: - xheart_ow_send_bit(v, dir); - break; - case 0x1: - xheart_ow_send_bit(v, 0); - break; - default: - xheart_ow_send_bit(v, 1); - break; - } - - return (rc); -} - -int -xheart_ow_pulse(struct xheart_softc *sc, int pulse, int data) -{ - uint64_t mcr_value; - paddr_t heart; - - heart = PHYS_TO_XKPHYS(HEART_PIU_BASE + HEART_MICROLAN, CCA_NC); - mcr_value = (pulse << 10) | (data << 2); - *(volatile uint64_t *)heart = mcr_value; - do { - mcr_value = *(volatile uint64_t *)heart; - } while ((mcr_value & 0x00000002) == 0); - - delay(500); - - return (mcr_value & 1); -} - -/* - * HEART interrupt handling routines - */ - -/* - * Find a suitable interrupt bit for the given interrupt. - */ -int -xheart_intr_register(int widget, int level, int *intrbit) -{ - int bit; - u_long cpuid = cpu_number(); - - /* - * All interrupts will be serviced at hardware level 0, - * so the `level' argument can be ignored. - */ - for (bit = HEART_INTR_WIDGET_MAX; bit >= HEART_INTR_WIDGET_MIN; bit--) - if ((xheart_intem[cpuid] & (1UL << bit)) == 0) - goto found; - - return EINVAL; - -found: - *intrbit = bit; - return 0; -} - -/* - * Register an interrupt handler for a given source, and enable it. - */ -int -xheart_intr_establish(int (*func)(void *), void *arg, int intrbit, - int level, const char *name, struct intrhand *ihstore) -{ - struct intrhand *ih; - int flags; - int s; - u_long cpuid = cpu_number(); - -#ifdef DIAGNOSTIC - if (intrbit < 0 || intrbit >= HEART_NINTS) - return EINVAL; -#endif - - flags = (level & IPL_MPSAFE) ? IH_MPSAFE : 0; - level &= ~IPL_MPSAFE; - - /* - * HEART interrupts are not supposed to be shared - the interrupt - * mask is large enough for all widgets. - */ - if (xheart_intrhand[intrbit] != NULL) - return EEXIST; - - if (ihstore == NULL) { - ih = malloc(sizeof(*ih), M_DEVBUF, M_NOWAIT); - if (ih == NULL) - return ENOMEM; - flags |= IH_ALLOCATED; - } else - ih = ihstore; - - ih->ih_next = NULL; - ih->ih_fun = func; - ih->ih_arg = arg; - ih->ih_level = level; - ih->ih_irq = intrbit; - ih->ih_flags = flags; - if (name != NULL) - evcount_attach(&ih->ih_count, name, &ih->ih_level); - - s = splhigh(); - - xheart_intrhand[intrbit] = ih; - - xheart_intem[cpuid] |= 1UL << intrbit; - xheart_intr_makemasks(); - - splx(s); /* causes hw mask update */ - - return 0; -} - -void -xheart_intr_disestablish(int intrbit) -{ - struct intrhand *ih; - int s; - u_long cpuid = cpu_number(); - -#ifdef DIAGNOSTIC - if (intrbit < 0 || intrbit >= HEART_NINTS) - return; -#endif - - s = splhigh(); - - if ((ih = xheart_intrhand[intrbit]) == NULL) { - splx(s); - return; - } - - xheart_intrhand[intrbit] = NULL; - - xheart_intem[cpuid] &= ~(1UL << intrbit); - xheart_intr_makemasks(); - - splx(s); - - if (ISSET(ih->ih_flags, IH_ALLOCATED)) - free(ih, M_DEVBUF, sizeof *ih); -} - -void -xheart_intr_clear(int intrbit) -{ - *(volatile uint64_t *)PHYS_TO_XKPHYS(HEART_PIU_BASE + HEART_ISR_CLR, - CCA_NC) = 1UL << intrbit; -} - -void -xheart_intr_set(int intrbit) -{ - *(volatile uint64_t *)PHYS_TO_XKPHYS(HEART_PIU_BASE + HEART_ISR_SET, - CCA_NC) = 1UL << intrbit; -} - -void -xheart_splx(int newipl) -{ - struct cpu_info *ci = curcpu(); - - /* Update masks to new ipl. Order highly important! */ - ci->ci_ipl = newipl; - xheart_setintrmask(newipl); - - /* If we still have softints pending trigger processing. */ - if (ci->ci_softpending != 0 && newipl < IPL_SOFTINT) - setsoftintr0(); -} - -/* - * Heart interrupt handler. Can be registered at any hardware interrupt level. - */ - -#define INTR_FUNCTIONNAME xheart_intr_handler -#define MASK_FUNCTIONNAME xheart_intr_makemasks -#define INTR_LOCAL_DECLS \ - paddr_t heart = PHYS_TO_XKPHYS(HEART_PIU_BASE, CCA_NC); \ - u_long cpuid = cpu_number(); -#define MASK_LOCAL_DECLS \ - u_long cpuid = cpu_number(); -#define INTR_GETMASKS \ -do { \ - isr = *(volatile uint64_t *)(heart + HEART_ISR); \ - imr = *(volatile uint64_t *)(heart + HEART_IMR(cpuid)); \ - switch (hwpend) { \ - case CR_INT_0: \ - isr &= HEART_ISR_LVL0_MASK; \ - bit = HEART_ISR_LVL0_MAX; \ - break; \ - case CR_INT_1: \ - isr &= HEART_ISR_LVL1_MASK; \ - bit = HEART_ISR_LVL1_MAX; \ - break; \ - case CR_INT_2: \ - isr &= HEART_ISR_LVL2_MASK; \ - bit = HEART_ISR_LVL2_MAX; \ - break; \ - case CR_INT_3: \ - isr &= HEART_ISR_LVL3_MASK; \ - bit = HEART_ISR_LVL3_MAX; \ - break; \ - case CR_INT_4: \ - isr &= HEART_ISR_LVL4_MASK; \ - bit = HEART_ISR_LVL4_MAX; \ - break; \ - default: \ - return 0; /* can't happen */ \ - } \ -} while (0) -#define INTR_MASKPENDING \ - *(volatile uint64_t *)(heart + HEART_IMR(cpuid)) &= ~isr -#define INTR_IMASK(ipl) xheart_imask[cpuid][ipl] -#define INTR_HANDLER(bit) xheart_intrhand[bit] -#define INTR_SPURIOUS(bit) \ -do { \ - printf("spurious xheart interrupt %d\n", bit); \ -} while (0) -#define INTR_MASKRESTORE \ - *(volatile uint64_t *)(heart + HEART_IMR(cpuid)) = imr -#define INTR_MASKSIZE HEART_NINTS - -#include <sgi/sgi/intr_template.c> - -void -xheart_setintrmask(int level) -{ - paddr_t heart = PHYS_TO_XKPHYS(HEART_PIU_BASE, CCA_NC); - u_long cpuid = cpu_number(); - - *(volatile uint64_t *)(heart + HEART_IMR(cpuid)) = - xheart_intem[cpuid] & ~xheart_imask[cpuid][level]; -} - -/* - * Timecounter interface. - */ - -uint -xheart_get_timecount(struct timecounter *tc) -{ - paddr_t heart = PHYS_TO_XKPHYS(HEART_PIU_BASE, CCA_NC); - - return (u_int)*(volatile uint64_t *)(heart + HEART_CTR_VALUE); -} diff --git a/sys/arch/sgi/xbow/xheartreg.h b/sys/arch/sgi/xbow/xheartreg.h deleted file mode 100644 index 6d498465dbf..00000000000 --- a/sys/arch/sgi/xbow/xheartreg.h +++ /dev/null @@ -1,120 +0,0 @@ -/* $OpenBSD: xheartreg.h,v 1.5 2012/06/17 12:34:19 miod Exp $ */ - -/* - * Copyright (c) 2008, 2011 Miodrag Vallat. - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* - * IP30 HEART registers - */ - -/* physical address in PIU mode */ -#define HEART_PIU_BASE 0x000000000ff00000 - -#define HEART_MODE 0x0000 -#define HEART_MEMORY_STATUS 0x0020 /* 8 32 bit registers */ -#define HEART_MEMORY_VALID 0x80000000 -#define HEART_MEMORY_SIZE_MASK 0x003f0000 -#define HEART_MEMORY_SIZE_SHIFT 16 -#define HEART_MEMORY_ADDR_MASK 0x000001ff -#define HEART_MEMORY_ADDR_SHIFT 0 -#define HEART_MEMORY_UNIT_SHIFT 25 /* 32MB */ - -#define HEART_MICROLAN 0x00b8 - -/* - * Interrupt handling registers. - * The Heart supports four different interrupt targets, although only - * the two cpus are used in practice. - */ - -#define HEART_IMR(s) (0x00010000 + (s) * 8) -#define HEART_ISR_SET 0x00010020 -#define HEART_ISR_CLR 0x00010028 -#define HEART_ISR 0x00010030 - -/* - * ISR bit assignments. - */ - -/** Level 4 interrupt: hardware error */ -#define HEART_ISR_LVL4_MASK 0xfff8000000000000UL -#define HEART_ISR_LVL4_MAX 63 -/* Heart (widget 8) error */ -#define HEART_ISR_WID08_ERROR 63 -/* CPU bus error */ -#define HEART_ISR_CPU_BUSERR(c) (59 + (c)) -/* Crossbow (widget 0) error */ -#define HEART_ISR_WID00_ERROR 58 -/* Widget error */ -#define HEART_ISR_WID0F_ERROR 57 -#define HEART_ISR_WID0E_ERROR 56 -#define HEART_ISR_WID0D_ERROR 55 -#define HEART_ISR_WID0C_ERROR 54 -#define HEART_ISR_WID0B_ERROR 53 -#define HEART_ISR_WID0A_ERROR 52 -#define HEART_ISR_WID09_ERROR 51 - -#define HEART_ISR_WID_ERROR(w) \ - ((w) == 0 ? HEART_ISR_WID00_ERROR : \ - (w) == 8 ? HEART_ISR_WID08_ERROR : HEART_ISR_WID09_ERROR + (w) - 9) - -/** Level 3 interrupt: heart counter/timer */ -#define HEART_ISR_LVL3_MASK 0x0004000000000000UL -#define HEART_ISR_LVL3_MAX 50 -/* Crossbow clock */ -#define HEART_ISR_HEARTCLOCK 50 - -/** Level 2 interrupt */ -#define HEART_ISR_LVL2_MASK 0x0003ffff00000000UL -#define HEART_ISR_LVL2_MAX 49 -/* IPI */ -#define HEART_ISR_IPI(c) (46 + (c)) -/* Debugger interrupts */ -#define HEART_ISR_DBG(c) (42 + (c)) -/* Power switch */ -#define HEART_ISR_POWER 41 -/* 40-32 freely available */ - -/** Level 1 interrupt */ -#define HEART_ISR_LVL1_MASK 0x00000000ffff0000UL -#define HEART_ISR_LVL1_MAX 31 -/* 31-16 freely available */ - -/** Level 0 interrupt */ -#define HEART_ISR_LVL0_MASK 0x000000000000ffffUL -#define HEART_ISR_LVL0_MAX 15 -/* 15-3 freely available */ - -#define HEART_INTR_WIDGET_MAX 15 -#define HEART_INTR_WIDGET_MIN 3 - -#define HEART_NINTS 64 - -/* - * Crossbow clock, as a free-running counter. - * The clock rate is 400 MHz, with the counter running at 1/32 of the clock, - * i.e. 12.5 MHz (80 nS period) - */ - -#define HEART_CTR_VALUE 0x00020000 /* 52-bit counter value, r/o */ -#define HEART_CTR_LIMIT 0x00030000 /* 24-bit limit value */ -#define HEART_CTR_TRIGGER 0x00040000 - -/* - * Per-processor ID register. - */ - -#define HEART_PRID 0x00050000 |