ts1000.s

来自「eCos操作系统源码」· S 代码 · 共 610 行 · 第 1/2 页

S
610
字号
##=============================================================================####      ts1000.S####      TS1000 board hardware setup####=============================================================================#####ECOSGPLCOPYRIGHTBEGIN###### -------------------------------------------## This file is part of eCos, the Embedded Configurable Operating System.## Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.## Copyright (C) 2002 Gary Thomas#### eCos is free software; you can redistribute it and/or modify it under## the terms of the GNU General Public License as published by the Free## Software Foundation; either version 2 or (at your option) any later version.#### eCos is distributed in the hope that it will be useful, but WITHOUT ANY## WARRANTY; without even the implied warranty of MERCHANTABILITY or## FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License## for more details.#### You should have received a copy of the GNU General Public License along## with eCos; if not, write to the Free Software Foundation, Inc.,## 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.#### As a special exception, if other files instantiate templates or use macros## or inline functions from this file, or you compile this file and link it## with other works to produce a work based on this file, this file does not## by itself cause the resulting work to be covered by the GNU General Public## License. However the source code for this file must still be made available## in accordance with section (3) of the GNU General Public License.#### This exception does not invalidate any other reasons why a work based on## this file might be covered by the GNU General Public License.#### Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.## at http://sources.redhat.com/ecos/ecos-license/## -------------------------------------------#####ECOSGPLCOPYRIGHTEND######=============================================================================#######DESCRIPTIONBEGIN######## Author(s):   hmt## Contributors:hmt, gthomas## Date:        1999-06-08## Purpose:     TS1000 board hardware setup## Description: This file contains any code needed to initialize the##              hardware on an Allied Telesyn TS1000 (PPC855T) board.########DESCRIPTIONEND########=============================================================================#include <pkgconf/hal.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 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(CYG_HAL_STARTUP_ROMRAM) \ || defined(CYGPRI_RAM_START_PROGRAMS_UPMS)# define CYGPRI_DO_PROGRAM_UPMS#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. */	#------------------------------------------------------------------------------//// Macros to build BR/OR registers//#define _BR(_reg,_BA,_PS,_MS,_V) \        .long   CYGARC_REG_IMM_BASE+_reg, ((_BA&0xFFFF8000)|(_PS<<10)|(_MS<<6)|_V)// Port size#define _PS_32 0x00  // 32 bits#define _PS_8  0x01  // 8 bits#define _PS_16 0x02  // 16 bits// Machine select#define _MS_GPCM 0x00#define _MS_UPMA 0x02#define _MS_UPMB 0x03                                #define _OR_GPCM(_reg,_AM,_CSNT,_ACS,_BIH,_SCY,_SETA,_TRLX,_EHTR) \        .long   CYGARC_REG_IMM_BASE+_reg, ((_AM&0xFFFF8000)|(_CSNT<<11)|(_ACS<<9)|(_BIH<<8)|(_SCY<<4)|(_SETA<<3)|(_TRLX<<2)|(_EHTR<<1))// GPCM - Chip select negation time#define _CSNT_0 0#define _CSNT_1 1                                // GPCM - Address setup time#define _ACS_0  0x00  // !CS asserted with address lines#define _ACS_4  0x02  // !CS asserted 1/4 clock after address lines#define _ACS_2  0x03  // !CS asserted 1/2 clock after address lines// Burst Inhibit#define _BIH_0 0 // Bursting supported#define _BIH_1 1 // Bursting disabled        // GPCM - Address setup times#define _SCY_0  0x0 // No additional wait states#define _SCY_1  0x1 // 1 additional wait states#define _SCY_2  0x2 // 2 additional wait states#define _SCY_3  0x3 // 3 additional wait states#define _SCY_4  0x4 // 4 additional wait states#define _SCY_5  0x5 // 5 additional wait states#define _SCY_6  0x6 // 6 additional wait states#define _SCY_7  0x7 // 7 additional wait states#define _SCY_8  0x8 // 8 additional wait states#define _SCY_9  0x9 // 9 additional wait states#define _SCY_10 0xA // 10 additional wait states#define _SCY_11 0xB // 11 additional wait states#define _SCY_12 0xC // 12 additional wait states#define _SCY_13 0xD // 13 additional wait states#define _SCY_14 0xE // 14 additional wait states#define _SCY_15 0xF // 15 additional wait states	// GPCM - external transfer acknowledge#define _SETA_0 0   // No external acknowledge#define _SETA_1 1   // External acknowledge// GPCM - relaxed timing#define _TRLX_0 0   // Strict timing#define _TRLX_1 1   // Relaxed timing (wait states doubled)        // GPCM - external hold time#define _EHTR_0 0   // Strict timing#define _EHTR_1 1   // One wait state needed when switching banks                #define _OR_UPM(_reg,_AM,_SAM,_G5LA,_G5LS,_BIH)\        .long   CYGARC_REG_IMM_BASE+_reg,((_AM&0xFFFF8000)|(_SAM<<11)|(_G5LA<<10)|(_G5LS<<9)|(_BIH<<8))#define _SAM_0 0 // Address lines are not multiplexed#define _SAM_1 1 // Address lines are multiplexed by controller        #define _G5LA_0 0 // Use GPLB5 for GPL5#define _G5LA_1 1 // Use GPLA5 for GPL5        #define _G5LS_0 0 // !GPL5 asserted on low edge#define _G5LS_1 1 // !GPL5 asserted on high edge	#------------------------------------------------------------------------------//        // PTA field is (System Clock in MHz * Refresh rate in us) / Prescale// e.g.  ((14*3.6864)*62.5)/32 => 100.8 => 101        //// Since the processor is clocked using the EXTCLK signal, the PLL// should always run 1-1//        #define PLPRCR_PTX 0x000#define MAMR_PTA 98//// Special MPC8xx cache control//#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					#------------------------------------------------------------------------------// LED macro uses r23, r25: r4 assumed to point to IMMR#define LED( x )                            \        lhz     r25,PADAT(r4)           ;   \        andi.   r25,r25,(~0x3C&0xFFFF)  ;   \        ori     r25,r25,(x<<2)          ;   \        sth     r25,PADAT(r4)           ;   \	#------------------------------------------------------------------------------                FUNC_START( hal_hardware_init )        mflr    r30             // Save original return address        	# 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        //        // Set up GPIO port A - used to drive LEDs.        //        lhz     r3,PAODR(r4)    // paodr &= ~0x803C        andi.   r3,r3,(~0x803C&0xFFFF)        sth     r3,PAODR(r4)        lhz     r3,PADIR(r4)    // padir |= 0x803C -- all outputs        ori     r3,r3,0x803C        sth     r3,PADIR(r4)        lhz     r3,PAPAR(r4)    // papar &= ~0x803C        andi.   r3,r3,(~0x803C&0xFFFF)        sth     r3,PAPAR(r4)#ifdef CYG_HAL_STARTUP_RAM        lhz     r3,PADAT(r4)    // Turn off all LEDs, preserve PHY state        ori     r3,r3,0x003C#else        	lwi	r3,0x803C       // Turn off all LEDS, reset PHY#endif        	sth	r3,PADAT(r4)        		LED( 0 )			# turn all LEDs off	# 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 */	# 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		LED( 0x01 )	#ifdef CYG_HAL_STARTUP_ROMRAM// Need to set the PC into the FLASH (ROM) before the address map changes	lwi	r3,10f        lwi     r5,0xFE000000	or	r3,r3,r5	mtctr	r3	bctr10:	#endif			/*	 * SIU Initialization.	 */	lwi	r3,0x00610400        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,0x0000            // FIXME:   should this be 0x0000 or 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)

⌨️ 快捷键说明

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