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

📄 hal_platform_setup.h

📁 eCos操作系统源码
💻 H
字号:
#ifndef CYGONCE_HAL_PLATFORM_SETUP_H#define CYGONCE_HAL_PLATFORM_SETUP_H/*=============================================================================////      hal_platform_setup.h////      Platform specific support for HAL (assembly code)////=============================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// 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):    gthomas// Contributors: gthomas, jlarmour// Date:         2000-03-10// Purpose:      NEC CEB/V850 platform specific support routines// Description: // Usage:       #include <cyg/hal/hal_platform_setup.h>////####DESCRIPTIONEND####////===========================================================================*/#include <pkgconf/system.h>           // System-wide configuration info#include <pkgconf/hal.h>              // Architecture independent configuration#include <cyg/hal/v850_common.h>        #include CYGBLD_HAL_PLATFORM_H        // Platform specific configuration        .macro  lea     addr,reg        movhi   hi(\addr),r0,\reg        movea   lo(\addr),\reg,\reg        .endm                .macro  PLATFORM_SETUP1#if defined(CYG_HAL_STARTUP_ROM) || defined(CYG_HAL_STARTUP_ROMRAM)        movhi   hi(V850_REGS),r0,r6               // set bus control signals        mov     0x01,r1                                st.b    r1,lo(V850_REG_SYC)[r6]        // Internal RAM, internal ROM and I/O - no wait states, regardless        // of the setting of DWC        // External RAM is 70ns, External ROM is 120ns. Therefore...#if CYGHWR_HAL_V85X_CPU_FREQ < 14285714        // External RAM      - 0 wait states        movea   0x3F00,r0,r1#elif CYGHWR_HAL_V85X_CPU_FREQ < 28571428        // External RAM      - 1 wait state        movea   0x7F00,r0,r1#elif CYGHWR_HAL_V85X_CPU_FREQ < 42857142        // External RAM      - 2 wait states        movea   0xBF00,r0,r1#else        // External RAM      - 3 wait states        movea   0xFF00,r0,r1#endif#if CYGHWR_HAL_V85X_CPU_FREQ < 8333333        // External ROM      - 0 wait states        ori     0x00FC,r1,r1#elif CYGHWR_HAL_V85X_CPU_FREQ < 16666667        // External ROM      - 1 wait states        ori     0x00FD,r1,r1#elif CYGHWR_HAL_V85X_CPU_FREQ < 25000000        // External ROM      - 2 wait states        ori     0x00FE,r1,r1#else        // External ROM      - 3 wait states        ori     0x00FF,r1,r1#endif        st.h    r1,lo(V850_REG_DWC)[r6]        // Internal RAM, ROM, I/O - always 0 idle regardless of the setting        // of BCC        // External RAM      - 0 idle        // External ROM      - 0 idle        movea   0x2AA8,r0,r1        st.h    r1,lo(V850_REG_BCC)[r6]        // No INTs on rising edge        mov     0x00,r1                                st.b    r1,lo(V850_REG_EGP0)[r6]        // enable INTP0 (serial) IRQ only, set for falling edge        mov     0x01,r1                                st.b    r1,lo(V850_REG_EGN0)[r6]        // Port 1 mode: set serial DSR, RXD and CTS as inputs, and others        // as outputs        movea   0x2C,r0,r1                                st.b    r1,lo(V850_REG_PM1)[r6]        // Port 3 mode: SW2 read port: set to all input        movea   0xFF,r0,r1                                st.b    r1,lo(V850_REG_PM3)[r6]        // Set serial port control inputs (DSR, RXD, CTS) to 1        // FIXME Why? Also I don't get why the top two bits are set.        movea   0xEC,r0,r1                                st.b    r1,lo(V850_REG_P1)[r6]        // Enable all outputs for 7-segment LED        mov     0x00,r1                                st.b    r1,lo(V850_REG_PM10)[r6]        // Set LED to 0        mov     0x00,r1                                st.b    r1,lo(V850_REG_P10)[r6]        // Init serial port 0 baud rate to divide clock down to 9600 baud        // by setting baud count here        // This may seem unnecessary, but setting up the serial allows        // us to do diag output before HAL diag is initialized. The values        // are clock dependent however, but this is only for debug so we        // don't care.        movea   0xDD,r0,r1                                st.b    r1,lo(V850_REG_BRGC0)[r6]        // and divisor here        mov     0x03,r1                                st.b    r1,lo(V850_REG_BRGMC00)[r6]        // set serial 0 to enable tx/rx and 8-N-1        movea   0xC8,r0,r1                                st.b    r1,lo(V850_REG_ASIM0)[r6]        // disable reception of serial interrupts, and set serial interrupt        // priority to level 7 (lowest)        movea   0x47,r0,r1                                st.b    r1,lo(V850_REG_STIC0)[r6]        // Memory expansion mode - set to 4MB        // We could probably set this to 256K (MM==0x4), but there seems        // no advantage        mov     0x07,r1                                st.b    r1,lo(V850_REG_MM)[r6]        // Setting the PCC register is tricky - it is a "specific register"        // We set the CPU clock to full speed        stsr    PSW,r7        ori     CYGARC_PSW_NP,r7,r8        ldsr    r8,PSW        mov     0x00,r1        st.b    r1,lo(V850_REG_PRCMD)[r6]        st.b    r1,lo(V850_REG_PCC)[r6]        ldsr    r7,PSW        nop        nop        nop        nop        nop#endif        .endm/*---------------------------------------------------------------------------*//* end of hal_platform_setup.h                                               */#endif /* CYGONCE_HAL_PLATFORM_SETUP_H */

⌨️ 快捷键说明

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