view gsm-fw/L1/include/l1_macro.h @ 952:15b1b396ad23

c139explore: OsmocomBB morons got uwire wrong, TI got it right
author Mychaela Falconia <falcon@ivan.Harhan.ORG>
date Wed, 04 Nov 2015 03:51:00 +0000
parents 30f2e994fcb0
children
line wrap: on
line source

/************* Revision Controle System Header *************
 *                  GSM Layer 1 software
 * L1_MACRO.H
 *
 *        Filename l1_macro.h
 *  Copyright 2003 (C) Texas Instruments
 *
 ************* Revision Controle System Header *************/

#include "l1_confg.h"
#if(L1_DYN_DSP_DWNLD == 1)
  #include "../dyn_dwl_include/l1_dyn_dwl_const.h"
#endif
#include "l1_types.h"

#if (TRACE_TYPE==5) && NUCLEUS_TRACE
//WARNING : this type of trace takes a lot of space in data RAM (~16kB)

  // switch for Nucleus debugging messages.
  #define NU_ALLOC_ERR      0
  #define NU_DEALLOC_ERR    1
  #define NU_RCVE_QUEUE_ERR 2
  #define NU_SEND_QUEUE_ERR 3
  #define NU_OBTA_SEMA_ERR  4
  #define NU_RLSE_SEMA_ERR  5

  // Nucleus debug function.
    #define DEBUGMSG(status,type) \
    if(status) switch(type) \
    { \
      case NU_ALLOC_ERR: \
      printf("NU mem. allocation error %d file %s line %d\n", status,__FILE__,__LINE__); \
      exit(0);            \
      break; \
      \
      case NU_DEALLOC_ERR: \
      printf("NU mem. deallocation error %d file %s line %d\n", status,__FILE__,__LINE__); \
      exit(0);            \
      break; \
      \
      case NU_RCVE_QUEUE_ERR: \
      printf("NU rcve queue error %d file %s line %d\n", status,__FILE__,__LINE__); \
      exit(0);            \
      break; \
      \
      case NU_SEND_QUEUE_ERR: \
      printf("NU send queue error %d file %s line %d\n", status,__FILE__,__LINE__); \
      exit(0);            \
      break; \
      \
      case NU_OBTA_SEMA_ERR: \
      printf("NU obtain semaph. error %d file %s line %d\n", status,__FILE__,__LINE__); \
      exit(0);            \
      break; \
      \
      case NU_RLSE_SEMA_ERR: \
      printf("NU release semaph. error %d file %s line %d\n", status,__FILE__,__LINE__); \
      exit(0);            \
      break; \
      \
      default: \
      printf("Unknown error %d file %s line %d\n", status,__FILE__,__LINE__); \
      exit(0);            \
      break; \
    }
#else
  #define DEBUGMSG(status,type)
#endif

/************************************************************/
/* Macros for FAST INTEGER MODULO implementation.           */
/************************************************************/
#define IncMod(operand, increment, modulo) \
  if( (operand += increment) >= modulo ) operand -= modulo


// Define MACRO for selecting the min. time to next task.
#define Select_min_time(Task_Time, Min_Time) \
  if(Task_Time < Min_Time) Min_Time = Task_Time;

/************************************************************/
/* Macros for MCU/DSP API address conversion    .           */
/************************************************************/

#define API_address_dsp2mcu(dsp_address) \
  (MCU_API_BASE_ADDRESS + ((API)((dsp_address) - DSP_API_BASE_ADDRESS) * 2))

#define API_address_mcu2dsp(mcu_address) \
  (DSP_API_BASE_ADDRESS + ((UWORD32)((mcu_address) - MCU_API_BASE_ADDRESS) / 2))




  /* Added temporirly for RF_KEypad build */

  #if (L1_RF_KBD_FIX == 1)

  #if(OP_L1_STANDALONE == 1)

#if 0
  typedef struct
  {
  //   T_RVF_MB_ID    prim_id;
  //   T_RVF_ADDR_ID  addr_id;
  //   BOOL           swe_is_initialized;
  //   T_RVM_RETURN   (*error_ft)(T_RVM_NAME        swe_name,
  //                              T_RVM_RETURN      error_cause,
  //                              T_RVM_ERROR_TYPE  error_type,
  //                              T_RVM_STRING      error_msg);
  #if ((CHIPSET == 12) || (CHIPSET == 15))
  //  T_KPD_RECEIVED_KEY_INFO received_key_info[KPD_MAX_DETECTABLE];
    //UINT8                   nb_active_keys;
    UWORD16                  repeat_time;
    UWORD16                  long_time;
  #endif
  } T_KPD_ENV_CTRL_BLK_L1;

#endif

//  typedef  unsigned char KPD_CORRECTION_RATIO; //UWORD8 //omaps00090550
  void kpd_timer_modify(UWORD8 ratio,UWORD32 frameNumber); //omaps00090550
  #define KBR_DEBOUNCING_TIME           (MEM_KEYBOARD + 0x02) /* KBR debouncing time reg */
  #define KPD_DEBOUNCING_TIME   (0x3F)
  #define KBR_LONG_KEY_TIME             (MEM_KEYBOARD + 0x04) /* KBR long key time reg */
  #define KBR_TIME_OUT                  (MEM_KEYBOARD + 0x06) /* KBR Time out reg */
  #define KBR_CTRL_REG                  (MEM_KEYBOARD + 0x00) /* KBR control reg */
  #define KBR_STATE_MACHINE_STATUS      (MEM_KEYBOARD + 0x0E) /* KBR state machine status reg */
  #define KPD_CLK_DIV32 4
  #define KPD_CLOCK_DIVIDER     KPD_CLK_DIV32

    #define SetGroupBits16(registre,position,number,value) {\
                                                        UINT16 tmp=registre;\
                                                        volatile UINT16 tmpvalue;\
                                                        tmpvalue = (value<<(16-(number)));\
                                                        tmpvalue = (tmpvalue>>(16-(number)));\
                                                        tmp&=~((0xFFFF>>(16-(number)))<<(position));\
                                                        tmp|=((tmpvalue&(0xFFFF>>(16-(number))))<<(position));\
                                                        registre=tmp;\
                                                        }
  #endif/* #if(OP_L1_STANDALONE == 1) */

  #endif /* #if (L1_RF_KBD_FIX == 1) */
  /* Added temporirly for RF_KEypad build */