FreeCalypso > hg > freecalypso-sw
view rvinterf/lowlevel/clientcmd.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 | a5c8f48003cd |
children | 5f919af515f1 |
line wrap: on
line source
/* * This rvinterf module implements the handling of client commands. */ #include <sys/types.h> #include <stdio.h> #include <string.h> #include <strings.h> #include <stdlib.h> #include <unistd.h> #include "../include/pktmux.h" #include "../include/limits.h" #include "../include/localsock.h" #include "client.h" void process_msg_from_client(cli) struct client *cli; { int c; switch (cli->rx_buf[0]) { case CLI2RVI_WANT_RVTRACE: if (cli->rx_msglen != 9) { send_local_msg_to_client(cli, "-Bad command length"); return; } c = cli->int_rvt_count; if (c >= MAX_RVT_INTEREST) { send_local_msg_to_client(cli, "-Error: too many RVT interests"); return; } cli->int_rvt_mask[c] = cli->rx_buf[1] << 24 | cli->rx_buf[2] << 16 | cli->rx_buf[3] << 8 | cli->rx_buf[4]; cli->int_rvt_match[c] = cli->rx_buf[5] << 24 | cli->rx_buf[6] << 16 | cli->rx_buf[7] << 8 | cli->rx_buf[8]; cli->int_rvt_count++; send_local_msg_to_client(cli, "+OK"); return; case CLI2RVI_WANT_MUXPROTO: if (cli->rx_msglen != 2) { send_local_msg_to_client(cli, "-Bad command length"); return; } if (cli->rx_buf[1] < 0x12 || cli->rx_buf[1] > 0x1B) { send_local_msg_to_client(cli, "-Unsupported protocol MUX value"); return; } cli->int_proto[cli->rx_buf[1] - 0x12] = 1; send_local_msg_to_client(cli, "+OK"); return; case CLI2RVI_DROP_MUXPROTO: if (cli->rx_msglen != 2) { send_local_msg_to_client(cli, "-Bad command length"); return; } if (cli->rx_buf[1] < 0x12 || cli->rx_buf[1] > 0x1B) { send_local_msg_to_client(cli, "-Unsupported protocol MUX value"); return; } cli->int_proto[cli->rx_buf[1] - 0x12] = 0; send_local_msg_to_client(cli, "+OK"); return; case CLI2RVI_RESET_PACKET_RX: cli->int_rvt_count = 0; bzero(cli->int_proto, sizeof(cli->int_proto)); send_local_msg_to_client(cli, "+OK"); return; case CLI2RVI_PKT_TO_TARGET: c = cli->rx_msglen - 1; if (c < 1 || c > MAX_PKT_TO_TARGET) { send_local_msg_to_client(cli, "-Invalid Tx packet length"); return; } send_pkt_to_target(cli->rx_buf + 1, c); log_sent_packet(cli->rx_buf + 1, c); return; case CLI2RVI_RAWBYTES_TO_TARGET: /* To be implemented */ default: send_local_msg_to_client(cli, "-Unimplemented command"); } }