FreeCalypso > hg > freecalypso-sw
view target-utils/libtiffs/rdinmem.c @ 884:353daaa6014d
gsm-fw/gpf/conf/gsmcomp.c: increased max partition in the voice-only config
The code we got from TCS211 had the maximum prim pool partition size set to
900 bytes in the voice-only config (no FAX_AND_DATA, no GPRS) and to 1600 bytes
in every other config. As it turns out, this "minimized" config breaks when
the AT command interface is used with %CPI enabled, as the responsible code in
ATI does an ACI_MALLOC of 1012 bytes. TI may have considered this case to be
unsupported usage (perhaps they didn't care about the combination of a
voice-only PS with AT command control), but we do want this use case to work
without crashing. Solution: I made the largest prim pool the same as it is
with FAX_AND_DATA: 3 partitions of 1600 bytes.
author | Space Falcon <falcon@ivan.Harhan.ORG> |
---|---|
date | Sat, 27 Jun 2015 07:31:30 +0000 |
parents | 2900fe603f8a |
children |
line wrap: on
line source
#include <sys/types.h> #include "types.h" #include "struct.h" #include "globals.h" #include "macros.h" mpffs_read_into_ram(pathname, buf, maxlen, lenrtn) char *pathname; u8 *buf; size_t maxlen, *lenrtn; { int stat, cont; u8 *chunk_start; size_t chunk_size, real_len, roomleft; stat = mpffs_find_file(pathname, &chunk_start, &chunk_size, &cont); if (stat < 0) return(stat); if (chunk_size > maxlen) { toobig: printf("Error: %s is bigger than the read buffer\n", pathname); return(-1); } real_len = chunk_size; bcopy(chunk_start, buf, chunk_size); buf += chunk_size; roomleft = maxlen - chunk_size; while (cont) { stat = mpffs_get_segment(cont, &chunk_start, &chunk_size, &cont); if (stat < 0) return(stat); if (chunk_size > roomleft) goto toobig; real_len += chunk_size; bcopy(chunk_start, buf, chunk_size); buf += chunk_size; roomleft -= chunk_size; } if (lenrtn) *lenrtn = real_len; return(0); }