1 /******************************************************************************
2  *
3  *  Copyright 2004-2012 Broadcom Corporation
4  *
5  *  Licensed under the Apache License, Version 2.0 (the "License");
6  *  you may not use this file except in compliance with the License.
7  *  You may obtain a copy of the License at:
8  *
9  *  http://www.apache.org/licenses/LICENSE-2.0
10  *
11  *  Unless required by applicable law or agreed to in writing, software
12  *  distributed under the License is distributed on an "AS IS" BASIS,
13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  *  See the License for the specific language governing permissions and
15  *  limitations under the License.
16  *
17  ******************************************************************************/
18 
19 /******************************************************************************
20  *
21  *  Interface file for BTA AG AT command interpreter.
22  *
23  ******************************************************************************/
24 #ifndef BTA_AG_AT_H
25 #define BTA_AG_AT_H
26 
27 #include <stddef.h>
28 #include <cstddef>
29 #include <cstdint>
30 
31 /*****************************************************************************
32  *  Constants
33  ****************************************************************************/
34 
35 /* AT command argument capabilities */
36 #define BTA_AG_AT_NONE 0x01 /* no argument */
37 #define BTA_AG_AT_SET 0x02  /* set value */
38 #define BTA_AG_AT_READ 0x04 /* read value */
39 #define BTA_AG_AT_TEST 0x08 /* test value range */
40 #define BTA_AG_AT_FREE 0x10 /* freeform argument */
41 
42 /* AT command argument format */
43 #define BTA_AG_AT_STR 0 /* string */
44 #define BTA_AG_AT_INT 1 /* integer */
45 
46 /*****************************************************************************
47  *  Data types
48  ****************************************************************************/
49 
50 /* AT command table element */
51 typedef struct {
52   const char* p_cmd; /* AT command string */
53   size_t command_id; /* passed to the callback on p_cmd match */
54   uint8_t arg_type;  /* allowable argument type syntax */
55   uint8_t fmt;       /* whether arg is int or string */
56   uint8_t min;       /* minimum value for int arg */
57   int16_t max;       /* maximum value for int arg */
58 } tBTA_AG_AT_CMD;
59 
60 /* callback function executed when command is parsed */
61 struct tBTA_AG_SCB;
62 typedef void(tBTA_AG_AT_CMD_CBACK)(tBTA_AG_SCB* p_user, uint16_t command_id,
63                                    uint8_t arg_type, char* p_arg, char* p_end,
64                                    int16_t int_arg);
65 
66 /* callback function executed to send "ERROR" result code */
67 typedef void(tBTA_AG_AT_ERR_CBACK)(tBTA_AG_SCB* p_user, bool unknown,
68                                    const char* p_arg);
69 
70 /* AT command parsing control block */
71 typedef struct {
72   const tBTA_AG_AT_CMD* p_at_tbl;    /* AT command table */
73   tBTA_AG_AT_CMD_CBACK* p_cmd_cback; /* command callback */
74   tBTA_AG_AT_ERR_CBACK* p_err_cback; /* error callback */
75   void* p_user;                      /* user-defined data */
76   char* p_cmd_buf;                   /* temp parsing buffer */
77   uint16_t cmd_pos;                  /* position in temp buffer */
78   uint16_t cmd_max_len;              /* length of temp buffer to allocate */
79   uint8_t state;                     /* parsing state */
80 } tBTA_AG_AT_CB;
81 
82 /*****************************************************************************
83  *  Function prototypes
84  ****************************************************************************/
85 
86 /*****************************************************************************
87  *
88  * Function         bta_ag_at_init
89  *
90  * Description      Initialize the AT command parser control block.
91  *
92  *
93  * Returns          void
94  *
95  ****************************************************************************/
96 void bta_ag_at_init(tBTA_AG_AT_CB* p_cb);
97 
98 /*****************************************************************************
99  *
100  * Function         bta_ag_at_reinit
101  *
102  * Description      Re-initialize the AT command parser control block.  This
103  *                  function resets the AT command parser state and frees
104  *                  any GKI buffer.
105  *
106  *
107  * Returns          void
108  *
109  ****************************************************************************/
110 void bta_ag_at_reinit(tBTA_AG_AT_CB* p_cb);
111 
112 /*****************************************************************************
113  *
114  * Function         bta_ag_at_parse
115  *
116  * Description      Parse AT commands.  This function will take the input
117  *                  character string and parse it for AT commands according to
118  *                  the AT command table passed in the control block.
119  *
120  *
121  * Returns          void
122  *
123  ****************************************************************************/
124 void bta_ag_at_parse(tBTA_AG_AT_CB* p_cb, char* p_buf, uint16_t len);
125 
126 #endif /* BTA_AG_AT_H */
127