view chipsetsw/drivers/drv_core/inth/sys_inth.h @ 295:38ef7d6a6277

l1p_cmpl.c: initial import from LoCosto source
author Mychaela Falconia <falcon@freecalypso.org>
date Mon, 02 Oct 2017 06:01:18 +0000
parents 509db1a7b7b8
children
line wrap: on
line source

/*                @(#) nom : sys_inth.h SID: 1.2 date : 05/23/03              */
/* Filename:      sys_inth.h                                                  */
/* Version:       1.2                                                         */
/******************************************************************************
 *                   WIRELESS COMMUNICATION SYSTEM DEVELOPMENT
 *
 *             (C) 2002 Texas Instruments France. All rights reserved
 *
 *                          Author : Francois AMAND
 *
 *
 *  Important Note
 *  --------------
 *
 *  This S/W is a preliminary version. It contains information on a product 
 *  under development and is issued for evaluation purposes only. Features 
 *  characteristics, data and other information are subject to change.
 *
 *  The S/W is furnished under Non Disclosure Agreement and may be used or
 *  copied only in accordance with the terms of the agreement. It is an offence
 *  to copy the software in any way except as specifically set out in the 
 *  agreement. No part of this document may be reproduced or transmitted in any
 *  form or by any means, electronic or mechanical, including photocopying and
 *  recording, for any purpose without the express written permission of Texas
 *  Instruments Inc.
 *
 ******************************************************************************
 *
 *  FILE NAME: sys_inth.h
 *
 *
 *  PURPOSE:  Header file for the Interrupt Handler Driver.
 *
 *
 *  FILE REFERENCES:
 *
 *  Name                  IO      Description
 *  -------------         --      ---------------------------------------------
 *  
 *
 *
 *  EXTERNAL VARIABLES:
 *
 *  Source:
 *
 *  Name                  Type              IO   Description
 *  -------------         ---------------   --   ------------------------------
 *
 *
 *
 *  EXTERNAL REFERENCES:
 *
 *  Name                Description
 *  ------------------  -------------------------------------------------------
 *
 *
 *
 *  ABNORMAL TERMINATION CONDITIONS, ERROR AND WARNING MESSAGES:
 *  
 *
 *
 *  ASSUMPTION, CONSTRAINTS, RESTRICTIONS:
 *  
 *
 *
 *  NOTES:
 *  
 *
 *
 *  REQUIREMENTS/FUNCTIONAL SPECIFICATION REFERENCES:
 *
 *
 *
 *
 *  DEVELOPMENT HISTORY:
 *
 *  Date         Name(s)         Version  Description
 *  -----------  --------------  -------  -------------------------------------
 *  11-Oct-2002  Francois AMAND  0.0.1    First implementation
 *
 *  ALGORITHM: 
 *
 *
 *****************************************************************************/

#include "l1sw.cfg"
#include "chipset.cfg"

