diff src/g23m-gprs/cci/cci_gea_start.c @ 1:fa8dc04885d8

src/g23m-*: import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 16 Oct 2020 06:25:50 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/g23m-gprs/cci/cci_gea_start.c	Fri Oct 16 06:25:50 2020 +0000
@@ -0,0 +1,118 @@
+/* 
++----------------------------------------------------------------------------- 
+|  Project :  
+|  Modul   :  cci_gea_start.c
++----------------------------------------------------------------------------- 
+|  Copyright 2002 Texas Instruments Berlin, AG 
+|                 All rights reserved. 
+| 
+|                 This file is confidential and a trade secret of Texas 
+|                 Instruments Berlin, AG 
+|                 The receipt of or possession of this file does not convey 
+|                 any rights to reproduce or disclose its contents or to 
+|                 manufacture, use, or sell anything it may describe, in 
+|                 whole, or in part, without the specific written consent of 
+|                 Texas Instruments Berlin, AG. 
++----------------------------------------------------------------------------- 
+|  Purpose :  This module implements local functions for service FBS of
+|             entity CCI.
++----------------------------------------------------------------------------- 
+*/ 
+
+#define CCI_GEA_START_C
+
+#ifndef CCI_THREAD
+  #define ENTITY_LLC
+#else
+  #define ENTITY_CCI
+#endif
+
+
+/*==== INCLUDES =============================================================*/
+
+#include "typedefs.h"   /* to get Condat data types */
+#include "vsi.h"        /* to get a lot of macros */
+#include "macdef.h"
+#include "gprs.h"
+#include "gsm.h"        /* to get a lot of macros */
+#include "cnf_llc.h"    /* to get cnf-definitions */
+#include "mon_llc.h"    /* to get mon-definitions */
+#include "prim.h"       /* to get the definitions of used SAP and directions */
+#include "cci.h"        /* to get the global entity definitions */
+#ifndef CCI_THREAD
+#include "llc.h"        /* to get the global entity definitions */
+#endif
+
+#ifndef _SIMULATION_
+#include "config/chipset.cfg"
+#endif /* ifdef SIMULATION */
+
+
+/*==== CONST ================================================================*/
+
+/*==== LOCAL VARS ===========================================================*/
+
+/*==== PRIVATE FUNCTIONS ====================================================*/
+
+/*==== PUBLIC FUNCTIONS =====================================================*/
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : gea_start
++------------------------------------------------------------------------------
+| Description : The function  .... 
+|
+| Parameters  : void
+|
++------------------------------------------------------------------------------
+*/
+
+
+/* GEA work-around only affects Calypso+ chipset. */
+  #ifndef CCI_FLASH_ROM
+    /* Assembly routine gea_start() should be executed from the Internal RAM */
+    void gea_start(void){
+#if (CHIPSET == 12) || (CHIPSET == 14)
+      /* Enable Timer1 clock */
+      *(volatile USHORT *) 0xfffe3800 |= 0x0020; 
+
+      /* Save into the stack ARM registers r0 to r4 */
+      asm(" push {r0-r4}");
+
+      /* Load in r0 READ_TIMER1 address */
+      asm(" ldr r0, READ_TIMER1_ADDR");
+
+      /* Set bit START in GEA_CNTL register */
+      asm(" ldr r1, GEA_CNTL_ADDR");
+      asm(" mov r4,#4");
+      asm(" ldrh r2, [r1]");
+      asm(" orr r2,r4");
+      asm(" strh r2,[r1]");
+
+      /* Load Timer1 in r3 in order to prevent DMA access on strobe0 during the
+         GEA clock switch. This reading of Timer1 generates around 13 cycles of
+         MCU clock activity on strobe1 and so guaranties that strobe0 will be
+         quiet during that time. */
+      asm(" ldrh r3,[r0]");
+
+      /* Restore ARM registers r0 to r4 from the stack */
+      asm(" pop {r0-r4}");
+
+      /*  Branch to end of the function, to avoid that the 2 following constant 
+          definitions are mistaken with code instructions. */
+      asm(" br    $gea_end_func");
+
+      /* Must be defined inside the function body, else depending on the compiler 
+         version, they are not inserted in the right section */
+    asm("READ_TIMER1_ADDR .long 0xFFFE3804");
+    asm("GEA_CNTL_ADDR  .long 0xffffc000");
+
+      asm("$gea_end_func:");      
+    }
+#else
+    }    
+#endif /*(CHIPSET == 12)*/
+
+  #endif /* CCI_FLASH_ROM */
+