OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [hal/] [sh/] [sh2/] [v2_0/] [include/] [var_intr.h] - Rev 591

Go to most recent revision | Compare with Previous | Blame | View Log

#ifndef CYGONCE_VAR_INTR_H
#define CYGONCE_VAR_INTR_H
 
//==========================================================================
//
//      var_intr.h
//
//      HAL variant interrupt and clock support
//
//==========================================================================
//####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):    jskov
// Contributors: jskov,
// Date:         1999-04-24
// Purpose:      Define Interrupt support
// Description:  The macros defined here provide the HAL APIs for handling
//               interrupts and the clock.
//              
// Usage:
//               #include <cyg/hal/hal_intr.h>
//               ...
//              
//
//####DESCRIPTIONEND####
//
//==========================================================================
 
#include <pkgconf/hal.h>
 
#include CYGBLD_HAL_CPU_MODULES_H       // INTC module selection
 
//--------------------------------------------------------------------------
// Optional platform overrides and fallbacks
#include <cyg/hal/plf_intr.h>
 
#ifndef CYGPRI_HAL_INTERRUPT_ACKNOWLEDGE_PLF
# define CYGPRI_HAL_INTERRUPT_ACKNOWLEDGE_PLF(vec)
#endif
 
#ifndef CYGPRI_HAL_INTERRUPT_CONFIGURE_PLF
# define CYGPRI_HAL_INTERRUPT_CONFIGURE_PLF(vec, level, up)
#endif
 
//----------------------------------------------------------------------------
// Additional vectors provided by INTC V1
 
#if (CYGARC_SH_MOD_INTC == 1)
 
#ifndef CYGPRI_HAL_INTERRUPT_UPDATE_LEVEL_PLF
# define CYGPRI_HAL_INTERRUPT_UPDATE_LEVEL_PLF(vec, level)                  \
    case CYGNUM_HAL_INTERRUPT_NMI:                                          \
        /* fall through */                                                  \
    case CYGNUM_HAL_INTERRUPT_LVL4 ... CYGNUM_HAL_INTERRUPT_LVL_MAX:        \
        /* Cannot change levels */                                          \
        break;                                                           
#endif
 
#define CYGNUM_HAL_INTERRUPT_LVL8           9 
#define CYGNUM_HAL_INTERRUPT_LVL9          10
#define CYGNUM_HAL_INTERRUPT_LVL10         11
#define CYGNUM_HAL_INTERRUPT_LVL11         12
#define CYGNUM_HAL_INTERRUPT_LVL12         13
#define CYGNUM_HAL_INTERRUPT_LVL13         14
#define CYGNUM_HAL_INTERRUPT_LVL14         15
#define CYGNUM_HAL_INTERRUPT_DMAC0_TE      16
#define CYGNUM_HAL_INTERRUPT_DMAC1_TE      17
#define CYGNUM_HAL_INTERRUPT_WDT_ITI       18
#define CYGNUM_HAL_INTERRUPT_REF_CMI       19
#define CYGNUM_HAL_INTERRUPT_EDMAC_EINT    20
#define CYGNUM_HAL_INTERRUPT_FRT_ICI       21
#define CYGNUM_HAL_INTERRUPT_FRT_OCI       22
#define CYGNUM_HAL_INTERRUPT_FRT_OVI       23
#define CYGNUM_HAL_INTERRUPT_TPU0_TGI0A    24
#define CYGNUM_HAL_INTERRUPT_TPU0_TGI0B    25
#define CYGNUM_HAL_INTERRUPT_TPU0_TGI0C    26
#define CYGNUM_HAL_INTERRUPT_TPU0_TGI0D    27
#define CYGNUM_HAL_INTERRUPT_TPU0_TGI0V    28
#define CYGNUM_HAL_INTERRUPT_TPU1_TGI1A    29
#define CYGNUM_HAL_INTERRUPT_TPU1_TGI1B    30
#define CYGNUM_HAL_INTERRUPT_TPU1_TGI1V    31
#define CYGNUM_HAL_INTERRUPT_TPU1_TGI1U    32
#define CYGNUM_HAL_INTERRUPT_TPU2_TGI2A    33
#define CYGNUM_HAL_INTERRUPT_TPU2_TGI2B    34
#define CYGNUM_HAL_INTERRUPT_TPU2_TGI2V    35
#define CYGNUM_HAL_INTERRUPT_TPU2_TGI2U    36
#define CYGNUM_HAL_INTERRUPT_SCIF1_ERI1    37
#define CYGNUM_HAL_INTERRUPT_SCIF1_RXI1    38
#define CYGNUM_HAL_INTERRUPT_SCIF1_BRI1    39
#define CYGNUM_HAL_INTERRUPT_SCIF1_TXI1    40
#define CYGNUM_HAL_INTERRUPT_SCIF2_ERI2    41
#define CYGNUM_HAL_INTERRUPT_SCIF2_RXI2    42
#define CYGNUM_HAL_INTERRUPT_SCIF2_BRI2    43
#define CYGNUM_HAL_INTERRUPT_SCIF2_TXI2    44
#define CYGNUM_HAL_INTERRUPT_SIO0_RERI0    45
#define CYGNUM_HAL_INTERRUPT_SIO0_TERI0    46
#define CYGNUM_HAL_INTERRUPT_SIO0_RDFI0    47
#define CYGNUM_HAL_INTERRUPT_SIO0_TDEI0    48
#define CYGNUM_HAL_INTERRUPT_SIO1_RERI1    49
#define CYGNUM_HAL_INTERRUPT_SIO1_TERI1    50
#define CYGNUM_HAL_INTERRUPT_SIO1_RDFI1    51
#define CYGNUM_HAL_INTERRUPT_SIO1_TDEI1    52
#define CYGNUM_HAL_INTERRUPT_SIO2_RERI2    53
#define CYGNUM_HAL_INTERRUPT_SIO2_TERI2    54
#define CYGNUM_HAL_INTERRUPT_SIO2_RDFI2    55
#define CYGNUM_HAL_INTERRUPT_SIO2_TDEI2    56
 
