view src/aci2/atb/ATBCommon.h @ 516:1ed9de6c90bd

src/g23m-gsm/sms/sms_for.c: bogus malloc removed The new error handling code that was not present in TCS211 blob version contains a malloc call that is bogus for 3 reasons: 1) The memory allocation in question is not needed in the first place; 2) libc malloc is used instead of one of the firmware's proper ways; 3) The memory allocation is made inside a function and then never freed, i.e., a memory leak. This bug was caught in gcc-built FreeCalypso fw projects (Citrine and Selenite) because our gcc environment does not allow any use of libc malloc (any reference to malloc produces a link failure), but this code from TCS3.2 is wrong even for Magnetite: if this code path is executed repeatedly over a long time, the many small allocations made by this malloc call without a subsequent free will eventually exhaust the malloc heap provided by the TMS470 environment, malloc will start returning NULL, and the bogus code will treat it as an error. Because the memory allocation in question is not needed at all, the fix entails simply removing it.
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 22 Jul 2018 06:04:49 +0000
parents 93999a60b835
children
line wrap: on
line source

#ifndef ATB_COMMON_H
#define ATB_COMMON_H

/**********************************************
 * STANDARD DEFINITIONS
 *
 **********************************************/
#ifndef USHORT
#define EXTERN extern
#define GLOBAL
#define LOCAL static
#define ULONG unsigned long
#define LONG long
#define USHORT unsigned short
#define SHORT short
#define UBYTE unsigned char
#define BYTE unsigned char
#define BOOL unsigned char
#endif
#ifndef TRUE
#define TRUE		1
#define FALSE		0
#endif

/* UNICODE CHARACTERS */

#define UNICODE_EOLN				0x0000
#define UNICODE_STARTHIGHLIGHT		0x0100 
#define UNICODE_ENDHIGHLIGHT		0x0200
#define UNICODE_LINEFEED			0x0A00
#define UNICODE_CR					0x0D00

#define UNICODE_SPACE				0x2000
#define UNICODE_HASH				0x2300
#define UNICODE_STAR				0x2A00
#define UNICODE_PLUS				0x2B00
#define UNICODE_FULLSTOP			0x2E00
#define UNICODE_EXCLAMATION			0x2100
#define UNICODE_QUESTION			0x3F00

#define UNICODE_ASCII				0xFF00
#define UNICODE_NONASCII			0x00FF
#define UNICODE_EXTENDEDASCII		0x8000

#define WHOLESTRING					0xFFFF	// parameter for length in uc... functions, copies until null is found
#define UNICODE_WIDEST_CHAR			0xFFFF	/* Used to return width of widest character in font */


/**********************************************
 * T_ATB_TEXT
 *
 * Standard text data structure
 *********************************************/

typedef struct
{
	UBYTE	dcs;
	USHORT	len;
	UBYTE	*data;
}
T_ATB_TEXT;


/**********************************************
 * T_ATB_DCS
 *
 * Data coding schemes for text
 *********************************************/

typedef enum
{
	ATB_DCS_ASCII,
	ATB_DCS_UNICODE
}
T_ATB_DCS;


/**********************************************
 * T_ATB_WIN_SIZE
 *
 * Size of editor window
 *********************************************/
 
typedef struct
{
	SHORT px;
	SHORT py;
	SHORT sx;
	SHORT sy;
}
T_ATB_WIN_SIZE;


/**********************************************
 * FUNCTION PROTOTYPES
 *
 *********************************************/

/* ATB memory allocation */

UBYTE* 	ATB_mem_Alloc(USHORT size);
void	ATB_mem_Free(UBYTE* address, USHORT size);

/* Character and string handling */

/*SPR2175, new function for conversion*/
int 	ATB_convert_String(			char * ipString,	UBYTE ipDataType,	int ipLength,
										char * opString, 	UBYTE opDataType,	int opLength, UBYTE addNull);

char 	ATB_char_GSM(char ascii_character);
char	ATB_char_Ascii(USHORT character);
USHORT	ATB_char_Unicode(char character);
BOOL	ATB_char_IsAscii(USHORT character);
BOOL	ATB_char_IsAlphabetic(USHORT character);
BOOL	ATB_char_IsNumeric(USHORT character);
BOOL	ATB_char_IsVisible(USHORT character);
UBYTE	ATB_string_Size(T_ATB_TEXT *text);
void	ATB_string_SetChar(T_ATB_TEXT *text, USHORT textIndex, USHORT character);
USHORT	ATB_string_GetChar(T_ATB_TEXT *text, USHORT textIndex);
BOOL	ATB_string_MoveLeft(T_ATB_TEXT *text, USHORT textIndex, USHORT offset);
BOOL	ATB_string_MoveRight(T_ATB_TEXT *text, USHORT textIndex, USHORT offset, USHORT size);
USHORT ATB_string_Length(T_ATB_TEXT* text);
USHORT	ATB_string_UCLength(USHORT* text);
void 	ATB_string_Copy(T_ATB_TEXT* dest, T_ATB_TEXT* src);
void	ATB_string_Concat(T_ATB_TEXT* dest, T_ATB_TEXT* srcen);
SHORT	ATB_string_FindChar(T_ATB_TEXT* text, USHORT character);
void	ATB_string_ToUnicode(T_ATB_TEXT *dest, T_ATB_TEXT *src);
void	ATB_string_ToAscii(T_ATB_TEXT *dest, T_ATB_TEXT *src);
USHORT	ATB_string_IndexMove(T_ATB_TEXT *text, USHORT textIndex, SHORT offset);
#endif