var_misc.c

来自「eCos操作系统源码」· C语言 代码 · 共 461 行 · 第 1/2 页

C
461
字号
        iprX &= ~CYGARC_REG_IPRE_DMAC_MASK;                                      iprX |= (level)*CYGARC_REG_IPRE_DMAC_PRI1;                             HAL_WRITE_UINT16(CYGARC_REG_IPRE, iprX);                                 break;                                                               case CYGNUM_HAL_INTERRUPT_IRDA_ERI1:                                     case CYGNUM_HAL_INTERRUPT_IRDA_RXI1:                                     case CYGNUM_HAL_INTERRUPT_IRDA_BRI1:                                     case CYGNUM_HAL_INTERRUPT_IRDA_TXI1:                                         HAL_READ_UINT16(CYGARC_REG_IPRE, iprX);                                  iprX &= ~CYGARC_REG_IPRE_IRDA_MASK;                                      iprX |= (level)*CYGARC_REG_IPRE_IRDA_PRI1;                             HAL_WRITE_UINT16(CYGARC_REG_IPRE, iprX);                                 break;                                                               case CYGNUM_HAL_INTERRUPT_SCIF_ERI2:                                     case CYGNUM_HAL_INTERRUPT_SCIF_RXI2:                                     case CYGNUM_HAL_INTERRUPT_SCIF_BRI2:                                     case CYGNUM_HAL_INTERRUPT_SCIF_TXI2:                                         HAL_READ_UINT16(CYGARC_REG_IPRE, iprX);                                  iprX &= ~CYGARC_REG_IPRE_SCIF_MASK;                                      iprX |= (level)*CYGARC_REG_IPRE_SCIF_PRI1;                             HAL_WRITE_UINT16(CYGARC_REG_IPRE, iprX);                                 break;                                                               case CYGNUM_HAL_INTERRUPT_ADC_ADI:                                           HAL_READ_UINT16(CYGARC_REG_IPRE, iprX);                                  iprX &= ~CYGARC_REG_IPRE_ADC_MASK;                                       iprX |= (level)*CYGARC_REG_IPRE_ADC_PRI1;                              HAL_WRITE_UINT16(CYGARC_REG_IPRE, iprX);                                 break;                                                           #endif // (CYGARC_SH_MOD_INTC >= 2)#if (CYGARC_SH_MOD_INTC >= 3)        /* IPRF */                                                               case CYGNUM_HAL_INTERRUPT_LCDC_LCDI:                                         HAL_READ_UINT16(CYGARC_REG_IPRF, iprX);                                  iprX &= ~CYGARC_REG_IPRF_LCDI_MASK;                                      iprX |= (level)*CYGARC_REG_IPRF_LCDI_PRI1;                             HAL_WRITE_UINT16(CYGARC_REG_IPRF, iprX);                                 break;                                                               case CYGNUM_HAL_INTERRUPT_PCC_PCC0:                                          HAL_READ_UINT16(CYGARC_REG_IPRF, iprX);                                  iprX &= ~CYGARC_REG_IPRF_PCC0_MASK;                                      iprX |= (level)*CYGARC_REG_IPRF_PCC0_PRI1;                             HAL_WRITE_UINT16(CYGARC_REG_IPRF, iprX);                                 break;                                                               case CYGNUM_HAL_INTERRUPT_PCC_PCC1:                                          HAL_READ_UINT16(CYGARC_REG_IPRF, iprX);                                  iprX &= ~CYGARC_REG_IPRF_PCC1_MASK;                                      iprX |= (level)*CYGARC_REG_IPRF_PCC1_PRI1;                             HAL_WRITE_UINT16(CYGARC_REG_IPRF, iprX);                                 break;                                                           #endif // (CYGARC_SH_MOD_INTC >= 3)    case CYGNUM_HAL_INTERRUPT_RESERVED_1E0:                                  case CYGNUM_HAL_INTERRUPT_RESERVED_3E0:                                      /* Do nothing for these reserved vectors. */                             break;                                                               // Platform extensions    CYGPRI_HAL_INTERRUPT_UPDATE_LEVEL_PLF(vector, level)    default:        CYG_FAIL("Unknown interrupt vector");                                     break;    }                                                                    }voidhal_interrupt_set_level(int vector, int level){    CYG_ASSERT((0 <= (level) && 15 >= (level)), "Illegal level");        CYG_ASSERT((CYGNUM_HAL_ISR_MIN <= (vector)                                         && CYGNUM_HAL_ISR_MAX >= (vector)), "Illegal vector");                                                                              cyg_hal_ILVL_table[vector] = level;    hal_interrupt_update_level(vector);}voidhal_interrupt_mask(int vector)                                    {    switch( (vector) ) {                                                    case CYGNUM_HAL_INTERRUPT_NMI:                                                /* fall through */                                                    case CYGNUM_HAL_INTERRUPT_LVL0 ... CYGNUM_HAL_INTERRUPT_LVL14:        /* Normally can only be masked by fiddling Imask in SR,           but some platforms use external interrupt controller,           so allow regular handling. */        // fall through    case CYGNUM_HAL_INTERRUPT_TMU0_TUNI0 ... CYGNUM_HAL_ISR_MAX:                    cyg_hal_IMASK_table[vector] = 0;        hal_interrupt_update_level(vector);        break;                                                                case CYGNUM_HAL_INTERRUPT_RESERVED_1E0:                                   case CYGNUM_HAL_INTERRUPT_RESERVED_3E0:                                       /* Do nothing for these reserved vectors. */                              break;                                                                default:                                                                      CYG_FAIL("Unknown interrupt vector");                                     break;                                                                }                                                                     }voidhal_interrupt_unmask(int vector)                                  {    switch( (vector) ) {                                                    case CYGNUM_HAL_INTERRUPT_NMI:                                                /* fall through */                                                    case CYGNUM_HAL_INTERRUPT_LVL0 ... CYGNUM_HAL_INTERRUPT_LVL14:                  /* Normally can only be masked by fiddling Imask in SR,           but some platforms use external interrupt controller,           so allow regular handling. */        // fall through    case CYGNUM_HAL_INTERRUPT_TMU0_TUNI0 ... CYGNUM_HAL_ISR_MAX:                    cyg_hal_IMASK_table[vector] = 1;        hal_interrupt_update_level(vector);        break;                                                                case CYGNUM_HAL_INTERRUPT_RESERVED_1E0:                                   case CYGNUM_HAL_INTERRUPT_RESERVED_3E0:                                       /* Do nothing for these reserved vectors. */                              break;                                                                default:                                                                      CYG_FAIL("Unknown interrupt vector");                                     break;                                                                }                                                                     }voidhal_interrupt_acknowledge(int vector){#if (CYGARC_SH_MOD_INTC >= 2)    if ( (vector) >= CYGNUM_HAL_INTERRUPT_IRQ_IRQ0                               && (vector) <= CYGNUM_HAL_INTERRUPT_IRQ_IRQ5) {                                                                                                  cyg_uint8 irr0;                                                                                                                                     HAL_READ_UINT8(CYGARC_REG_IRR0, irr0);               switch ( vector ) {                          #ifndef CYGHWR_HAL_SH_IRQ_USE_IRQLVL                         case CYGNUM_HAL_INTERRUPT_IRQ_IRQ0:                      irr0 &= ~CYGARC_REG_IRR0_IRQ0;                       break;                                           case CYGNUM_HAL_INTERRUPT_IRQ_IRQ1:                      irr0 &= ~CYGARC_REG_IRR0_IRQ1;                       break;                                           case CYGNUM_HAL_INTERRUPT_IRQ_IRQ2:                      irr0 &= ~CYGARC_REG_IRR0_IRQ2;                       break;                                           case CYGNUM_HAL_INTERRUPT_IRQ_IRQ3:                      irr0 &= ~CYGARC_REG_IRR0_IRQ3;                       break;                                   #endif                                                       case CYGNUM_HAL_INTERRUPT_IRQ_IRQ4:                      irr0 &= ~CYGARC_REG_IRR0_IRQ4;                       break;                                           case CYGNUM_HAL_INTERRUPT_IRQ_IRQ5:                      irr0 &= ~CYGARC_REG_IRR0_IRQ5;                       break;                                           default:                                                 CYG_FAIL("Unhandled interrupt vector");          }                                                    HAL_WRITE_UINT8(CYGARC_REG_IRR0, irr0);          }                                                                     #endif    CYGPRI_HAL_INTERRUPT_ACKNOWLEDGE_PLF(vector);}// Note: The PINTs can be masked and configured individually, even// though there are only two vectors. Maybe add some fake vectors just// for masking/configuring?void hal_interrupt_configure(int vector, int level, int up){#if (CYGARC_SH_MOD_INTC >= 2)    if ( (vector) >= CYGNUM_HAL_INTERRUPT_IRQ_IRQ0                              && (vector) <= CYGNUM_HAL_INTERRUPT_IRQ_IRQ5) {                                                                                                cyg_uint16 icr1, ss, mask;                                               ss = 0;                                                                  mask = CYGARC_REG_ICR1_SENSE_UP|CYGARC_REG_ICR1_SENSE_LEVEL;             if (up) ss |= CYGARC_REG_ICR1_SENSE_UP;                                if (level) ss |= CYGARC_REG_ICR1_SENSE_LEVEL;                          CYG_ASSERT(!(up && level), "Cannot trigger on high level!");                                                                                  switch( (vector) ) {                                                   case CYGNUM_HAL_INTERRUPT_IRQ_IRQ5:                                          ss <<= CYGARC_REG_ICR1_SENSE_IRQ5_shift;                                 mask <<= CYGARC_REG_ICR1_SENSE_IRQ5_shift;                               break;                                                               case CYGNUM_HAL_INTERRUPT_IRQ_IRQ4:                                          ss <<= CYGARC_REG_ICR1_SENSE_IRQ4_shift;                                 mask <<= CYGARC_REG_ICR1_SENSE_IRQ4_shift;                               break;                                                       #ifndef CYGHWR_HAL_SH_IRQ_USE_IRQLVL        case CYGNUM_HAL_INTERRUPT_IRQ_IRQ3:                                          ss <<= CYGARC_REG_ICR1_SENSE_IRQ3_shift;                                 mask <<= CYGARC_REG_ICR1_SENSE_IRQ3_shift;                               break;                                                               case CYGNUM_HAL_INTERRUPT_IRQ_IRQ2:                                          ss <<= CYGARC_REG_ICR1_SENSE_IRQ2_shift;                                 mask <<= CYGARC_REG_ICR1_SENSE_IRQ2_shift;                               break;                                                               case CYGNUM_HAL_INTERRUPT_IRQ_IRQ1:                                          ss <<= CYGARC_REG_ICR1_SENSE_IRQ1_shift;                                 mask <<= CYGARC_REG_ICR1_SENSE_IRQ1_shift;                               break;                                                               case CYGNUM_HAL_INTERRUPT_IRQ_IRQ0:                                          ss <<= CYGARC_REG_ICR1_SENSE_IRQ0_shift;                                 mask <<= CYGARC_REG_ICR1_SENSE_IRQ0_shift;                               break;                                                       #endif        default:            CYG_FAIL("Unhandled interrupt vector");        }                                                                                 HAL_READ_UINT16(CYGARC_REG_ICR1, icr1);                                  icr1 &= ~mask;                                                           icr1 |= ss;                                                              HAL_WRITE_UINT16(CYGARC_REG_ICR1, icr1);                             }                                                                    #endif    CYGPRI_HAL_INTERRUPT_CONFIGURE_PLF(vector, level, up);}//---------------------------------------------------------------------------// End of hal_misc.c

⌨️ 快捷键说明

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