Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/btconfig add details of later (to v4.2) specificati...
details: https://anonhg.NetBSD.org/src/rev/632e185d6f43
branches: trunk
changeset: 812042:632e185d6f43
user: plunky <plunky%NetBSD.org@localhost>
date: Sat Nov 28 09:25:45 2015 +0000
description:
add details of later (to v4.2) specification versions and
extended feature flags,
diffstat:
usr.sbin/btconfig/btconfig.c | 43 ++++++++++++++++++++++++++++++++++++-------
1 files changed, 36 insertions(+), 7 deletions(-)
diffs (106 lines):
diff -r 2813144e0f22 -r 632e185d6f43 usr.sbin/btconfig/btconfig.c
--- a/usr.sbin/btconfig/btconfig.c Sat Nov 28 09:04:34 2015 +0000
+++ b/usr.sbin/btconfig/btconfig.c Sat Nov 28 09:25:45 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: btconfig.c,v 1.26 2011/10/17 16:37:50 mbalmer Exp $ */
+/* $NetBSD: btconfig.c,v 1.27 2015/11/28 09:25:45 plunky Exp $ */
/*-
* Copyright (c) 2006 Itronix Inc.
@@ -33,7 +33,7 @@
#include <sys/cdefs.h>
__COPYRIGHT("@(#) Copyright (c) 2006 Itronix, Inc. All rights reserved.");
-__RCSID("$NetBSD: btconfig.c,v 1.26 2011/10/17 16:37:50 mbalmer Exp $");
+__RCSID("$NetBSD: btconfig.c,v 1.27 2015/11/28 09:25:45 plunky Exp $");
#include <sys/ioctl.h>
#include <sys/param.h>
@@ -64,6 +64,7 @@
static void tag(const char *);
static void print_features0(uint8_t *);
static void print_features1(uint8_t *);
+static void print_features2(uint8_t *);
static void print_result(int, struct bt_devinquiry *);
static void do_inquiry(void);
@@ -659,7 +660,10 @@
case HCI_SPEC_V20: printf("2.0 + EDR\n"); break;
case HCI_SPEC_V21: printf("2.1 + EDR\n"); break;
case HCI_SPEC_V30: printf("3.0 + HS\n"); break;
- default: printf("unknown\n"); break;
+ case HCI_SPEC_V40: printf("4.0\n"); break;
+ case HCI_SPEC_V41: printf("4.1\n"); break;
+ case HCI_SPEC_V42: printf("4.2\n"); break;
+ default: printf("[%d]\n", version); break;
}
load_value(HCI_CMD_READ_UNIT_CLASS, buf, HCI_CLASS_SIZE);
@@ -741,6 +745,7 @@
width = printf("\tfeatures:");
print_features0(btr.btr_features0);
print_features1(btr.btr_features1);
+ print_features2(btr.btr_features2);
tag(NULL);
}
@@ -802,9 +807,9 @@
if (*f & HCI_LMP_PAGISCHEME) tag("<paging parameter>");
if (*f & HCI_LMP_POWER_CONTROL) tag("<power control>");
if (*f & HCI_LMP_TRANSPARENT_SCO) tag("<transparent SCO>");
- if (*f & HCI_LMP_FLOW_CONTROL_LAG0) tag("<flow control lag 0>");
- if (*f & HCI_LMP_FLOW_CONTROL_LAG1) tag("<flow control lag 1>");
- if (*f & HCI_LMP_FLOW_CONTROL_LAG2) tag("<flow control lag 2>");
+ if (*f & HCI_LMP_FLOW_CONTROL_LAG0) tag("<flow control lag lsb>");
+ if (*f & HCI_LMP_FLOW_CONTROL_LAG1) tag("<flow control lag mb>");
+ if (*f & HCI_LMP_FLOW_CONTROL_LAG2) tag("<flow control lag msb>");
if (*f & HCI_LMP_BC_ENCRYPTION) tag("<broadcast encryption>");
f++;
@@ -823,6 +828,8 @@
if (*f & HCI_LMP_EV5_PKT) tag("<EV5 packets>");
if (*f & HCI_LMP_AFH_CAPABLE_SLAVE) tag("<AFH capable slave>");
if (*f & HCI_LMP_AFH_CLASS_SLAVE) tag("<AFH class slave>");
+ if (*f & HCI_LMP_BR_EDR_UNSUPPORTED)tag("<BR/EDR not supported>");
+ if (*f & HCI_LMP_LE_CONTROLLER) tag("<LE (controller)>");
if (*f & HCI_LMP_3SLOT_EDR_ACL) tag("<3 slot EDR ACL>");
f++;
@@ -839,6 +846,7 @@
/* ------------------- byte 6 --------------------*/
if (*f & HCI_LMP_EXTENDED_INQUIRY) tag("<extended inquiry>");
+ if (*f & HCI_LMP_LE_BR_EDR_CONTROLLER)tag("<simultaneous LE & BR/EDR (controller)>");
if (*f & HCI_LMP_SIMPLE_PAIRING) tag("<secure simple pairing>");
if (*f & HCI_LMP_ENCAPSULATED_PDU) tag("<encapsulated PDU>");
if (*f & HCI_LMP_ERRDATA_REPORTING) tag("<errdata reporting>");
@@ -857,7 +865,28 @@
{
/* ------------------- byte 0 --------------------*/
- if (*f & HCI_LMP_SSP) tag("<secure simple pairing>");
+ if (*f & HCI_LMP_SSP) tag("<secure simple pairing (host)>");
+ if (*f & HCI_LMP_LE_HOST) tag("<LE (host)>");
+ if (*f & HCI_LMP_LE_BR_EDR_HOST) tag("<simultaneous LE & BR/EDR (host)>");
+ if (*f & HCI_LMP_SECURE_CONN_HOST) tag("<secure connections (host)>");
+}
+
+static void
+print_features2(uint8_t *f)
+{
+ /* ------------------- byte 0 --------------------*/
+ if (*f & HCI_LMP_CONNLESS_MASTER) tag("<connectionless master>");
+ if (*f & HCI_LMP_CONNLESS_SLAVE) tag("<connectionless slave>");
+ if (*f & HCI_LMP_SYNC_TRAIN) tag("<synchronization train>");
+ if (*f & HCI_LMP_SYNC_SCAN) tag("<synchronization scan>");
+ if (*f & HCI_LMP_INQ_RSP_NOTIFY) tag("<inquiry response notification>");
+ if (*f & HCI_LMP_INTERLACE_SCAN) tag("<generalized interlace scan>");
+ if (*f & HCI_LMP_COARSE_CLOCK) tag("<coarse clock adjustment>");
+
+ /* ------------------- byte 1 --------------------*/
+ if (*f & HCI_LMP_SECURE_CONN_CONTROLLER)tag("<secure connections (controller)>");
+ if (*f & HCI_LMP_PING) tag("<ping>");
+ if (*f & HCI_LMP_TRAIN_NUDGING) tag("<train nudging>");
}
static void
Home |
Main Index |
Thread Index |
Old Index