#define CYGNUM_HAL_INTERRUPT_LVL_MAX       CYGNUM_HAL_INTERRUPT_LVL14
 
#undef  CYGNUM_HAL_ISR_MAX
#ifdef CYGNUM_HAL_ISR_PLF_MAX
# define CYGNUM_HAL_ISR_MAX                CYGNUM_HAL_ISR_PLF_MAX
#else
# define CYGNUM_HAL_ISR_MAX                CYGNUM_HAL_INTERRUPT_SIO2_TDEI2
#endif
 
// The vector used by the Real time clock
#ifndef CYGNUM_HAL_INTERRUPT_RTC
# define CYGNUM_HAL_INTERRUPT_RTC             CYGNUM_HAL_INTERRUPT_FRT_OCI
#endif
 
#elif (CYGARC_SH_MOD_INTC == 2)
 
#ifndef CYGPRI_HAL_INTERRUPT_UPDATE_LEVEL_PLF
# define CYGPRI_HAL_INTERRUPT_UPDATE_LEVEL_PLF(vec, level)                  \
    case CYGNUM_HAL_INTERRUPT_NMI:                                          \
        /* Cannot change levels */                                          \
        break;                                                           
#endif
 
#define CYGNUM_HAL_INTERRUPT_DMAC0_DEI0         9 
#define CYGNUM_HAL_INTERRUPT_DMAC1_DEI1        10
#define CYGNUM_HAL_INTERRUPT_DMAC2_DEI2        11
#define CYGNUM_HAL_INTERRUPT_DMAC3_DEI3        12
#define CYGNUM_HAL_INTERRUPT_MTU0_TGI0A        13
#define CYGNUM_HAL_INTERRUPT_MTU0_TGI0B        14
#define CYGNUM_HAL_INTERRUPT_MTU0_TGI0C        15
#define CYGNUM_HAL_INTERRUPT_MTU0_TGI0D        16
#define CYGNUM_HAL_INTERRUPT_MTU0_TGI0V        17
#define CYGNUM_HAL_INTERRUPT_MTU1_TGI1A        18
#define CYGNUM_HAL_INTERRUPT_MTU1_TGI1B        19
#define CYGNUM_HAL_INTERRUPT_MTU1_TGI1V        20
#define CYGNUM_HAL_INTERRUPT_MTU1_TGI1U        21
#define CYGNUM_HAL_INTERRUPT_MTU2_TGI2A        22
#define CYGNUM_HAL_INTERRUPT_MTU2_TGI2B        23
#define CYGNUM_HAL_INTERRUPT_MTU2_TGI2V        24
#define CYGNUM_HAL_INTERRUPT_MTU2_TGI2U        25
#define CYGNUM_HAL_INTERRUPT_MTU3_TGI3A        26
#define CYGNUM_HAL_INTERRUPT_MTU3_TGI3B        27
#define CYGNUM_HAL_INTERRUPT_MTU3_TGI3C        28
#define CYGNUM_HAL_INTERRUPT_MTU3_TGI3D        29
#define CYGNUM_HAL_INTERRUPT_MTU3_TGI3V        30
#define CYGNUM_HAL_INTERRUPT_MTU4_TGI4A        31
#define CYGNUM_HAL_INTERRUPT_MTU4_TGI4B        32
#define CYGNUM_HAL_INTERRUPT_MTU4_TGI4C        33
#define CYGNUM_HAL_INTERRUPT_MTU4_TGI4D        34
#define CYGNUM_HAL_INTERRUPT_MTU4_TGI4V        35
#define CYGNUM_HAL_INTERRUPT_SCI0_ERI0         36
#define CYGNUM_HAL_INTERRUPT_SCI0_RXI0         37
#define CYGNUM_HAL_INTERRUPT_SCI0_TXI0         38
#define CYGNUM_HAL_INTERRUPT_SCI0_TEI0         39
#define CYGNUM_HAL_INTERRUPT_SCI1_ERI1         40
#define CYGNUM_HAL_INTERRUPT_SCI1_RXI1         41
#define CYGNUM_HAL_INTERRUPT_SCI1_TXI1         42
#define CYGNUM_HAL_INTERRUPT_SCI1_TEI1         43
#define CYGNUM_HAL_INTERRUPT_AD_ADI0           44
#define CYGNUM_HAL_INTERRUPT_AD_ADI1           45
#define CYGNUM_HAL_INTERRUPT_DTC_SWDTCE        46
#define CYGNUM_HAL_INTERRUPT_CMT0_CMI0         47
#define CYGNUM_HAL_INTERRUPT_CMT1_CMI1         48
#define CYGNUM_HAL_INTERRUPT_WDT_ITI           49
#define CYGNUM_HAL_INTERRUPT_BSC_CMI           50
#define CYGNUM_HAL_INTERRUPT_IO_OEI            51
#define CYGNUM_HAL_INTERRUPT_VAR_RESERVED      52       // just to catch bad assignments
 
#undef  CYGNUM_HAL_ISR_MAX
#ifdef CYGNUM_HAL_ISR_PLF_MAX
# define CYGNUM_HAL_ISR_MAX                  CYGNUM_HAL_ISR_PLF_MAX
#else
# define CYGNUM_HAL_ISR_MAX                  CYGNUM_HAL_INTERRUPT_VAR_RESERVED
#endif
 
//                           eCos vector this entry decodes to , actual HW interrupt vector
#define CYGHWR_HAL_SH_SH2_CUSTOM_INTERRUPT_LAYOUT                         \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL0         ,  1 ;     \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL1         ,  2 ;     \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL2         ,  3 ;     \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL3         ,  4 ;     \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL4         ,  5 ;     \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL5         ,  6 ;     \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL6         ,  7 ;     \
        exception_vector_int CYGNUM_HAL_INTERRUPT_LVL7         ,  8 ;     \
                                                                          \
        exception_vector_int CYGNUM_HAL_INTERRUPT_DMAC0_DEI0   ,  9  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 10  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 11  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 12  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_DMAC1_DEI1   , 13  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 14  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 15  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 16  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_DMAC2_DEI2   , 17  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 18  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 19  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 20  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_DMAC3_DEI3   , 21  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 22  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 23  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 24  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU0_TGI0A   , 25  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU0_TGI0B   , 26  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU0_TGI0C   , 27  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU0_TGI0D   , 28  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU0_TGI0V   , 29  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 30  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 31  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 32  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU1_TGI1A   , 33  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU1_TGI1B   , 34  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 35  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 36  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU1_TGI1V   , 37  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU1_TGI1U   , 38  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 39  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 40  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU2_TGI2A   , 41  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU2_TGI2B   , 42  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 43  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 44  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU2_TGI2V   , 45  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU2_TGI2U   , 46  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 47  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 48  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU3_TGI3A   , 49  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU3_TGI3B   , 50  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU3_TGI3C   , 51  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU3_TGI3D   , 52  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU3_TGI3V   , 53  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 54  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 55  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 56  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU4_TGI4A   , 57  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU4_TGI4B   , 58  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU4_TGI4C   , 59  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU4_TGI4D   , 60  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_MTU4_TGI4V   , 61  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 62  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 63  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 64  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI0_ERI0    , 65  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI0_RXI0    , 66  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI0_TXI0    , 67  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI0_TEI0    , 68  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI1_ERI1    , 69  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI1_RXI1    , 70  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI1_TXI1    , 71  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_SCI1_TEI1    , 72  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_AD_ADI0      , 73  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_AD_ADI1      , 74  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 75  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 76  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_DTC_SWDTCE   , 77  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 78  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 79  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 80  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_CMT0_CMI0    , 81  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 82  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 83  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 84  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_CMT1_CMI1    , 85  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 86  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 87  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 88  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_WDT_ITI      , 89  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_BSC_CMI      , 90  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 91  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_VAR_RESERVED , 92  ;    \
        exception_vector_int CYGNUM_HAL_INTERRUPT_BSC_CMI      , 93  ;    \
        .set    vecno, CYGNUM_HAL_INTERRUPT_VAR_RESERVED             ;    \
        .rept   (256-CYGNUM_HAL_INTERRUPT_VAR_RESERVED)              ;    \
        exception_vector_int vecno                                   ;    \
        .set    vecno, vecno+1                                       ;    \
        .endr
 
// The vector used by the Real time clock
#ifndef CYGNUM_HAL_INTERRUPT_RTC
# define CYGNUM_HAL_INTERRUPT_RTC             CYGNUM_HAL_INTERRUPT_CMT0_CMI0
#endif
 
#else
 
# error "No vectors defined for this INTC type"
 
#endif
 
//----------------------------------------------------------------------------
// Platform may provide extensions to the interrupt configuration functions
// via these macros. The first macro is put inside the functions's
// switch statements, the last two called as functions.
#ifndef CYGPRI_HAL_INTERRUPT_UPDATE_LEVEL_PLF
# define CYGPRI_HAL_INTERRUPT_UPDATE_LEVEL_PLF(vec, level)
# define CYGPRI_HAL_INTERRUPT_ACKNOWLEDGE_PLF(vec)
# define CYGPRI_HAL_INTERRUPT_CONFIGURE_PLF(vec)
#endif
 
#ifndef __ASSEMBLER__
//--------------------------------------------------------------------------
// Clock control, using Free-running Timer to match on compare register A
 
#include <cyg/hal/sh_regs.h>            // register definitions
#include <cyg/hal/hal_io.h>             // io macros
#include <cyg/infra/cyg_ass.h>          // CYG_FAIL
 
#if defined(CYGARC_SH_MOD_FRT)
#define HAL_CLOCK_VAR_INITIALIZE( _period_ )                                \
    CYG_MACRO_START                                                         \
    register cyg_uint8 _tier_;                                              \
                                                                            \
    /* Disable interrupts while programming the timer */                    \
    HAL_READ_UINT8(CYGARC_REG_TIER, _tier_);                                \
    HAL_WRITE_UINT8(CYGARC_REG_TIER, 0);                                    \
                                                                            \
    /* Clear counter register */                                            \
    HAL_WRITE_UINT8(CYGARC_REG_FRC, 0);                                     \
    /* Set compare A register */                                            \
    HAL_WRITE_UINT8(CYGARC_REG_TOCR, CYGARC_REG_TOCR_OLVLA);                \
    HAL_WRITE_UINT16(CYGARC_REG_OCR, _period_);                             \
                                                                            \
    /* Enable match A counter clear */                                      \
    HAL_WRITE_UINT8(CYGARC_REG_FTCSR, CYGARC_REG_FTCSR_CCLRA);              \
    /* Set interrupt prescaling */                                          \
    HAL_WRITE_UINT8(CYGARC_REG_TCR,                                         \
                     ((8==CYGHWR_HAL_SH_FRT_PRESCALE) ?                     \
                          CYGARC_REG_TCR_CLK_8 :                            \
                      (32==CYGHWR_HAL_SH_FRT_PRESCALE) ?                    \
                          CYGARC_REG_TCR_CLK_32:                            \
                      (128==CYGHWR_HAL_SH_FRT_PRESCALE) ?                   \
                          CYGARC_REG_TCR_CLK_128:CYGARC_REG_TCR_CLK_EXT));  \
                                                                            \
                                                                            \
    CYG_MACRO_END
 
// HAL_CLOCK_VAR_INITIALIZE is called from hal_variant_init since the
// FRT is also used by the hal_delay_us code.
#define HAL_CLOCK_INITIALIZE( _period_ )                                    \
    CYG_MACRO_START                                                         \
    register cyg_uint8 _tier_;                                              \
                                                                            \
    CYG_ASSERT((cyg_uint16)(_period_) < (cyg_uint16)0xfffe,                 \
               "period too large for 16bit FRT");                           \
                                                                            \
    /* Disable interrupts while programming the timer */                    \
    HAL_READ_UINT8(CYGARC_REG_TIER, _tier_);                                \
    HAL_WRITE_UINT8(CYGARC_REG_TIER, 0);                                    \
                                                                            \
    /* Set compare A register */                                            \
    HAL_WRITE_UINT8(CYGARC_REG_TOCR, CYGARC_REG_TOCR_OLVLA);                \
    HAL_WRITE_UINT16(CYGARC_REG_OCR, _period_);                             \
                                                                            \
    /* Enable interrupt */                                                  \
    _tier_ |= CYGARC_REG_TIER_OCIAE;                                        \
    HAL_WRITE_UINT8(CYGARC_REG_TIER, _tier_);                               \
                                                                            \
    CYG_MACRO_END
 
#define HAL_CLOCK_RESET( _vector_, _period_ )   \
    CYG_MACRO_START                             \
    register cyg_uint8 _ftcsr_;                 \
                                                \
    /* Clear match flag */                      \
    HAL_READ_UINT8(CYGARC_REG_FTCSR, _ftcsr_);  \
    _ftcsr_ &= ~CYGARC_REG_FTCSR_OCFA;          \
    HAL_WRITE_UINT8(CYGARC_REG_FTCSR, _ftcsr_); \
                                                \
    CYG_MACRO_END
 
#define HAL_CLOCK_READ( _pvalue_ )              \
    CYG_MACRO_START                             \
    register cyg_uint16 _frc_;                  \
                                                \
    HAL_READ_UINT16(CYGARC_REG_FRC, _frc_);     \
                                                \
    *(_pvalue_) = _frc_;                        \
    CYG_MACRO_END
 
#elif defined(CYGARC_SH_MOD_CMT)
 
/* Compare Match Timer 0 is used for the eCos kernel RTC */
#define HAL_CLOCK_VAR_INITIALIZE( _period_ )                                \
    CYG_MACRO_START                                                         \
    register cyg_uint16 _tmp_;                                              \
                                                                            \
    /* Disable timer while programming it */                                \
    HAL_READ_UINT16(CYGARC_REG_CMSTR, _tmp_);                               \
    HAL_WRITE_UINT16(CYGARC_REG_CMSTR, _tmp_ & ~CYGARC_REG_CMSTR_STR0);     \
                                                                            \
    /* Clear counter register */                                            \
    HAL_WRITE_UINT16(CYGARC_REG_CMCNT0, 0);                                 \
    /* Set compare 0 register */                                            \
    HAL_WRITE_UINT16(CYGARC_REG_CMCOR0, _period_);                          \
                                                                            \
    /* Set prescaling and disable interrupts */                             \
    HAL_WRITE_UINT16(CYGARC_REG_CMCSR0,                                     \
                     ((8==CYGHWR_HAL_SH_CMT_PRESCALE) ?                     \
                          CYGARC_REG_CMCSR_CLK_8 :                          \
                      (32==CYGHWR_HAL_SH_CMT_PRESCALE) ?                    \
                          CYGARC_REG_CMCSR_CLK_32:                          \
                      (128==CYGHWR_HAL_SH_CMT_PRESCALE) ?                   \
                          CYGARC_REG_CMCSR_CLK_128:CYGARC_REG_CMCSR_CLK_512));  \
                                                                            \
    /* Start timer */                                                       \
    HAL_WRITE_UINT16(CYGARC_REG_CMSTR, _tmp_ | CYGARC_REG_CMSTR_STR0);      \
                                                                            \
    CYG_MACRO_END
 
// HAL_CLOCK_VAR_INITIALIZE is called from hal_variant_init since the
// CMT0 is also used by the hal_delay_us code.
#define HAL_CLOCK_INITIALIZE( _period_ )                                    \
    CYG_MACRO_START                                                         \
    register cyg_uint16 _tmp_;                                              \
                                                                            \
    CYG_ASSERT((cyg_uint16)(_period_) < (cyg_uint16)0xfffe,                 \
               "period too large for 16bit CMT");                           \
                                                                            \
    /* Disable timer while programming it */                                \
    HAL_READ_UINT16(CYGARC_REG_CMSTR, _tmp_);                               \
    HAL_WRITE_UINT16(CYGARC_REG_CMSTR, _tmp_ & ~CYGARC_REG_CMSTR_STR0);     \
                                                                            \
    /* Clear counter register */                                            \
    HAL_WRITE_UINT16(CYGARC_REG_CMCNT0, 0);                                 \
    /* Set compare 0 register */                                            \
    HAL_WRITE_UINT16(CYGARC_REG_CMCOR0, _period_);                          \
                                                                            \
    /* Set prescaling and enable interrupts */                              \
    HAL_WRITE_UINT16(CYGARC_REG_CMCSR0, CYGARC_REG_CMCSR_CMIE |             \
                     ((8==CYGHWR_HAL_SH_CMT_PRESCALE) ?                     \
                          CYGARC_REG_CMCSR_CLK_8 :                          \
                      (32==CYGHWR_HAL_SH_CMT_PRESCALE) ?                    \
                          CYGARC_REG_CMCSR_CLK_32:                          \
                      (128==CYGHWR_HAL_SH_CMT_PRESCALE) ?                   \
                          CYGARC_REG_CMCSR_CLK_128:CYGARC_REG_CMCSR_CLK_512));  \
                                                                            \
    /* Start timer */                                                       \
    HAL_WRITE_UINT16(CYGARC_REG_CMSTR, _tmp_ | CYGARC_REG_CMSTR_STR0);      \
                                                                            \
    CYG_MACRO_END
 
#define HAL_CLOCK_RESET( _vector_, _period_ )   \
    CYG_MACRO_START                             \
    register cyg_uint16 _tmp_;                  \
                                                \
    /* Clear match flag */                      \
    HAL_READ_UINT16(CYGARC_REG_CMCSR0, _tmp_);  \
    _tmp_ &= ~CYGARC_REG_CMCSR_CMF;             \
    HAL_WRITE_UINT16(CYGARC_REG_CMCSR0, _tmp_); \
                                                \
    CYG_MACRO_END
 
#define HAL_CLOCK_READ( _pvalue_ )              \
    CYG_MACRO_START                             \
    register cyg_uint16 _tmp_;                  \
                                                \
    HAL_READ_UINT16(CYGARC_REG_CMCNT0, _tmp_);  \
                                                \
    *(_pvalue_) = _tmp_;                        \
    CYG_MACRO_END
 
 
 
#else
# error "No RTC handling defined"
#endif
 
 
 
#ifdef CYGVAR_KERNEL_COUNTERS_CLOCK_LATENCY
#define HAL_CLOCK_LATENCY( _pvalue_ ) HAL_CLOCK_READ(_pvalue_)
#endif
 
 
//----------------------------------------------------------------------------
// Reset.
#ifndef HAL_PLATFORM_RESET
#define HAL_PLATFORM_RESET()                                                                    \
 CYG_MACRO_START                                                                                \
 HAL_WRITE_UINT16(CYGARC_REG_RSTCSR_W, CYGARC_REG_RSTCSR_W_RSTx_MAGIC|CYGARC_REG_RSTCSR_RSTE);  \
 HAL_WRITE_UINT16(CYGARC_REG_WTCNT_W, CYGARC_REG_WTCNT_W_MAGIC|0xfe);                           \
 HAL_WRITE_UINT16(CYGARC_REG_WTCSR_W, CYGARC_REG_WTCSR_W_MAGIC|CYGARC_REG_WTCSR_TME|CYGARC_REG_WTCSR_WTIT);           \
 /* wait for it */                                                                              \
 for(;;) ;                                                                                      \
 CYG_MACRO_END
#else
#define HAL_PLATFORM_RESET()
#endif
 
#endif // __ASSEMBLER__
 
//--------------------------------------------------------------------------
#endif // ifndef CYGONCE_VAR_INTR_H
// End of var_intr.h
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.