⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ocelot_c.h

📁 MIPS处理器的bootloader,龙芯就是用的修改过的PMON2
💻 H
字号:
/*	$OpenBSD$ *//* * 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 by Opsycon 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. * */#ifndef _OCELOT_C_H_#define _OCELOT_C_H_#include <machine/endian.h>/* *  Mapping */#define	IO_OFFSET		0x40000000#define	PHYS_TO_IOSPACE(x)	(PHYS_TO_UNCACHED(x) + IO_OFFSET)/* *  Define top of PMON-land. PMON will not use memory above this *  address but leave it alone for applications. *///#define	PMON_TOP		0x00200000	/* 2MB *//* *  CS space mapping. */#define	FPGA_BASE		PHYS_TO_IOSPACE(0x1c000000)#define	FPGA_SIZE		0x00800000#define	RTC_BASE		PHYS_TO_IOSPACE(0x1c800000)#define	RTC_SIZE		0x00800000#define	UART_BASE		PHYS_TO_IOSPACE(0x1d000000)#define	UART_SIZE		0x01000000#define	FLASH_BASE		PHYS_TO_IOSPACE(0x1f000000)#define	FLASH_SIZE		0x00c00000#define	BOOT_BASE		PHYS_TO_IOSPACE(0x1fc00000)#define	BOOT_SIZE		0x00400000/* * Internal SRAM mapping */#define OC_SRAM_BASE		PHYS_TO_IOSPACE(0x1e000000)#define OC_SRAM_SIZE		0x00040000/* *  PCI Bus allocation */#define PCI0_MEM_SPACE_BASE     0xc0000000#define PCI0_MEM_SPACE_SIZE     0x10000000#define PCI0_IO_SPACE_BASE      0xe0000000#define PCI0_IO_SPACE_SIZE      0x08000000#define PCI1_MEM_SPACE_BASE     0xd0000000#define PCI1_MEM_SPACE_SIZE     0x10000000#define PCI1_IO_SPACE_BASE      0xe8000000#define PCI1_IO_SPACE_SIZE      0x08000000#define	ISA_IO_BASE		PCI_IO_BASE/* *  Timekeeper/NVRAM (M48T37) */#define NVRAM_BASE_ADDR         PHYS_TO_IOSPACE(0x1c800000)#define NVRAM_SIZE              (0x7ff0)#define NVRAM_BASE              NVRAM_BASE_ADDR#define NVRAM_FIRST_ENV         (NVRAM_BASE + 0x0000)#define NVRAM_LAST_ENV          (NVRAM_BASE + 0x77ff)#define NVRAM_SIZE_ENV          (NVRAM_LAST_ENV - NVRAM_FIRST_ENV + 1)#define NVRAM_VXWORKS           (NVRAM_BASE + NVRAM_SIZE - 512)#define NVRAM_VXWORKS_DEFAULT \"dc(0,0)host:/usr/vw/config/ev64340/vxWorks h=90.0.0.3 e=90.0.0.50 u=target"#define NVRAM_ENETADDR          (NVRAM_BASE + 0x7cf2)#define M48T37_BASE             (NVRAM_BASE_ADDR + NVRAM_SIZE)/* *  Device module flash memory. */#define	GT_DM_FLASH	0x1a000000/* *  Device module duart I/O ports. */#define COM1_BASE_ADDR	PHYS_TO_IOSPACE(0x1d000000 + 0x20)	/* Com 1 */#define COM2_BASE_ADDR	PHYS_TO_IOSPACE(0x1d000000 + 0x00)	/* Com 2 */#define GT_COM1   	1 #define GT_COM2   	2 #define	NS16550HZ	20000000#if BYTE_ORDER == LITTLE_ENDIAN#define nsreg(x)	unsigned char CAT(pad_,x)[3]; unsigned char x;#define NSREG(x)	((x) * 4 + 3)#elif BYTE_ORDER == BIG_ENDIAN#define nsreg(x)	unsigned char x; unsigned char CAT(pad_,x)[3];#define NSREG(x)	((x) * 4)#else#error BYTE_ORDER is neither BIG_ENDIAN or LITTLE_ENDIAN#endif#endif /* _OCELOT_C_H_ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -