1*042d53a7SEvalZero /*
2*042d53a7SEvalZero * Licensed to the Apache Software Foundation (ASF) under one
3*042d53a7SEvalZero * or more contributor license agreements. See the NOTICE file
4*042d53a7SEvalZero * distributed with this work for additional information
5*042d53a7SEvalZero * regarding copyright ownership. The ASF licenses this file
6*042d53a7SEvalZero * to you under the Apache License, Version 2.0 (the
7*042d53a7SEvalZero * "License"); you may not use this file except in compliance
8*042d53a7SEvalZero * with the License. You may obtain a copy of the License at
9*042d53a7SEvalZero *
10*042d53a7SEvalZero * http://www.apache.org/licenses/LICENSE-2.0
11*042d53a7SEvalZero *
12*042d53a7SEvalZero * Unless required by applicable law or agreed to in writing,
13*042d53a7SEvalZero * software distributed under the License is distributed on an
14*042d53a7SEvalZero * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15*042d53a7SEvalZero * KIND, either express or implied. See the License for the
16*042d53a7SEvalZero * specific language governing permissions and limitations
17*042d53a7SEvalZero * under the License.
18*042d53a7SEvalZero */
19*042d53a7SEvalZero
20*042d53a7SEvalZero #include <string.h>
21*042d53a7SEvalZero #include <errno.h>
22*042d53a7SEvalZero #include "nimble/ble.h"
23*042d53a7SEvalZero #include "nimble/nimble_opt.h"
24*042d53a7SEvalZero #include "host/ble_sm.h"
25*042d53a7SEvalZero #include "ble_hs_priv.h"
26*042d53a7SEvalZero
27*042d53a7SEvalZero void *
ble_sm_cmd_get(uint8_t opcode,size_t len,struct os_mbuf ** txom)28*042d53a7SEvalZero ble_sm_cmd_get(uint8_t opcode, size_t len, struct os_mbuf **txom)
29*042d53a7SEvalZero {
30*042d53a7SEvalZero struct ble_sm_hdr *hdr;
31*042d53a7SEvalZero
32*042d53a7SEvalZero *txom = ble_hs_mbuf_l2cap_pkt();
33*042d53a7SEvalZero if (*txom == NULL) {
34*042d53a7SEvalZero return NULL;
35*042d53a7SEvalZero }
36*042d53a7SEvalZero
37*042d53a7SEvalZero if (os_mbuf_extend(*txom, sizeof(*hdr) + len) == NULL) {
38*042d53a7SEvalZero os_mbuf_free_chain(*txom);
39*042d53a7SEvalZero return NULL;
40*042d53a7SEvalZero }
41*042d53a7SEvalZero
42*042d53a7SEvalZero hdr = (struct ble_sm_hdr *)(*txom)->om_data;
43*042d53a7SEvalZero
44*042d53a7SEvalZero hdr->opcode = opcode;
45*042d53a7SEvalZero
46*042d53a7SEvalZero return hdr->data;
47*042d53a7SEvalZero }
48*042d53a7SEvalZero
49*042d53a7SEvalZero /* this function consumes tx os_mbuf */
50*042d53a7SEvalZero int
ble_sm_tx(uint16_t conn_handle,struct os_mbuf * txom)51*042d53a7SEvalZero ble_sm_tx(uint16_t conn_handle, struct os_mbuf *txom)
52*042d53a7SEvalZero {
53*042d53a7SEvalZero struct ble_l2cap_chan *chan;
54*042d53a7SEvalZero struct ble_hs_conn *conn;
55*042d53a7SEvalZero
56*042d53a7SEvalZero BLE_HS_DBG_ASSERT(ble_hs_locked_by_cur_task());
57*042d53a7SEvalZero
58*042d53a7SEvalZero STATS_INC(ble_l2cap_stats, sm_tx);
59*042d53a7SEvalZero
60*042d53a7SEvalZero ble_hs_misc_conn_chan_find_reqd(conn_handle, BLE_L2CAP_CID_SM,
61*042d53a7SEvalZero &conn, &chan);
62*042d53a7SEvalZero return ble_l2cap_tx(conn, chan, txom);
63*042d53a7SEvalZero }
64*042d53a7SEvalZero
65*042d53a7SEvalZero #if NIMBLE_BLE_SM
66*042d53a7SEvalZero void
ble_sm_pair_cmd_log(struct ble_sm_pair_cmd * cmd)67*042d53a7SEvalZero ble_sm_pair_cmd_log(struct ble_sm_pair_cmd *cmd)
68*042d53a7SEvalZero {
69*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "io_cap=%d oob_data_flag=%d authreq=0x%02x "
70*042d53a7SEvalZero "mac_enc_key_size=%d init_key_dist=%d "
71*042d53a7SEvalZero "resp_key_dist=%d",
72*042d53a7SEvalZero cmd->io_cap, cmd->oob_data_flag, cmd->authreq,
73*042d53a7SEvalZero cmd->max_enc_key_size, cmd->init_key_dist,
74*042d53a7SEvalZero cmd->resp_key_dist);
75*042d53a7SEvalZero }
76*042d53a7SEvalZero
77*042d53a7SEvalZero void
ble_sm_pair_confirm_log(struct ble_sm_pair_confirm * cmd)78*042d53a7SEvalZero ble_sm_pair_confirm_log(struct ble_sm_pair_confirm *cmd)
79*042d53a7SEvalZero {
80*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "value=");
81*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->value, sizeof cmd->value);
82*042d53a7SEvalZero }
83*042d53a7SEvalZero
84*042d53a7SEvalZero void
ble_sm_pair_random_log(struct ble_sm_pair_random * cmd)85*042d53a7SEvalZero ble_sm_pair_random_log(struct ble_sm_pair_random *cmd)
86*042d53a7SEvalZero {
87*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "value=");
88*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->value, sizeof cmd->value);
89*042d53a7SEvalZero }
90*042d53a7SEvalZero
91*042d53a7SEvalZero void
ble_sm_pair_fail_log(struct ble_sm_pair_fail * cmd)92*042d53a7SEvalZero ble_sm_pair_fail_log(struct ble_sm_pair_fail *cmd)
93*042d53a7SEvalZero {
94*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "reason=%d", cmd->reason);
95*042d53a7SEvalZero }
96*042d53a7SEvalZero
97*042d53a7SEvalZero void
ble_sm_enc_info_log(struct ble_sm_enc_info * cmd)98*042d53a7SEvalZero ble_sm_enc_info_log(struct ble_sm_enc_info *cmd)
99*042d53a7SEvalZero {
100*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "ltk=");
101*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->ltk, sizeof cmd->ltk);
102*042d53a7SEvalZero }
103*042d53a7SEvalZero
104*042d53a7SEvalZero void
ble_sm_master_id_log(struct ble_sm_master_id * cmd)105*042d53a7SEvalZero ble_sm_master_id_log(struct ble_sm_master_id *cmd)
106*042d53a7SEvalZero {
107*042d53a7SEvalZero /* These get logged separately to accommodate a bug in the va_args
108*042d53a7SEvalZero * implementation related to 64-bit integers.
109*042d53a7SEvalZero */
110*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "ediv=0x%04x ", cmd->ediv);
111*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "rand=0x%016llx", cmd->rand_val);
112*042d53a7SEvalZero }
113*042d53a7SEvalZero
114*042d53a7SEvalZero void
ble_sm_id_info_log(struct ble_sm_id_info * cmd)115*042d53a7SEvalZero ble_sm_id_info_log(struct ble_sm_id_info *cmd)
116*042d53a7SEvalZero {
117*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "irk=");
118*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->irk, sizeof cmd->irk);
119*042d53a7SEvalZero }
120*042d53a7SEvalZero
121*042d53a7SEvalZero void
ble_sm_id_addr_info_log(struct ble_sm_id_addr_info * cmd)122*042d53a7SEvalZero ble_sm_id_addr_info_log(struct ble_sm_id_addr_info *cmd)
123*042d53a7SEvalZero {
124*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "addr_type=%d addr=", cmd->addr_type);
125*042d53a7SEvalZero BLE_HS_LOG_ADDR(DEBUG, cmd->bd_addr);
126*042d53a7SEvalZero }
127*042d53a7SEvalZero
128*042d53a7SEvalZero void
ble_sm_sign_info_log(struct ble_sm_sign_info * cmd)129*042d53a7SEvalZero ble_sm_sign_info_log(struct ble_sm_sign_info *cmd)
130*042d53a7SEvalZero {
131*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "sig_key=");
132*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->sig_key, sizeof cmd->sig_key);
133*042d53a7SEvalZero }
134*042d53a7SEvalZero
135*042d53a7SEvalZero void
ble_sm_sec_req_log(struct ble_sm_sec_req * cmd)136*042d53a7SEvalZero ble_sm_sec_req_log(struct ble_sm_sec_req *cmd)
137*042d53a7SEvalZero {
138*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "authreq=0x%02x", cmd->authreq);
139*042d53a7SEvalZero }
140*042d53a7SEvalZero
141*042d53a7SEvalZero void
ble_sm_public_key_log(struct ble_sm_public_key * cmd)142*042d53a7SEvalZero ble_sm_public_key_log(struct ble_sm_public_key *cmd)
143*042d53a7SEvalZero {
144*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "x=");
145*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->x, sizeof cmd->x);
146*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "y=");
147*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->y, sizeof cmd->y);
148*042d53a7SEvalZero }
149*042d53a7SEvalZero
150*042d53a7SEvalZero void
ble_sm_dhkey_check_log(struct ble_sm_dhkey_check * cmd)151*042d53a7SEvalZero ble_sm_dhkey_check_log(struct ble_sm_dhkey_check *cmd)
152*042d53a7SEvalZero {
153*042d53a7SEvalZero BLE_HS_LOG(DEBUG, "value=");
154*042d53a7SEvalZero ble_hs_log_flat_buf(cmd->value, sizeof cmd->value);
155*042d53a7SEvalZero }
156*042d53a7SEvalZero
157*042d53a7SEvalZero #endif
158