diff --git a/tools/parser/hci.c b/tools/parser/hci.c
index 5e05730..c0ca27e 100644
--- a/tools/parser/hci.c
+++ b/tools/parser/hci.c
}
}
+static inline void write_default_link_policy_dump(int level, struct frame *frm)
+{
+ uint16_t policy = btohs(htons(get_u16(frm)));
+ char *str;
+
+ p_indent(level, frm);
+ printf("policy 0x%2.2x\n", policy);
+
+ str = hci_lptostr(policy);
+ if (str) {
+ p_indent(level, frm);
+ printf("Link policy: %s\n", str);
+ free(str);
+ }
+}
+
static inline void sniff_subrating_dump(int level, struct frame *frm)
{
sniff_subrating_cp *cp = frm->ptr;
case OCF_READ_LINK_POLICY:
generic_command_dump(level + 1, frm);
return;
+ case OCF_READ_DEFAULT_LINK_POLICY:
+ return;
case OCF_SWITCH_ROLE:
accept_conn_req_dump(level + 1, frm);
return;
case OCF_WRITE_LINK_POLICY:
write_link_policy_dump(level + 1, frm);
return;
+ case OCF_WRITE_DEFAULT_LINK_POLICY:
+ write_default_link_policy_dump(level + 1, frm);
+ return;
case OCF_SNIFF_SUBRATING:
sniff_subrating_dump(level + 1, frm);
return;
}
}
+static inline void read_default_link_policy_dump(int level, struct frame *frm)
+{
+ uint8_t status = get_u8(frm);
+ uint16_t policy = btohs(htons(get_u16(frm)));
+ char *str;
+
+ p_indent(level, frm);
+ printf("status 0x%2.2x policy 0x%2.2x\n", status, policy);
+
+ if (status > 0) {
+ p_indent(level, frm);
+ printf("Error: %s\n", status2str(status));
+ } else {
+ str = hci_lptostr(policy);
+ if (str) {
+ p_indent(level, frm);
+ printf("Link policy: %s\n", str);
+ free(str);
+ }
+ }
+}
+
static inline void read_pin_type_dump(int level, struct frame *frm)
{
read_pin_type_rp *rp = frm->ptr;
case OCF_SNIFF_SUBRATING:
generic_response_dump(level, frm);
return;
+ case OCF_READ_DEFAULT_LINK_POLICY:
+ read_default_link_policy_dump(level, frm);
+ return;
+ case OCF_WRITE_DEFAULT_LINK_POLICY:
+ status_response_dump(level, frm);
+ return;
}
break;