diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2005-01-13 22:48:24 +0000 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2005-01-13 22:48:24 +0000 |
commit | 1b71ff969ad17bd4e1265b6cc1d06ca38afc6c27 (patch) | |
tree | 2700f26ca8ba67dc88d9b510f26cd6dc85079ccd /tools | |
parent | 818f37527b66b1bd8c177759a8c7710882030093 (diff) |
Use library function for link supervision timeout
Diffstat (limited to 'tools')
-rw-r--r-- | tools/hcitool.c | 39 |
1 files changed, 8 insertions, 31 deletions
diff --git a/tools/hcitool.c b/tools/hcitool.c index ffa98536..8aef142b 100644 --- a/tools/hcitool.c +++ b/tools/hcitool.c @@ -1211,11 +1211,8 @@ static char *lst_help = static void cmd_lst(int dev_id, int argc, char **argv) { struct hci_conn_info_req *cr; - struct hci_request rq; - read_link_supervision_timeout_rp rp; - write_link_supervision_timeout_cp cp; bdaddr_t bdaddr; - uint16_t handle; + uint16_t timeout; int opt, dd; for_each_opt(opt, lst_options, NULL) { @@ -1260,43 +1257,23 @@ static void cmd_lst(int dev_id, int argc, char **argv) exit(1); } - handle = htobs(cr->conn_info->handle); - if (argc == 1) { - memset(&rq, 0, sizeof(rq)); - rq.ogf = OGF_HOST_CTL; - rq.ocf = OCF_READ_LINK_SUPERVISION_TIMEOUT; - rq.cparam = &handle; - rq.clen = 2; - rq.rparam = &rp; - rq.rlen = READ_LINK_SUPERVISION_TIMEOUT_RP_SIZE; - - if (hci_send_req(dd, &rq, 100) < 0) { + if (hci_read_link_supervision_timeout(dd, htobs(cr->conn_info->handle), &timeout, 1000) < 0) { perror("HCI read_link_supervision_timeout request failed"); exit(1); } - if (rp.status) { - fprintf(stderr, "HCI read_link_supervision_timeout failed (0x%2.2X)\n", - rp.status); - exit(1); - } - if (rp.link_sup_to) + timeout = btohs(timeout); + + if (timeout) printf("Link supervision timeout: %u slots (%.2f msec)\n", - rp.link_sup_to, (float)rp.link_sup_to * 0.625); + timeout, (float) timeout * 0.625); else printf("Link supervision timeout never expires\n"); } else { - cp.handle = htobs(cr->conn_info->handle); - cp.link_sup_to = strtol(argv[1], NULL, 10); - - memset(&rq, 0, sizeof(rq)); - rq.ogf = OGF_HOST_CTL; - rq.ocf = OCF_WRITE_LINK_SUPERVISION_TIMEOUT; - rq.cparam = &cp; - rq.clen = WRITE_LINK_SUPERVISION_TIMEOUT_CP_SIZE; + timeout = btohs(strtol(argv[1], NULL, 10)); - if (hci_send_req(dd, &rq, 100) < 0) { + if (hci_write_link_supervision_timeout(dd, htobs(cr->conn_info->handle), timeout, 1000) < 0) { perror("HCI write_link_supervision_timeout request failed"); exit(1); } |