#if (CHIPSET == 12)

  #ifndef __SYS_INTH_H__
    #define __SYS_INTH_H__

    #if (OP_L1_STANDALONE == 0)
      #include "main/sys_types.h"
    #else
      #include "sys_types.h"
    #endif
    #include "sys_map.h"


    /*
     *  Driver version
     */
    #define C_INTH_DRIVER_VERSION 0x0001
  
  
    /*
     *  Number of interrupts
     */
    #define C_INTH_NUM_INT        32
    #define C_INTH_2ND_NUM_INT    5
    
    #define C_INTH_NB_INTERRUPT   (C_INTH_NUM_INT + C_INTH_2ND_NUM_INT)
  
  
    /*
     *  Main INTH : Interrupt bit numbers
     */
    #define C_INTH_WATCHDOG_IT       0
    #define C_INTH_TIMER1_IT         1
    #define C_INTH_TIMER2_IT         2
    #define C_INTH_TSP_RECEIVE_IT    3
    #define C_INTH_FRAME_IT          4
    #define C_INTH_PAGE_IT           5
    #define C_INTH_SIM_IT            6
    #define C_INTH_UART_MODEM1_IT    7
    #define C_INTH_KEYBOARD_IT       8
    #define C_INTH_RTC_TIMER_IT      9
    #define C_INTH_RTC_ALARM_IT      10
    #define C_INTH_ULPD_GAUGING_IT   11
    #define C_INTH_ABB_IRQ_IT        12
    #define C_INTH_SPIv              13
    #define C_INTH_DMA_IT            14
    #define C_INTH_API_IT            15
    #define C_INTH_GPIO_IT           16
    #define C_INTH_ABB_FIQ_IT        17
    #define C_INTH_UART_IRDA_IT      18
    #define C_INTH_TGSM_IT           19
    #define C_INTH_GEA_IT            20
    #define C_INTH_EXT_IRQ1_IT       21
    #define C_INTH_EXT_IRQ2_IT       22
    #define C_INTH_USIM_CD_IT        23
    #define C_INTH_USIM_IT           24
    #define C_INTH_LCD_IT            25
    #define C_INTH_USB_IT            26
    #define C_INTH_MMC_SD_MS_IT      27
    #define C_INTH_UART_MODEM2_IT    28
    #define C_INTH_2ND_INTH_IT       29
    #define C_INTH_I2C_IT            30
    #define C_INTH_NAND_FLASH_IT     31
  
    /*
     *  Second INTH : Interrupt bit numbers
     */
    #define C_INTH_RNG_IT            32
    #define C_INTH_SHA1_MD5_IT       33
    #define C_INTH_EMPU_IT           34
    #define C_INTH_SEC_DMA_IT        35
    #define C_INTH_SEC_TIMER_IT      36
  
  
    /*
     * Address of the Main interrupt handler registers
     */
    #define C_INTH_IT_REG1      C_MAP_INTH_BASE            /* INTH IT register 1 */
    #define C_INTH_IT_REG2     (C_MAP_INTH_BASE + 0x02)    /* INTH IT register 2 */
    #define C_INTH_MASK_REG1   (C_MAP_INTH_BASE + 0x08)    /* INTH mask register 1 */
    #define C_INTH_MASK_REG2   (C_MAP_INTH_BASE + 0x0a)    /* INTH mask register 2 */
    #define C_INTH_B_IRQ_REG   (C_MAP_INTH_BASE + 0x10)    /* INTH source binary IRQ reg. */
    #define C_INTH_B_FIQ_REG   (C_MAP_INTH_BASE + 0x12)    /* INTH source binary FIQ reg. */
    #define C_INTH_CTRL_REG    (C_MAP_INTH_BASE + 0x14)    /* INTH control register */
    #define C_INTH_EXT_REG     (C_MAP_INTH_BASE + 0x20)    /* INTH 1st external int. reg. */
  
    /*
     * Address of the Second interrupt handler registers
     */
    #define C_INTH2_IT_REG1   C_MAP_INTH_SEC_BASE          /* INTH IT register 1 */
    #define C_INTH2_MASK_REG1 (C_MAP_INTH_SEC_BASE + 0x08) /* INTH mask register 1 */
    #define C_INTH2_B_IRQ_REG (C_MAP_INTH_SEC_BASE + 0x10) /* INTH source binary IRQ reg. */
    #define C_INTH2_CTRL_REG  (C_MAP_INTH_SEC_BASE + 0x14) /* INTH control register */
    #define C_INTH2_EXT_REG   (C_MAP_INTH_SEC_BASE + 0x20) /* INTH 1st external int. reg. */
  
  
    /*
     * INTH_B_x_REG definition
     */
    #define C_INTH_SRC_NUM    0x001f
    #define C_INTH2_SRC_NUM   0x0007
  
    /*
     * ILR_IRQx_REG definition
     */
    #define C_INTH_IRQ        0
    #define C_INTH_FIQ        1
  
    #define C_INTH_LEVEL      0
    #define C_INTH_EDGE       1
  
  

    /****************************************************************************
     *                            MACRO DEFINITION
     ***************************************************************************/
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH_ENABLE_ONE_IT
     *      Enable the interrupt specified in argument.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *  d_it           Interrupt index
     *
     * RETURN VALUE: None
     *
     ***************************************************************************/
  
    #define F_INTH_ENABLE_ONE_IT(d_it) { \
      if (d_it < 16) \
        * (volatile SYS_UWORD16 *) C_INTH_MASK_REG1 &= ~(1 << d_it); \
      else if (d_it < C_INTH_NUM_INT) \
        * (volatile SYS_UWORD16 *) C_INTH_MASK_REG2 &= ~(1 << (d_it-16)); \
      else if (d_it < (C_INTH_NUM_INT + C_INTH_2ND_NUM_INT)) \
        * (volatile SYS_UWORD16 *) C_INTH2_MASK_REG1 &= ~(1 << (d_it-32)); \
    }
  
  
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH_DISABLE_ONE_IT
     *      Disable the interrupt specified in argument.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *  d_it           Interrupt index
     *
     * RETURN VALUE: None
     *
     ***************************************************************************/
  
    #define F_INTH_DISABLE_ONE_IT(d_it) { \
      if (d_it < 16) \
        * (volatile SYS_UWORD16 *) C_INTH_MASK_REG1 |= (1 << d_it); \
      else if (d_it < C_INTH_NUM_INT) \
        * (volatile SYS_UWORD16 *) C_INTH_MASK_REG2 |= (1 << (d_it-16)); \
      else if (d_it < (C_INTH_NUM_INT + C_INTH_2ND_NUM_INT)) \
        * (volatile SYS_UWORD16 *) C_INTH2_MASK_REG1 |= (1 << (d_it-32)); \
    }
  
  
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH_DISABLE_ALL_IT
     *      Disable all interrupts.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *
     * RETURN VALUE: None
     *
     ***************************************************************************/
  
    #define F_INTH_DISABLE_ALL_IT { \
      * (volatile SYS_UWORD16 *) C_INTH_MASK_REG1  = 0xffff; \
      * (volatile SYS_UWORD16 *) C_INTH_MASK_REG2  = 0xffff; \
      * (volatile SYS_UWORD16 *) C_INTH2_MASK_REG1 = 0x001f; \
    }
  
  
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH_RESET_ALL_IT
     *      Reset all interrupts.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *
     * RETURN VALUE: None
     *
     ***************************************************************************/
  
    #define F_INTH_RESET_ALL_IT { \
      * (volatile SYS_UWORD16 *) C_INTH_IT_REG1  &= 0x0000; \
      * (volatile SYS_UWORD16 *) C_INTH_IT_REG2  &= 0x0000; \
      * (volatile SYS_UWORD16 *) C_INTH2_IT_REG1 &= 0x0000; \
    }
  
  
       /****************************************************************************
     *
     *  MACRO NAME: F_INTH_RESET_ONE_IT
     *      Reset the interrupt specified in argument.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *  d_it           Interrupt index
     *
     * RETURN VALUE: None
     *
     ***************************************************************************/
  
    #define F_INTH_RESET_ONE_IT(d_it) { \
      if (d_it < 16) \
        * (volatile SYS_UWORD16 *) C_INTH_IT_REG1 &= ~(1 << d_it); \
      else if (d_it < C_INTH_NUM_INT) \
        * (volatile SYS_UWORD16 *) C_INTH_IT_REG2 &= ~(1 << (d_it-16)); \
      else if (d_it < (C_INTH_NUM_INT + C_INTH_2ND_NUM_INT)) \
        * (volatile SYS_UWORD16 *) C_INTH2_IT_REG1 &= ~(1 << (d_it-32)); \
    }
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH_VALID_NEXT
     *      Valid next interrupt on the main interrupt handler.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *  d_fiq_nirq     Source of the interrupt IRQ or FIQ
     *
     * RETURN VALUE: None
     *
     ***************************************************************************/
  
    #define F_INTH_VALID_NEXT(d_fiq_nirq)   * (volatile SYS_UWORD16 *) C_INTH_CTRL_REG |= (1 << d_fiq_nirq)
  
  
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH2_VALID_NEXT
     *      Valid next interrupt on the 2nd level interrupt handler.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *  d_fiq_nirq     Source of the interrupt IRQ or FIQ.
     *
     * RETURN VALUE: None
     *
     ***************************************************************************/
  
    #define F_INTH2_VALID_NEXT(d_fiq_nirq)  * (volatile SYS_UWORD16 *) C_INTH2_CTRL_REG |= (1 << d_fiq_nirq)
  
  
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH_GET_IRQ
     *      Return pending IRQ interrupt index on the main interrupt handler.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *
     * RETURN VALUE: IRQ interrupt index
     *
     ***************************************************************************/
  
    #define F_INTH_GET_IRQ  ((* (SYS_UWORD16 *) C_INTH_B_IRQ_REG) & C_INTH_SRC_NUM)
  
  
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH_GET_FIQ
     *      Return pending FIQ interrupt index on the main interrupt handler.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *
     * RETURN VALUE: FIQ interrupt index
     *
     ***************************************************************************/
  
    #define F_INTH_GET_FIQ  ((* (SYS_UWORD16 *) C_INTH_B_FIQ_REG) & C_INTH_SRC_NUM)
  
  
  
    /****************************************************************************
     *
     *  MACRO NAME: F_INTH2_GET_IRQ
     *      Return pending IRQ interrupt index on the 2nd level interrupt handler.
     *
     *
     *  ARGUMENT LIST:
     *
     *  Argument       Description
     *  ------------   ----------------------------------------------------------
     *
     * RETURN VALUE: FIQ interrupt index
     *
     ***************************************************************************/
  
    #define F_INTH2_GET_IRQ  ((* (SYS_UWORD16 *) C_INTH2_B_IRQ_REG) & C_INTH2_SRC_NUM)
  
  
  
    /****************************************************************************
     *                            STRUCTURE DEFINITION
     ***************************************************************************/
    
    typedef struct {
      SYS_UWORD8    d_fiq_nirq;
      SYS_UWORD8    d_edge_nlevel;
      SYS_UWORD8    d_priority;
      SYS_FUNC      d_it_handler;
    } T_INTH_CONFIG;
  
  

    /****************************************************************************
     *                         GLOBAL VARIABLES REFERENCE
     ***************************************************************************/
  
    extern SYS_FUNC a_inth_it_handlers[C_INTH_NUM_INT][2];
    extern SYS_FUNC a_inth2_irq_handlers[C_INTH_2ND_NUM_INT];
  
  
    /****************************************************************************
     *                            PROTOTYPE DEFINITION
     ***************************************************************************/
  
    /*
     *  16-BIS functions
     */
    extern void           f_inth_setup(T_INTH_CONFIG *p_inth_config);
    extern SYS_UWORD16    f_inth_get_version(void);
  
    /*
     *  32-BIS functions
     */
    extern void           f_inth_dummy(void);
    extern void           f_inth_irq_handler(void);
    extern void           f_inth_fiq_handler(void);
    extern void           f_inth_2nd_level_handler(void);

  #endif /* __SYS_INTH_H__ */

#endif /* (CHIPSET == 12) */