Diff between 51899b5d8fc531bbe8762a9c6a57057e5004ac59 and a484dfebfd48c32d6a04e9373f80c69c6d9574da

Changed Files

File Additions Deletions Status
monitor/bt.h +20 -0 modified
monitor/packet.c +46 -2 modified

Full Patch

diff --git a/monitor/bt.h b/monitor/bt.h
index af2ce91..ffe95e5 100644
--- a/monitor/bt.h
+++ b/monitor/bt.h
@@ -706,6 +706,26 @@ struct bt_hci_cmd_write_voice_setting {
 	uint16_t setting;
 } __attribute__ ((packed));
 
+#define BT_HCI_CMD_READ_AUTO_FLUSH_TIMEOUT	0x0c27
+struct bt_hci_cmd_read_auto_flush_timeout {
+	uint16_t handle;
+} __attribute__ ((packed));
+struct bt_hci_rsp_read_auto_flush_timeout {
+	uint8_t  status;
+	uint16_t handle;
+	uint16_t timeout;
+} __attribute__ ((packed));
+
+#define BT_HCI_CMD_WRITE_AUTO_FLUSH_TIMEOUT	0x0c28
+struct bt_hci_cmd_write_auto_flush_timeout {
+	uint16_t handle;
+	uint16_t timeout;
+} __attribute__ ((packed));
+struct bt_hci_rsp_write_auto_flush_timeout {
+	uint8_t  status;
+	uint16_t handle;
+} __attribute__ ((packed));
+
 #define BT_HCI_CMD_READ_NUM_BROADCAST_RETRANS	0x0c29
 struct bt_hci_rsp_read_num_broadcast_retrans {
 	uint8_t  status;
diff --git a/monitor/packet.c b/monitor/packet.c
index 0c2dad4..e7f6717 100644
--- a/monitor/packet.c
+++ b/monitor/packet.c
@@ -1649,6 +1649,14 @@ static void print_channel_map(const uint8_t *map)
 	print_field("Channel map: 0x%s", str);
 }
 
+static void print_flush_timeout(uint16_t timeout)
+{
+	if (timeout)
+		print_timeout(timeout);
+	else
+		print_field("Timeout: No Automatic Flush");
+}
+
 void packet_print_version(const char *label, uint8_t version,
 				const char *sublabel, uint16_t subversion)
 {
@@ -3661,6 +3669,38 @@ static void write_voice_setting_cmd(const void *data, uint8_t size)
 	print_voice_setting(cmd->setting);
 }
 
+static void read_auto_flush_timeout_cmd(const void *data, uint8_t size)
+{
+	const struct bt_hci_cmd_read_auto_flush_timeout *cmd = data;
+
+	print_handle(cmd->handle);
+}
+
+static void read_auto_flush_timeout_rsp(const void *data, uint8_t size)
+{
+	const struct bt_hci_rsp_read_auto_flush_timeout *rsp = data;
+
+	print_status(rsp->status);
+	print_handle(rsp->handle);
+	print_flush_timeout(rsp->timeout);
+}
+
+static void write_auto_flush_timeout_cmd(const void *data, uint8_t size)
+{
+	const struct bt_hci_cmd_write_auto_flush_timeout *cmd = data;
+
+	print_handle(cmd->handle);
+	print_flush_timeout(cmd->timeout);
+}
+
+static void write_auto_flush_timeout_rsp(const void *data, uint8_t size)
+{
+	const struct bt_hci_rsp_write_auto_flush_timeout *rsp = data;
+
+	print_status(rsp->status);
+	print_handle(rsp->handle);
+}
+
 static void read_num_broadcast_retrans_rsp(const void *data, uint8_t size)
 {
 	const struct bt_hci_rsp_read_num_broadcast_retrans *rsp = data;
@@ -5034,8 +5074,12 @@ static const struct opcode_data opcode_table[] = {
 	{ 0x0c26,  75, "Write Voice Setting",
 				write_voice_setting_cmd, 2, true,
 				status_rsp, 1, true },
-	{ 0x0c27,  76, "Read Automatic Flush Timeout" },
-	{ 0x0c28,  77, "Write Automatic Flush Timeout" },
+	{ 0x0c27,  76, "Read Automatic Flush Timeout",
+				read_auto_flush_timeout_cmd, 2, true,
+				read_auto_flush_timeout_rsp, 5, true },
+	{ 0x0c28,  77, "Write Automatic Flush Timeout",
+				write_auto_flush_timeout_cmd, 4, true,
+				write_auto_flush_timeout_rsp, 3, true },
 	{ 0x0c29,  78, "Read Num Broadcast Retransmissions",
 				null_cmd, 0, true,
 				read_num_broadcast_retrans_rsp, 2, true },