diff gsm-fw/L1/dsp/leadapi.h @ 558:565bf963c3a2

gsm-fw/L1/dsp/leadapi.[ch]: import from Leonardo semi-src
author Michael Spacefalcon <msokolov@ivan.Harhan.ORG>
date Mon, 04 Aug 2014 17:58:49 +0000
parents
children fba5efca2293
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/gsm-fw/L1/dsp/leadapi.h	Mon Aug 04 17:58:49 2014 +0000
@@ -0,0 +1,95 @@
+/*******************************************************************************
+            TEXAS INSTRUMENTS INCORPORATED PROPRIETARY INFORMATION           
+                                                                             
+  Property of Texas Instruments -- For  Unrestricted  Internal  Use  Only 
+   Unauthorized reproduction and/or distribution is strictly prohibited.  This 
+   product  is  protected  under  copyright  law  and  trade  secret law as an 
+   unpublished work.  Created 1987, (C) Copyright 1997 Texas Instruments.  All 
+   rights reserved.                                                            
+                 
+                                                           
+   Filename       	: leadapi.h
+
+   Description    	: Boot the LEAD - header file
+
+   Target               : ARM
+
+   Project        	: 
+
+   Author         	: A0917556
+
+   Version number	: 1.8
+
+   Date and time	: 02/22/01 11:54:48
+
+   Previous delta 	: 01/22/01 10:32:42
+
+   SCCS file      	: /db/gsm_asp/db_ht96/dsp_0/gsw/rel_0/mcu_l1/release_gprs/RELEASE_GPRS/drivers1/common/SCCS/s.leadapi.h
+
+   Sccs Id  (SID)       : '@(#) leadapi.h 1.8 02/22/01 11:54:48 '
+
+
+*****************************************************************************/
+
+#include "chipset.cfg"
+
+#define	NULL          0
+
+#define APIF_ADDR     0xFFD00000L
+#define BASE_API_ARM  APIF_ADDR     /* API RAM for ARM */
+#if (CHIPSET == 4)
+  #define BASE_API_LEAD 0xE800      /* API RAM for Lead */
+#elif (CHIPSET == 7) || (CHIPSET == 8) || (CHIPSET == 10) || (CHIPSET == 11) || (CHIPSET == 12)
+  #define BASE_API_LEAD 0xE000      /* API RAM for Lead */
+#else
+  #define BASE_API_LEAD 0xF800      /* API RAM for Lead */
+#endif
+
+#define DOWNLOAD_EXT_PAGE   (APIF_ADDR + 0x0FF8)   /* Address of the extended DSP page of the */
+#define DOWNLOAD_SIZE       (APIF_ADDR + 0x0FFA)   /* Address of the download size variable */
+#define DOWNLOAD_ADDR       (APIF_ADDR + 0x0FFC)   /* Address of the download address variable */
+#define DOWNLOAD_STATUS     (APIF_ADDR + 0x0FFE)   /* Address of the download status variable */
+
+/* Maximum size of a block which can be copied into the API RAM */
+
+#define MAX_BLOCK_SIZE 0x7F0       
+#define MAX_UINT       65535   
+
+/* Possible values for the download status */
+
+#define LEAD_READY      1
+#define BLOCK_READY     2
+#define PROGRAM_DONE    3
+#define PAGE_SELECTION  4
+
+
+// Constants for timeout
+#define LA_TIMEOUT      10000
+#define LA_SUCCESS      0
+#define LA_ERR_TIMEOUT  1
+
+// Constants for error
+#define LA_BAD_EXT_VALUE  2
+#define LA_BAD_VERSION    3
+#define LA_BAD_TAG        4
+
+// Prototypes
+void LA_InitialLeadBoot16(const unsigned char bootCode[]);
+void LA_InitialLeadBoot(const unsigned char bootCode[]);
+short  LA_LoadPage16(const unsigned char code[], SYS_UWORD16 page, SYS_UWORD16 start);
+short  LA_LoadPage(const unsigned char code[], SYS_UWORD16 page, SYS_UWORD16 start);
+void LA_ResetLead(void);
+void LA_StartLead(SYS_UWORD16 pll);
+
+extern const unsigned char bootCode[];
+
+/*
+ * Global variables
+ */ 
+#ifdef LEADAPI_C
+#define LA_GLOBAL 
+#else
+#define LA_GLOBAL extern
+#endif
+
+LA_GLOBAL volatile unsigned leadInt;