NSMBW-Decomp
A decompilation of New Super Mario Bros. Wii
Loading...
Searching...
No Matches
bta_ag_at.h
1/******************************************************************************
2 *
3 * Copyright (C) 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/*****************************************************************************
28** Constants
29*****************************************************************************/
30
31/* AT command argument capabilities */
32#define BTA_AG_AT_NONE 0x01 /* no argument */
33#define BTA_AG_AT_SET 0x02 /* set value */
34#define BTA_AG_AT_READ 0x04 /* read value */
35#define BTA_AG_AT_TEST 0x08 /* test value range */
36#define BTA_AG_AT_FREE 0x10 /* freeform argument */
37
38/* AT command argument format */
39#define BTA_AG_AT_STR 0 /* string */
40#define BTA_AG_AT_INT 1 /* integer */
41
42/*****************************************************************************
43** Data types
44*****************************************************************************/
45
46/* AT command table element */
47typedef struct
48{
49 const char *p_cmd; /* AT command string */
50 UINT8 arg_type; /* allowable argument type syntax */
51 UINT8 fmt; /* whether arg is int or string */
52 UINT8 min; /* minimum value for int arg */
53 INT16 max; /* maximum value for int arg */
55
56/* callback function executed when command is parsed */
57typedef void (tBTA_AG_AT_CMD_CBACK)(void *p_user, UINT16 cmd, UINT8 arg_type,
58 char *p_arg, INT16 int_arg);
59
60/* callback function executed to send "ERROR" result code */
61typedef void (tBTA_AG_AT_ERR_CBACK)(void *p_user, BOOLEAN unknown, char *p_arg);
62
63/* AT command parsing control block */
64typedef struct
65{
66 tBTA_AG_AT_CMD *p_at_tbl; /* AT command table */
67 tBTA_AG_AT_CMD_CBACK *p_cmd_cback; /* command callback */
68 tBTA_AG_AT_ERR_CBACK *p_err_cback; /* error callback */
69 void *p_user; /* user-defined data */
70 char *p_cmd_buf; /* temp parsing buffer */
71 UINT16 cmd_pos; /* position in temp buffer */
72 UINT16 cmd_max_len; /* length of temp buffer to allocate */
73 UINT8 state; /* parsing state */
75
76/*****************************************************************************
77** Function prototypes
78*****************************************************************************/
79
80/*****************************************************************************
81**
82** Function bta_ag_at_init
83**
84** Description Initialize the AT command parser control block.
85**
86**
87** Returns void
88**
89*****************************************************************************/
90extern void bta_ag_at_init(tBTA_AG_AT_CB *p_cb);
91
92/*****************************************************************************
93**
94** Function bta_ag_at_reinit
95**
96** Description Re-initialize the AT command parser control block. This
97** function resets the AT command parser state and frees
98** any GKI buffer.
99**
100**
101** Returns void
102**
103*****************************************************************************/
104extern void bta_ag_at_reinit(tBTA_AG_AT_CB *p_cb);
105
106/*****************************************************************************
107**
108** Function bta_ag_at_parse
109**
110** Description Parse AT commands. This function will take the input
111** character string and parse it for AT commands according to
112** the AT command table passed in the control block.
113**
114**
115** Returns void
116**
117*****************************************************************************/
118extern void bta_ag_at_parse(tBTA_AG_AT_CB *p_cb, char *p_buf, UINT16 len);
119
120#endif /* BTA_AG_AT_H */
121