Diff between a48d9dedf2bf9aabf0b9d3d5f1386e5d6770b2f2 and 6e58f66d3003598c16b23be5691f31d72ba12ada

Changed Files

File Additions Deletions Status
tools/parser/hci.c +7 -3 modified

Full Patch

diff --git a/tools/parser/hci.c b/tools/parser/hci.c
index a517fb4..eb67caf 100644
--- a/tools/parser/hci.c
+++ b/tools/parser/hci.c
@@ -3534,6 +3534,7 @@ static inline void evt_le_advertising_report_dump(int level, struct frame *frm)
 	while (num_reports--) {
 		char addr[18];
 		le_advertising_info *info = frm->ptr;
+		int offset = 0;
 
 		p_ba2str(&info->bdaddr, addr);
 
@@ -3544,9 +3545,12 @@ static inline void evt_le_advertising_report_dump(int level, struct frame *frm)
 		printf("bdaddr %s (%s)\n", addr,
 					bdaddrtype2str(info->bdaddr_type));
 
-		if (info->length > 0) {
-			ext_inquiry_data_dump(level, frm,
-					((uint8_t *) &info->length) + 1);
+		while (offset < info->length) {
+			int eir_data_len = info->data[offset];
+
+			ext_inquiry_data_dump(level, frm, &info->data[offset]);
+
+			offset += eir_data_len + 1;
 		}
 
 		frm->ptr += LE_ADVERTISING_INFO_SIZE + info->length;