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

📄 mbx.s

📁 eCos1.31版
💻 S
📖 第 1 页 / 共 2 页
字号:
##=============================================================================####      mbx.S####      MBX board hardware setup####=============================================================================#####COPYRIGHTBEGIN#####                                                                          # -------------------------------------------                              # The contents of this file are subject to the Red Hat eCos Public License # Version 1.1 (the "License"); you may not use this file except in         # compliance with the License.  You may obtain a copy of the License at    # http://www.redhat.com/                                                   #                                                                          # Software distributed under the License is distributed on an "AS IS"      # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied.  See the # License for the specific language governing rights and limitations under # the License.                                                             #                                                                          # The Original Code is eCos - Embedded Configurable Operating System,      # released September 30, 1998.                                             #                                                                          # The Initial Developer of the Original Code is Red Hat.                   # Portions created by Red Hat are                                          # Copyright (C) 1998, 1999, 2000 Red Hat, Inc.                             # All Rights Reserved.                                                     # -------------------------------------------                              #                                                                          #####COPYRIGHTEND######=============================================================================#######DESCRIPTIONBEGIN######## Author(s):   hmt## Contributors:hmt## Date:        1999-06-08## Purpose:     MBX board hardware setup## Description: This file contains any code needed to initialize the##              hardware on a MBX860 or 821 PowerPC board.########DESCRIPTIONEND########=============================================================================#include <pkgconf/system.h>#include <pkgconf/hal.h>#include <pkgconf/hal_powerpc.h>#include <pkgconf/hal_powerpc_mbx.h>        #include <cyg/hal/arch.inc>		/* register symbols et al */#include <cyg/hal/ppc_regs.h>		/* on-chip resource layout, special */					/* registers, IMM layout...         */#include <cyg/hal/quicc/ppc8xx.h>       /* more of the same */	#------------------------------------------------------------------------------# this is kept thus for commonality with CygMon code#if 40 == CYGHWR_HAL_POWERPC_BOARD_SPEED# define __40MHZ 1#elif 50 == CYGHWR_HAL_POWERPC_BOARD_SPEED# define __50MHZ 1#else# error Bad Board speed defined: see CYGBLD_HAL_PLATFORM_H#endif#------------------------------------------------------------------------------# this is controlled with one define for tidiness:# (and it is undefined by default)//#define CYGPRI_RAM_START_PROGRAMS_UPMS#if defined(CYG_HAL_STARTUP_ROM) || defined(CYGPRI_RAM_START_PROGRAMS_UPMS)# define CYGPRI_DO_PROGRAM_UPMS#endif#if defined(CYGPRI_RAM_START_PROGRAMS_UPMS) && defined(CYGSEM_HAL_ROM_MONITOR)/* use old tables in a StubROM build iff RAM start will reprogram them */# define CYGPRI_USE_OLD_UPM_TABLES#endif/* The intention is that we only set up the UPMs in ROM start, be it actual * ROM application start or Stub ROMs that we built from the same sources. *  * The alternative approach - in which we have reliability doubts - is to * program the UPMs with *old* timing data in StubROM start, then * *reprogram* them with *new* timing data in RAM start - and of course * program with *new* timing data in plain ROM application start. * (Re-programming from new to new timing data fails - hence the suspicion * of reprogramming _at_all_, hence this private configuration) *  * With CYGPRI_RAM_START_PROGRAMS_UPMS left undefined, the former behaviour * - programming the UPMs exactly once - is obtained.  Define it to get the * latter, untrusted behaviour. */	#------------------------------------------------------------------------------// LED macro uses r3, r5: r4 left alone#define LED( x ) \	lwi	r5,0xfa100001;         \	lwi	r3,((x) & 0xe);        \	stb	r3,0(r5)	#------------------------------------------------------------------------------                FUNC_START( hal_hardware_init )	# Throughout this routine, r4 is the base address of the control	# registers.  r3 and r5 are scratch in general.		lwi     r4,CYGARC_REG_IMM_BASE  # base address of control registers	mtspr	CYGARC_REG_IMMR,r4	LED( 0 )			# turn all LEDs on	#define CACHE_UNLOCKALL		0x0a00#define CACHE_DISABLE		0x0400#define CACHE_INVALIDATEALL	0x0c00#define CACHE_ENABLE		0x0200#define CACHE_ENABLEBIT		0x8000#define CACHE_FORCEWRITETHROUGH 0x0100#define CACHE_NOWRITETHROUGH    0x0300#define CACHE_CLEAR_LE_SWAP     0x0700	# DATA CACHE	mfspr	r3,CYGARC_REG_DC_CST		/* clear error bits */        lis     r3,CACHE_UNLOCKALL	sync        mtspr   CYGARC_REG_DC_CST,r3		/* unlock all lines */	        lis     r3,CACHE_INVALIDATEALL	sync        mtspr   CYGARC_REG_DC_CST,r3		/* invalidate all lines */	lis	r3,CACHE_DISABLE	sync	mtspr	CYGARC_REG_DC_CST,r3            /* disable */		lis	r3,CACHE_FORCEWRITETHROUGH	sync	mtspr	CYGARC_REG_DC_CST,r3            /* set force-writethrough mode */	lis	r3,CACHE_CLEAR_LE_SWAP	sync	mtspr	CYGARC_REG_DC_CST,r3            /* clear little-endian swap mode */	/* (dunno what this is, but it sounds like a bad thing) */		# INSTRUCTION CACHE (no writeback modes)	mfspr	r3,CYGARC_REG_IC_CST		/* clear error bits */        lis     r3,CACHE_UNLOCKALL        mtspr   CYGARC_REG_IC_CST,r3		/* unlock all lines */	isync        lis     r3,CACHE_INVALIDATEALL        mtspr   CYGARC_REG_IC_CST,r3		/* invalidate all lines */        isync	lis	r3,CACHE_DISABLE	mtspr	CYGARC_REG_IC_CST,r3            /* disable */	isync		sync		/*	 * SIU Initialization.	 *//*        lwi	r3,0x0062A900*//*        lwi	r3,0x006A2900*/	lwi	r3,0x00602400        stw	r3,SIUMCR(r4)	/*	 * Enable bus monitor. Disable Watchdog timer.	 */	lwi	r3,0xffffff88	stw	r3,SYPCR(r4)	/*	 * Clear REFA & REFB. Enable but freeze timebase.	 */	lwi	r3,0x00c2	sth	r3,TBSCR(r4)	/*	 * Unlock some RTC registers (see section 5.11.2)	 */	lwi	r3,0x55ccaa33	stw	r3,RTCSCK(r4)	stw	r3,RTCK(r4)	stw	r3,RTSECK(r4)	stw	r3,RTCALK(r4)	/*	 * Clear SERC & ALR. RTC runs on freeze. Enable RTC.	 */	li	r3,0x00c3	sth	r3,RTCSC(r4)	/*	 * Clear periodic timer interrupt status.	 * Enable periodic timer and stop it on freeze.	 */        li	r3,0x0083        sth	r3,PISCR(r4)#ifdef CYGPRI_DO_PROGRAM_UPMS	/*	 * Perform UPM programming by writing to its 64 RAM locations.	 * Note that UPM initialization must be done before the Bank Register	 * initialization. Otherwise, system may hang when writing to Bank	 * Registers in certain cases.	 */	lis	r5,__upmtbl_start@h	ori	r5,r5,__upmtbl_start@l	lis	r6,__upmtbl_end@h	ori	r6,r6,__upmtbl_end@l	sub	r7,r6,r5      /* size of table */ 	srawi	r7,r7,2       /* in words */                li	r6,0x0000     /* Command - OP=Write, UPMA, MAD=0 */    1:        lwz	r3,0(r5)      /* get data from table */        stw	r3,MDR(r4)    /* store the data to MD register */        stw	r6,MCR(r4)    /* issue command to MCR register */        addi	r5,r5,4       /* next entry in the table */        addi	r6,r6,1       /* next MAD address */        cmpw	r6,r7         /* done yet ? */        blt	1b#endif // CYGPRI_DO_PROGRAM_UPMS	/*	 * Set refresh timer prescaler to divide by 8.	 */        li	r3,PTP_DIV32        sth	r3,MPTPR(r4)        /*	 * See Table 15-16 MPC860 User's Manual.	 *	 * PTA = 0x13 (clock dependent)	 * PTAE = enabled	 * AMA = 0	 * DSA = 2 cycle disable	 * G0CLA = A12	 * GPL_A4DIS = 0	 * RLFA = 0	 * WLFA = 0	 * TLFA = 0	 */#ifdef __50MHZ	lwi	r3,0x18801000#else	lwi	r3,0x13801000#endif        stw	r3,MAMR(r4)	/*	 * Base Register initialization.	 */	/* BOOT ROM */        lwi	r3,0xfe000401	# 8-bit, GPCM#ifdef __50MHZ        lwi	r5,0xff800960 /* for 120nS devices, else 0xff800940 */#else        lwi	r5,0xff800930#endif#ifdef CYGHWR_HAL_POWERPC_MBX_BOOT_32BIT_FLASH	// Then the 32-bit FLASH device is on CS0, the "ROM" is on CS7        stw	r3,BR7(r4)        stw	r5,OR7(r4)#else	// Boot from 8-bit ROM - the default, on CS0        stw	r3,BR0(r4)        stw	r5,OR0(r4)#endif	/* ONBOARD DRAM */        lwi	r3,0x00000081	# 32-bit, UPMA        lwi	r5,0xffc00400        stw	r3,BR1(r4)        stw	r5,OR1(r4)	/* DRAM DIMM BANK0 */        lwi	r3,0x00000080	# 32-bit, UPMA, INVALID        lwi	r5,0x00000400        stw	r3,BR2(r4)        stw	r5,OR2(r4)	/* DRAM DIMM BANK1 */        lwi	r3,0x00000080	# 32-bit, UPMA, INVALID        lwi	r5,0x00000400        stw	r3,BR3(r4)        stw	r5,OR3(r4)	/* NVRAM */        lwi	r3,0xfa000401	# 8-bit, GPCM#ifdef __50MHZ        lwi	r5,0xffe00930#else        lwi	r5,0xffe00920#endif        stw	r3,BR4(r4)        stw	r5,OR4(r4)	/* PCI BRIDGE MEM/IO */        lwi	r3,0x80000001	# 32-bit, GPCM        lwi	r5,0xa0000108        stw	r3,BR5(r4)        stw	r5,OR5(r4)	/* PCI BRIDGE REGISTERS */        lwi	r3,0xfa210001	# 32-bit, GPCM        lwi	r5,0xffff0108        stw	r3,BR6(r4)        stw	r5,OR6(r4)	/* FLASH */        lwi	r3,0xfc000001	# 32-bit, GPCM#ifdef __50MHZ        lwi	r5,0xff800940#else        lwi	r5,0xff800930#endif#ifdef CYGHWR_HAL_POWERPC_MBX_BOOT_32BIT_FLASH	// Then the 32-bit FLASH device is on CS0, the "ROM" is on CS7        stw	r3,BR0(r4)        stw	r5,OR0(r4)#else	// Boot from 8-bit ROM - so the 32-bit FLASH is on CS7        stw	r3,BR7(r4)        stw	r5,OR7(r4)#endif	/*	 *  SYSTEM CLOCK CONTROL REGISTER	 *	 *  COM   (1:2)   = 0

⌨️ 快捷键说明

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