view src/cs/drivers/drv_app/r2d/uwire.h @ 303:f76436d19a7a default tip

!GPRS config: fix long-standing AT+COPS chance hanging bug There has been a long-standing bug in FreeCalypso going back years: sometimes in the AT command bring-up sequence of an ACI-only MS, the AT+COPS command would produce only a power scan followed by cessation of protocol stack activity (only L1 ADC traces), instead of the expected network search sequence. This behaviour was seen in different FC firmware versions going back to Citrine, and seemed to follow some law of chance, not reliably repeatable. This bug has been tracked down and found to be specific to !GPRS configuration, stemming from our TCS2/TCS3 hybrid and reconstruction of !GPRS support that was bitrotten in TCS3.2/LoCosto version. ACI module psa_mms.c, needed only for !GPRS, was missing in the TCS3 version and had to be pulled from TCS2 - but as it turns out, there is a new field in the MMR_REG_REQ primitive that needs to be set correctly, and that psa_mms.c module is the place where this initialization needed to be added.
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 08 Jun 2023 08:23:37 +0000
parents 4e78acac3d88
children
line wrap: on
line source

/**
                                                                          
	@file:	uwire.h	
	
	@author Davide Carpegna                              
                                                                          
    @version	1.0	

    Purpose:	Driver for the uwire HD module       
	
*/

/*
																			
 	Date       	Modification												
  ------------------------------------									
    09/22/2000	Create		
    10/18/2001  Updated for R2D by Christophe Favergeon
																											    
																			
 (C) Copyright 2000 by Texas Instruments Incorporated, All Rights Reserved
*/

#ifndef _UWIRE_H_
#define _UWIRE_H_

#define MEM_UWIRE       0xFFFE4000
#define	TDR             (MEM_UWIRE)
#define	RDR             (MEM_UWIRE)
#define	CSR             (MEM_UWIRE+0x02)
#define	SR1             (MEM_UWIRE+0x04)
#define	SR2             (MEM_UWIRE+0x06)
#define	SR3             (MEM_UWIRE+0x08)

#define INDEX_CS1       (1 << 10)
#define NB_BITS_WR_8    (1 << 8 )
#define INDEX_CS0       0
#define NB_BITS_WR_9    (9 << 5)
#define CS_CMD          (1 << 12)
#define START           (1 << 13)
#define CS1_EDGE_RD     (1 << 6)
#define CS1_FRQ_FINT_4  (1 << 9)
#define CS0_FRQ_FINT_2  0
#define CS0_FRQ_FINT_4  (1 << 3)
#define SR3_CLK_EN      1

#define CSRB            ( 1<<14 )

#define IO_SEL0         0xFFFEF008
#define IO_SEL          0xFFFEF00A

#define GPIO_INOUT      0xFFFE4804
#define GPIO_OUT        0xFFFE4802 
#define CNTL_RST        0xFFFFFD04

#ifdef _WINDOWS
   #ifdef __cplusplus
      extern "C"
      {
   #endif
#endif

// prototypes of uwire functions for lcd
BOOLEAN lcd_polling(void);
void lcd_transmit_cmd(UINT8 cmd);
void uwire_init_lcd(void);

// Defined only for board
void lcd_transmit_data(UINT8 data);

// Defined only for PC
void lcd_refresh(void);
void lcd_set_pos(unsigned char x,unsigned char y);
void* lcd_get_dc(void);

#ifdef _WINDOWS
   #ifdef __cplusplus
      }
   #endif
#endif

#endif /*_UWIRE_H_*/