summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohan Hedberg <johan.hedberg@intel.com>2014-01-16 12:02:12 +0200
committerJohan Hedberg <johan.hedberg@intel.com>2014-01-16 12:23:15 +0200
commitd11ac83a18f694524fd393796a4d4668a4b4c6fb (patch)
treeadb9ed7da25061ba2c82367d58c1424d2b067f2f
parent809b0c24623e5e1e8185fe4b10cbd63c5886241e (diff)
emulator/bthost: Further cleanups to the RFCOMM code
-rw-r--r--emulator/bthost.c74
1 files changed, 36 insertions, 38 deletions
diff --git a/emulator/bthost.c b/emulator/bthost.c
index 4defc794d..da00b5a7c 100644
--- a/emulator/bthost.c
+++ b/emulator/bthost.c
@@ -361,7 +361,6 @@ void bthost_destroy(struct bthost *bthost)
if (bthost->rfcomm_conn_data)
free(bthost->rfcomm_conn_data);
-
free(bthost);
}
@@ -1636,47 +1635,48 @@ static void rfcomm_pn_recv(struct bthost *bthost, struct btconn *conn,
struct l2conn *l2conn, uint8_t cr,
const struct rfcomm_pn *pn)
{
- if (cr) {
- uint8_t buf[14];
- struct rfcomm_hdr *hdr = (struct rfcomm_hdr *)buf;
- struct rfcomm_mcc *mcc = (struct rfcomm_mcc *)(buf +
- sizeof(*hdr));
- struct rfcomm_pn *pn_cmd = (struct rfcomm_pn *)
- (buf + sizeof(*hdr) + sizeof(*mcc));
+ uint8_t buf[14];
+ struct rfcomm_hdr *hdr;
+ struct rfcomm_mcc *mcc;
+ struct rfcomm_pn *pn_cmd;
- memset(buf, 0, sizeof(buf));
+ if (!cr) {
+ rfcomm_sabm_send(bthost, conn, l2conn, 1,
+ bthost->rfcomm_conn_data->channel * 2);
+ return;
+ }
- hdr->address = RFCOMM_ADDR(1, 0);
- hdr->control = RFCOMM_CTRL(RFCOMM_UIH, 0);
- hdr->length = RFCOMM_LEN8(sizeof(*mcc) + sizeof(*pn_cmd));
+ hdr = (struct rfcomm_hdr *) buf;
+ mcc = (struct rfcomm_mcc *) (buf + sizeof(*hdr));
+ pn_cmd = (struct rfcomm_pn *) (buf + sizeof(*hdr) + sizeof(*mcc));
- mcc->type = RFCOMM_MCC_TYPE(0, RFCOMM_PN);
- mcc->length = RFCOMM_LEN8(sizeof(*pn_cmd));
+ memset(buf, 0, sizeof(buf));
- pn_cmd->dlci = pn->dlci;
- pn_cmd->priority = pn->priority;
- pn_cmd->ack_timer = pn->ack_timer;
- pn_cmd->max_retrans = pn->max_retrans;
- pn_cmd->mtu = pn->mtu;
- pn_cmd->credits = pn->credits;
+ hdr->address = RFCOMM_ADDR(1, 0);
+ hdr->control = RFCOMM_CTRL(RFCOMM_UIH, 0);
+ hdr->length = RFCOMM_LEN8(sizeof(*mcc) + sizeof(*pn_cmd));
- buf[sizeof(*hdr) + sizeof(*mcc) + sizeof(*pn_cmd)] =
- rfcomm_fcs(buf);
+ mcc->type = RFCOMM_MCC_TYPE(0, RFCOMM_PN);
+ mcc->length = RFCOMM_LEN8(sizeof(*pn_cmd));
- send_acl(bthost, conn->handle, l2conn->dcid, buf, sizeof(buf));
- } else if (bthost->rfcomm_conn_data) {
- rfcomm_sabm_send(bthost, conn, l2conn, 1,
- bthost->rfcomm_conn_data->channel * 2);
- }
+ pn_cmd->dlci = pn->dlci;
+ pn_cmd->priority = pn->priority;
+ pn_cmd->ack_timer = pn->ack_timer;
+ pn_cmd->max_retrans = pn->max_retrans;
+ pn_cmd->mtu = pn->mtu;
+ pn_cmd->credits = pn->credits;
+
+ buf[sizeof(*hdr) + sizeof(*mcc) + sizeof(*pn_cmd)] = rfcomm_fcs(buf);
+
+ send_acl(bthost, conn->handle, l2conn->dcid, buf, sizeof(buf));
}
static void rfcomm_mcc_recv(struct bthost *bthost, struct btconn *conn,
struct l2conn *l2conn, const void *data, uint16_t len)
{
const struct rfcomm_mcc *mcc = data;
- uint8_t type = RFCOMM_GET_MCC_TYPE(mcc->type);
- switch (type) {
+ switch (RFCOMM_GET_MCC_TYPE(mcc->type)) {
case RFCOMM_MSC:
rfcomm_msc_recv(bthost, conn, l2conn,
RFCOMM_TEST_CR(mcc->type) / 2,
@@ -1698,18 +1698,16 @@ static void rfcomm_uih_recv(struct bthost *bthost, struct btconn *conn,
{
const struct rfcomm_cmd *hdr = data;
const void *p;
- uint8_t ea;
- ea = RFCOMM_TEST_EA(hdr->length) ? true : false;
+ if (RFCOMM_GET_DLCI(hdr->address))
+ return;
- if (!RFCOMM_GET_DLCI(hdr->address)) {
- if (ea)
- p = data + sizeof(struct rfcomm_hdr);
- else
- p = data + sizeof(struct rfcomm_hdr) + sizeof(uint8_t);
+ if (RFCOMM_TEST_EA(hdr->length))
+ p = data + sizeof(struct rfcomm_hdr);
+ else
+ p = data + sizeof(struct rfcomm_hdr) + sizeof(uint8_t);
- rfcomm_mcc_recv(bthost, conn, l2conn, p, p - data);
- }
+ rfcomm_mcc_recv(bthost, conn, l2conn, p, p - data);
}
static void process_rfcomm(struct bthost *bthost, struct btconn *conn,