summaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-usb.c
diff options
context:
space:
mode:
Diffstat (limited to 'epan/dissectors/packet-usb.c')
-rw-r--r--epan/dissectors/packet-usb.c1956
1 files changed, 1019 insertions, 937 deletions
diff --git a/epan/dissectors/packet-usb.c b/epan/dissectors/packet-usb.c
index a8899da5..be266617 100644
--- a/epan/dissectors/packet-usb.c
+++ b/epan/dissectors/packet-usb.c
@@ -42,95 +42,95 @@ static dissector_handle_t darwin_usb_handle;
static dissector_handle_t netmon_usb_port_handle;
/* protocols and header fields */
-static int proto_usb = -1;
-static int proto_usbport = -1;
+static int proto_usb;
+static int proto_usbport;
/* USB pseudoheader fields, both FreeBSD and Linux */
-static int hf_usb_totlen = -1;
-static int hf_usb_busunit = -1;
-static int hf_usb_address = -1;
-static int hf_usb_mode = -1;
-static int hf_usb_freebsd_urb_type = -1;
-static int hf_usb_freebsd_transfer_type = -1;
-static int hf_usb_xferflags = -1;
-static int hf_usb_xferflags_force_short_xfer = -1;
-static int hf_usb_xferflags_short_xfer_ok = -1;
-static int hf_usb_xferflags_short_frames_ok = -1;
-static int hf_usb_xferflags_pipe_bof = -1;
-static int hf_usb_xferflags_proxy_buffer = -1;
-static int hf_usb_xferflags_ext_buffer = -1;
-static int hf_usb_xferflags_manual_status = -1;
-static int hf_usb_xferflags_no_pipe_ok = -1;
-static int hf_usb_xferflags_stall_pipe = -1;
-static int hf_usb_xferstatus = -1;
-static int hf_usb_xferstatus_open = -1;
-static int hf_usb_xferstatus_transferring = -1;
-static int hf_usb_xferstatus_did_dma_delay = -1;
-static int hf_usb_xferstatus_did_close = -1;
-static int hf_usb_xferstatus_draining = -1;
-static int hf_usb_xferstatus_started = -1;
-static int hf_usb_xferstatus_bw_reclaimed = -1;
-static int hf_usb_xferstatus_control_xfr = -1;
-static int hf_usb_xferstatus_control_hdr = -1;
-static int hf_usb_xferstatus_control_act = -1;
-static int hf_usb_xferstatus_control_stall = -1;
-static int hf_usb_xferstatus_short_frames_ok = -1;
-static int hf_usb_xferstatus_short_xfer_ok = -1;
-static int hf_usb_xferstatus_bdma_enable = -1;
-static int hf_usb_xferstatus_bdma_no_post_sync = -1;
-static int hf_usb_xferstatus_bdma_setup = -1;
-static int hf_usb_xferstatus_isochronous_xfr = -1;
-static int hf_usb_xferstatus_curr_dma_set = -1;
-static int hf_usb_xferstatus_can_cancel_immed = -1;
-static int hf_usb_xferstatus_doing_callback = -1;
-static int hf_usb_error = -1;
-static int hf_usb_interval = -1;
-static int hf_usb_nframes = -1;
-static int hf_usb_packet_size = -1;
-static int hf_usb_packet_count = -1;
-static int hf_usb_speed = -1;
-static int hf_usb_frame_length = -1;
-static int hf_usb_frame_flags = -1;
-static int hf_usb_frame_flags_read = -1;
-static int hf_usb_frame_flags_data_follows = -1;
-static int hf_usb_frame_data = -1;
-static int hf_usb_urb_id = -1;
-static int hf_usb_linux_urb_type = -1;
-static int hf_usb_linux_transfer_type = -1;
-static int hf_usb_endpoint_address = -1;
-static int hf_usb_endpoint_direction = -1;
-static int hf_usb_endpoint_number = -1;
-static int hf_usb_device_address = -1;
-static int hf_usb_bus_id = -1;
-static int hf_usb_setup_flag = -1;
-static int hf_usb_data_flag = -1;
-static int hf_usb_urb_ts_sec = -1;
-static int hf_usb_urb_ts_usec = -1;
-static int hf_usb_urb_status = -1;
-static int hf_usb_urb_len = -1;
-static int hf_usb_urb_data_len = -1;
-static int hf_usb_urb_unused_setup_header = -1;
-static int hf_usb_urb_interval = -1;
-static int hf_usb_urb_start_frame = -1;
-static int hf_usb_urb_copy_of_transfer_flags = -1;
+static int hf_usb_totlen;
+static int hf_usb_busunit;
+static int hf_usb_address;
+static int hf_usb_mode;
+static int hf_usb_freebsd_urb_type;
+static int hf_usb_freebsd_transfer_type;
+static int hf_usb_xferflags;
+static int hf_usb_xferflags_force_short_xfer;
+static int hf_usb_xferflags_short_xfer_ok;
+static int hf_usb_xferflags_short_frames_ok;
+static int hf_usb_xferflags_pipe_bof;
+static int hf_usb_xferflags_proxy_buffer;
+static int hf_usb_xferflags_ext_buffer;
+static int hf_usb_xferflags_manual_status;
+static int hf_usb_xferflags_no_pipe_ok;
+static int hf_usb_xferflags_stall_pipe;
+static int hf_usb_xferstatus;
+static int hf_usb_xferstatus_open;
+static int hf_usb_xferstatus_transferring;
+static int hf_usb_xferstatus_did_dma_delay;
+static int hf_usb_xferstatus_did_close;
+static int hf_usb_xferstatus_draining;
+static int hf_usb_xferstatus_started;
+static int hf_usb_xferstatus_bw_reclaimed;
+static int hf_usb_xferstatus_control_xfr;
+static int hf_usb_xferstatus_control_hdr;
+static int hf_usb_xferstatus_control_act;
+static int hf_usb_xferstatus_control_stall;
+static int hf_usb_xferstatus_short_frames_ok;
+static int hf_usb_xferstatus_short_xfer_ok;
+static int hf_usb_xferstatus_bdma_enable;
+static int hf_usb_xferstatus_bdma_no_post_sync;
+static int hf_usb_xferstatus_bdma_setup;
+static int hf_usb_xferstatus_isochronous_xfr;
+static int hf_usb_xferstatus_curr_dma_set;
+static int hf_usb_xferstatus_can_cancel_immed;
+static int hf_usb_xferstatus_doing_callback;
+static int hf_usb_error;
+static int hf_usb_interval;
+static int hf_usb_nframes;
+static int hf_usb_packet_size;
+static int hf_usb_packet_count;
+static int hf_usb_speed;
+static int hf_usb_frame_length;
+static int hf_usb_frame_flags;
+static int hf_usb_frame_flags_read;
+static int hf_usb_frame_flags_data_follows;
+static int hf_usb_frame_data;
+static int hf_usb_urb_id;
+static int hf_usb_linux_urb_type;
+static int hf_usb_linux_transfer_type;
+static int hf_usb_endpoint_address;
+static int hf_usb_endpoint_direction;
+static int hf_usb_endpoint_number;
+static int hf_usb_device_address;
+static int hf_usb_bus_id;
+static int hf_usb_setup_flag;
+static int hf_usb_data_flag;
+static int hf_usb_urb_ts_sec;
+static int hf_usb_urb_ts_usec;
+static int hf_usb_urb_status;
+static int hf_usb_urb_len;
+static int hf_usb_urb_data_len;
+static int hf_usb_urb_unused_setup_header;
+static int hf_usb_urb_interval;
+static int hf_usb_urb_start_frame;
+static int hf_usb_urb_copy_of_transfer_flags;
/* transfer_flags */
-static int hf_short_not_ok = -1;
-static int hf_iso_asap = -1;
-static int hf_no_transfer_dma_map = -1;
-static int hf_no_fsbr = -1;
-static int hf_zero_packet = -1;
-static int hf_no_interrupt = -1;
-static int hf_free_buffer = -1;
-static int hf_dir_in = -1;
-static int hf_dma_map_single = -1;
-static int hf_dma_map_page = -1;
-static int hf_dma_map_sg = -1;
-static int hf_map_local = -1;
-static int hf_setup_map_single = -1;
-static int hf_setup_map_local = -1;
-static int hf_dma_sg_combined = -1;
-static int hf_aligned_temp_buffer = -1;
+static int hf_short_not_ok;
+static int hf_iso_asap;
+static int hf_no_transfer_dma_map;
+static int hf_no_fsbr;
+static int hf_zero_packet;
+static int hf_no_interrupt;
+static int hf_free_buffer;
+static int hf_dir_in;
+static int hf_dma_map_single;
+static int hf_dma_map_page;
+static int hf_dma_map_sg;
+static int hf_map_local;
+static int hf_setup_map_single;
+static int hf_setup_map_local;
+static int hf_dma_sg_combined;
+static int hf_aligned_temp_buffer;
static int * const transfer_flags_fields[] = {
&hf_short_not_ok,
@@ -153,260 +153,260 @@ static int * const transfer_flags_fields[] = {
};
/* Win32 USBPcap pseudoheader fields */
-static int hf_usb_win32_header_len = -1;
-static int hf_usb_irp_id = -1;
-static int hf_usb_usbd_status = -1;
-static int hf_usb_function = -1;
-static int hf_usb_info = -1;
-static int hf_usb_usbpcap_info_reserved = -1;
-static int hf_usb_usbpcap_info_direction = -1;
-static int hf_usb_win32_device_address = -1;
-static int hf_usb_win32_transfer_type = -1;
+static int hf_usb_win32_header_len;
+static int hf_usb_irp_id;
+static int hf_usb_usbd_status;
+static int hf_usb_function;
+static int hf_usb_info;
+static int hf_usb_usbpcap_info_reserved;
+static int hf_usb_usbpcap_info_direction;
+static int hf_usb_win32_device_address;
+static int hf_usb_win32_transfer_type;
/* hf_usb_bus_id, hf_usb_endpoint_address, hf_usb_endpoint_direction,
* hf_usb_endpoint_number are common with
* FreeBSD and Linux pseudoheaders */
-static int hf_usb_win32_data_len = -1;
-static int hf_usb_win32_control_stage = -1;
-static int hf_usb_win32_iso_start_frame = -1;
-static int hf_usb_win32_iso_num_packets = -1;
-static int hf_usb_win32_iso_error_count = -1;
-static int hf_usb_win32_iso_offset = -1;
-static int hf_usb_win32_iso_length = -1;
-static int hf_usb_win32_iso_status = -1;
-
-static int hf_usb_request = -1;
-static int hf_usb_request_unknown_class = -1;
-static int hf_usb_value = -1;
-static int hf_usb_index = -1;
-static int hf_usb_length = -1;
-/* static int hf_usb_data_len = -1; */
-static int hf_usb_capdata = -1;
-static int hf_usb_device_wFeatureSelector = -1;
-static int hf_usb_interface_wFeatureSelector = -1;
-static int hf_usb_endpoint_wFeatureSelector = -1;
-static int hf_usb_wInterface = -1;
-static int hf_usb_wEndpoint = -1;
-static int hf_usb_wStatus = -1;
-static int hf_usb_wFrameNumber = -1;
-
-static int hf_usb_iso_error_count = -1;
-static int hf_usb_iso_numdesc = -1;
-static int hf_usb_iso_status = -1;
-static int hf_usb_iso_off = -1;
-static int hf_usb_iso_len = -1;
-static int hf_usb_iso_actual_len = -1;
-static int hf_usb_iso_pad = -1;
-static int hf_usb_iso_data = -1;
-
-static int hf_usb_bmRequestType = -1;
-static int hf_usb_control_response_generic = -1;
-static int hf_usb_bmRequestType_direction = -1;
-static int hf_usb_bmRequestType_type = -1;
-static int hf_usb_bmRequestType_recipient = -1;
-static int hf_usb_bDescriptorType = -1;
-static int hf_usb_get_descriptor_resp_generic = -1;
-static int hf_usb_descriptor_index = -1;
-static int hf_usb_language_id = -1;
-static int hf_usb_bLength = -1;
-static int hf_usb_bcdUSB = -1;
-static int hf_usb_bDeviceClass = -1;
-static int hf_usb_bDeviceSubClass = -1;
-static int hf_usb_bDeviceProtocol = -1;
-static int hf_usb_bMaxPacketSize0 = -1;
-static int hf_usb_idVendor = -1;
-static int hf_usb_idProduct = -1;
-static int hf_usb_bcdDevice = -1;
-static int hf_usb_iManufacturer = -1;
-static int hf_usb_iProduct = -1;
-static int hf_usb_iSerialNumber = -1;
-static int hf_usb_bNumConfigurations = -1;
-static int hf_usb_wLANGID = -1;
-static int hf_usb_bString = -1;
-static int hf_usb_bInterfaceNumber = -1;
-static int hf_usb_bAlternateSetting = -1;
-static int hf_usb_bNumEndpoints = -1;
-static int hf_usb_bInterfaceClass = -1;
-static int hf_usb_bInterfaceSubClass = -1;
-static int hf_usb_bInterfaceSubClass_audio = -1;
-static int hf_usb_bInterfaceSubClass_cdc = -1;
-static int hf_usb_bInterfaceSubClass_massstorage = -1;
-static int hf_usb_bInterfaceSubClass_hid = -1;
-static int hf_usb_bInterfaceSubClass_misc = -1;
-static int hf_usb_bInterfaceSubClass_app = -1;
-static int hf_usb_bInterfaceProtocol = -1;
-static int hf_usb_bInterfaceProtocol_cdc = -1;
-static int hf_usb_bInterfaceProtocol_massstorage = -1;
-static int hf_usb_bInterfaceProtocol_cdc_data = -1;
-static int hf_usb_bInterfaceProtocol_hid_boot = -1;
-static int hf_usb_bInterfaceProtocol_app_dfu = -1;
-static int hf_usb_bInterfaceProtocol_app_irda = -1;
-static int hf_usb_bInterfaceProtocol_app_usb_test_and_measurement = -1;
-static int hf_usb_iInterface = -1;
-static int hf_usb_bEndpointAddress = -1;
-static int hf_usb_bmAttributes = -1;
-static int hf_usb_bEndpointAttributeTransfer = -1;
-static int hf_usb_bEndpointAttributeSynchonisation = -1;
-static int hf_usb_bEndpointAttributeBehaviour = -1;
-static int hf_usb_wMaxPacketSize = -1;
-static int hf_usb_wMaxPacketSize_size = -1;
-static int hf_usb_wMaxPacketSize_slots = -1;
-static int hf_usb_bInterval = -1;
-static int hf_usb_bMaxBurst = -1;
-static int hf_usb_audio_bRefresh = -1;
-static int hf_usb_audio_bSynchAddress = -1;
-static int hf_usb_bSSEndpointAttributeBulkMaxStreams = -1;
-static int hf_usb_bSSEndpointAttributeIsoMult = -1;
-static int hf_usb_wBytesPerInterval = -1;
-static int hf_usb_wTotalLength = -1;
-static int hf_usb_bNumInterfaces = -1;
-static int hf_usb_bConfigurationValue = -1;
-static int hf_usb_iConfiguration = -1;
-static int hf_usb_bMaxPower = -1;
-static int hf_usb_configuration_bmAttributes = -1;
-static int hf_usb_configuration_legacy10buspowered = -1;
-static int hf_usb_configuration_selfpowered = -1;
-static int hf_usb_configuration_remotewakeup = -1;
-static int hf_usb_bEndpointAddress_direction = -1;
-static int hf_usb_bEndpointAddress_number = -1;
-static int hf_usb_response_in = -1;
-static int hf_usb_time = -1;
-static int hf_usb_request_in = -1;
-static int hf_usb_bFirstInterface = -1;
-static int hf_usb_bInterfaceCount = -1;
-static int hf_usb_bFunctionClass = -1;
-static int hf_usb_bFunctionSubClass = -1;
-static int hf_usb_bFunctionProtocol = -1;
-static int hf_usb_iFunction = -1;
-static int hf_usb_bNumDeviceCaps = -1;
-static int hf_usb_bDevCapabilityType = -1;
-static int hf_usb_usb20ext_bmAttributes = -1;
-static int hf_usb_usb20ext_LPM = -1;
-static int hf_usb_usb20ext_BESL_HIRD = -1;
-static int hf_usb_usb20ext_baseline_BESL_valid = -1;
-static int hf_usb_usb20ext_deep_BESL_valid = -1;
-static int hf_usb_usb20ext_baseline_BESL = -1;
-static int hf_usb_usb20ext_deep_BESL = -1;
-static int hf_usb_bReserved = -1;
-static int hf_usb_PlatformCapabilityUUID = -1;
-static int hf_usb_webusb_bcdVersion = -1;
-static int hf_usb_webusb_bVendorCode = -1;
-static int hf_usb_webusb_iLandingPage = -1;
-static int hf_usb_msos20_dwWindowsVersion = -1;
-static int hf_usb_msos20_wMSOSDescriptorSetTotalLength = -1;
-static int hf_usb_msos20_bMS_VendorCode = -1;
-static int hf_usb_msos20_bAltEnumCode = -1;
-static int hf_usb_data_fragment = -1;
-static int hf_usb_src = -1;
-static int hf_usb_dst = -1;
-static int hf_usb_addr = -1;
+static int hf_usb_win32_data_len;
+static int hf_usb_win32_control_stage;
+static int hf_usb_win32_iso_start_frame;
+static int hf_usb_win32_iso_num_packets;
+static int hf_usb_win32_iso_error_count;
+static int hf_usb_win32_iso_offset;
+static int hf_usb_win32_iso_length;
+static int hf_usb_win32_iso_status;
+
+static int hf_usb_request;
+static int hf_usb_request_unknown_class;
+static int hf_usb_value;
+static int hf_usb_index;
+static int hf_usb_length;
+/* static int hf_usb_data_len; */
+static int hf_usb_capdata;
+static int hf_usb_device_wFeatureSelector;
+static int hf_usb_interface_wFeatureSelector;
+static int hf_usb_endpoint_wFeatureSelector;
+static int hf_usb_wInterface;
+static int hf_usb_wEndpoint;
+static int hf_usb_wStatus;
+static int hf_usb_wFrameNumber;
+
+static int hf_usb_iso_error_count;
+static int hf_usb_iso_numdesc;
+static int hf_usb_iso_status;
+static int hf_usb_iso_off;
+static int hf_usb_iso_len;
+static int hf_usb_iso_actual_len;
+static int hf_usb_iso_pad;
+static int hf_usb_iso_data;
+
+static int hf_usb_bmRequestType;
+static int hf_usb_control_response_generic;
+static int hf_usb_bmRequestType_direction;
+static int hf_usb_bmRequestType_type;
+static int hf_usb_bmRequestType_recipient;
+static int hf_usb_bDescriptorType;
+static int hf_usb_get_descriptor_resp_generic;
+static int hf_usb_descriptor_index;
+static int hf_usb_language_id;
+static int hf_usb_bLength;
+static int hf_usb_bcdUSB;
+static int hf_usb_bDeviceClass;
+static int hf_usb_bDeviceSubClass;
+static int hf_usb_bDeviceProtocol;
+static int hf_usb_bMaxPacketSize0;
+static int hf_usb_idVendor;
+static int hf_usb_idProduct;
+static int hf_usb_bcdDevice;
+static int hf_usb_iManufacturer;
+static int hf_usb_iProduct;
+static int hf_usb_iSerialNumber;
+static int hf_usb_bNumConfigurations;
+static int hf_usb_wLANGID;
+static int hf_usb_bString;
+static int hf_usb_bInterfaceNumber;
+static int hf_usb_bAlternateSetting;
+static int hf_usb_bNumEndpoints;
+static int hf_usb_bInterfaceClass;
+static int hf_usb_bInterfaceSubClass;
+static int hf_usb_bInterfaceSubClass_audio;
+static int hf_usb_bInterfaceSubClass_cdc;
+static int hf_usb_bInterfaceSubClass_massstorage;
+static int hf_usb_bInterfaceSubClass_hid;
+static int hf_usb_bInterfaceSubClass_misc;
+static int hf_usb_bInterfaceSubClass_app;
+static int hf_usb_bInterfaceProtocol;
+static int hf_usb_bInterfaceProtocol_cdc;
+static int hf_usb_bInterfaceProtocol_massstorage;
+static int hf_usb_bInterfaceProtocol_cdc_data;
+static int hf_usb_bInterfaceProtocol_hid_boot;
+static int hf_usb_bInterfaceProtocol_app_dfu;
+static int hf_usb_bInterfaceProtocol_app_irda;
+static int hf_usb_bInterfaceProtocol_app_usb_test_and_measurement;
+static int hf_usb_iInterface;
+static int hf_usb_bEndpointAddress;
+static int hf_usb_bmAttributes;
+static int hf_usb_bEndpointAttributeTransfer;
+static int hf_usb_bEndpointAttributeSynchonisation;
+static int hf_usb_bEndpointAttributeBehaviour;
+static int hf_usb_wMaxPacketSize;
+static int hf_usb_wMaxPacketSize_size;
+static int hf_usb_wMaxPacketSize_slots;
+static int hf_usb_bInterval;
+static int hf_usb_bMaxBurst;
+static int hf_usb_audio_bRefresh;
+static int hf_usb_audio_bSynchAddress;
+static int hf_usb_bSSEndpointAttributeBulkMaxStreams;
+static int hf_usb_bSSEndpointAttributeIsoMult;
+static int hf_usb_wBytesPerInterval;
+static int hf_usb_wTotalLength;
+static int hf_usb_bNumInterfaces;
+static int hf_usb_bConfigurationValue;
+static int hf_usb_iConfiguration;
+static int hf_usb_bMaxPower;
+static int hf_usb_configuration_bmAttributes;
+static int hf_usb_configuration_legacy10buspowered;
+static int hf_usb_configuration_selfpowered;
+static int hf_usb_configuration_remotewakeup;
+static int hf_usb_bEndpointAddress_direction;
+static int hf_usb_bEndpointAddress_number;
+static int hf_usb_response_in;
+static int hf_usb_time;
+static int hf_usb_request_in;
+static int hf_usb_bFirstInterface;
+static int hf_usb_bInterfaceCount;
+static int hf_usb_bFunctionClass;
+static int hf_usb_bFunctionSubClass;
+static int hf_usb_bFunctionProtocol;
+static int hf_usb_iFunction;
+static int hf_usb_bNumDeviceCaps;
+static int hf_usb_bDevCapabilityType;
+static int hf_usb_usb20ext_bmAttributes;
+static int hf_usb_usb20ext_LPM;
+static int hf_usb_usb20ext_BESL_HIRD;
+static int hf_usb_usb20ext_baseline_BESL_valid;
+static int hf_usb_usb20ext_deep_BESL_valid;
+static int hf_usb_usb20ext_baseline_BESL;
+static int hf_usb_usb20ext_deep_BESL;
+static int hf_usb_bReserved;
+static int hf_usb_PlatformCapabilityUUID;
+static int hf_usb_webusb_bcdVersion;
+static int hf_usb_webusb_bVendorCode;
+static int hf_usb_webusb_iLandingPage;
+static int hf_usb_msos20_dwWindowsVersion;
+static int hf_usb_msos20_wMSOSDescriptorSetTotalLength;
+static int hf_usb_msos20_bMS_VendorCode;
+static int hf_usb_msos20_bAltEnumCode;
+static int hf_usb_data_fragment;
+static int hf_usb_src;
+static int hf_usb_dst;
+static int hf_usb_addr;
/* macOS */
-static int hf_usb_darwin_bcd_version = -1;
-static int hf_usb_darwin_header_len = -1;
-static int hf_usb_darwin_request_type = -1;
-static int hf_usb_darwin_io_len = -1;
-static int hf_usb_darwin_io_status = -1;
-static int hf_usb_darwin_iso_num_packets = -1;
-static int hf_usb_darwin_io_id = -1;
-static int hf_usb_darwin_device_location = -1;
-static int hf_usb_darwin_speed = -1;
-static int hf_usb_darwin_device_address = -1;
-static int hf_usb_darwin_endpoint_address = -1;
-static int hf_usb_darwin_endpoint_type = -1;
-static int hf_usb_darwin_iso_status = -1;
-static int hf_usb_darwin_iso_frame_number = -1;
-static int hf_usb_darwin_iso_timestamp = -1;
+static int hf_usb_darwin_bcd_version;
+static int hf_usb_darwin_header_len;
+static int hf_usb_darwin_request_type;
+static int hf_usb_darwin_io_len;
+static int hf_usb_darwin_io_status;
+static int hf_usb_darwin_iso_num_packets;
+static int hf_usb_darwin_io_id;
+static int hf_usb_darwin_device_location;
+static int hf_usb_darwin_speed;
+static int hf_usb_darwin_device_address;
+static int hf_usb_darwin_endpoint_address;
+static int hf_usb_darwin_endpoint_type;
+static int hf_usb_darwin_iso_status;
+static int hf_usb_darwin_iso_frame_number;
+static int hf_usb_darwin_iso_timestamp;
/* NetMon */
-static int hf_usbport_event_id = -1;
-static int hf_usbport_device_object = -1;
-static int hf_usbport_pci_bus = -1;
-static int hf_usbport_pci_device = -1;
-static int hf_usbport_pci_function = -1;
-static int hf_usbport_pci_vendor_id = -1;
-static int hf_usbport_pci_device_id = -1;
-static int hf_usbport_port_path_depth = -1;
-static int hf_usbport_port_path0 = -1;
-static int hf_usbport_port_path1 = -1;
-static int hf_usbport_port_path2 = -1;
-static int hf_usbport_port_path3 = -1;
-static int hf_usbport_port_path4 = -1;
-static int hf_usbport_port_path5 = -1;
-static int hf_usbport_device_handle = -1;
-static int hf_usbport_device_speed = -1;
-static int hf_usbport_endpoint = -1;
-static int hf_usbport_pipehandle = -1;
-static int hf_usbport_endpoint_desc_length = -1;
-static int hf_usbport_endpoint_desc_type = -1;
-static int hf_usbport_endpoint_address = -1;
-static int hf_usbport_bm_attributes = -1;
-static int hf_usbport_max_packet_size = -1;
-static int hf_usbport_interval = -1;
-static int hf_usbport_irp = -1;
-static int hf_usbport_urb = -1;
-static int hf_usbport_urb_transfer_data = -1;
-static int hf_usbport_urb_header_length = -1;
-static int hf_usbport_urb_header_function = -1;
-static int hf_usbport_urb_header_status = -1;
-static int hf_usbport_urb_header_usbddevice_handle = -1;
-static int hf_usbport_urb_header_usbdflags = -1;
-static int hf_usbport_urb_configuration_desc = -1;
-static int hf_usbport_urb_configuration_handle = -1;
-static int hf_usbport_urb_pipe_handle = -1;
-static int hf_usbport_urb_xferflags = -1;
-static int hf_usbport_urb_transfer_buffer_length = -1;
-static int hf_usbport_urb_transfer_buffer = -1;
-static int hf_usbport_urb_transfer_buffer_mdl = -1;
-static int hf_usbport_urb_reserved_mbz = -1;
-static int hf_usbport_urb_reserved_hcd = -1;
-static int hf_usbport_urb_reserved = -1;
-static int hf_usbport_keyword = -1;
-static int hf_usbport_keyword_diagnostic = -1;
-static int hf_usbport_keyword_power_diagnostics = -1;
-static int hf_usbport_keyword_perf_diagnostics = -1;
-static int hf_usbport_keyword_reserved1 = -1;
-
-static gint ett_usb_hdr = -1;
-static gint ett_usb_setup_hdr = -1;
-static gint ett_usb_isodesc = -1;
-static gint ett_usb_win32_iso_packet = -1;
-static gint ett_usb_endpoint = -1;
-static gint ett_usb_setup_bmrequesttype = -1;
-static gint ett_usb_usbpcap_info = -1;
-static gint ett_descriptor_device = -1;
-static gint ett_configuration_bmAttributes = -1;
-static gint ett_configuration_bEndpointAddress = -1;
-static gint ett_endpoint_bmAttributes = -1;
-static gint ett_endpoint_wMaxPacketSize = -1;
-static gint ett_usb_xferflags = -1;
-static gint ett_usb_xferstatus = -1;
-static gint ett_usb_frame = -1;
-static gint ett_usb_frame_flags = -1;
-static gint ett_usbport = -1;
-static gint ett_usbport_host_controller = -1;
-static gint ett_usbport_path = -1;
-static gint ett_usbport_device = -1;
-static gint ett_usbport_endpoint = -1;
-static gint ett_usbport_endpoint_desc = -1;
-static gint ett_usbport_urb = -1;
-static gint ett_usbport_keyword = -1;
-static gint ett_transfer_flags = -1;
-static gint ett_usb20ext_bmAttributes = -1;
-
-static expert_field ei_usb_undecoded = EI_INIT;
-static expert_field ei_usb_bLength_even = EI_INIT;
-static expert_field ei_usb_bLength_too_short = EI_INIT;
-static expert_field ei_usb_desc_length_invalid = EI_INIT;
-static expert_field ei_usb_invalid_setup = EI_INIT;
-static expert_field ei_usb_ss_ep_companion_before_ep = EI_INIT;
-static expert_field ei_usb_usbpcap_unknown_urb = EI_INIT;
-static expert_field ei_usb_bad_length = EI_INIT;
-static expert_field ei_usb_invalid_max_packet_size = EI_INIT;
-static expert_field ei_usb_invalid_max_packet_size0 = EI_INIT;
-static expert_field ei_usb_invalid_endpoint_type = EI_INIT;
-static expert_field ei_usb_unexpected_desc_type = EI_INIT;
-
-static expert_field ei_usbport_invalid_path_depth = EI_INIT;
+static int hf_usbport_event_id;
+static int hf_usbport_device_object;
+static int hf_usbport_pci_bus;
+static int hf_usbport_pci_device;
+static int hf_usbport_pci_function;
+static int hf_usbport_pci_vendor_id;
+static int hf_usbport_pci_device_id;
+static int hf_usbport_port_path_depth;
+static int hf_usbport_port_path0;
+static int hf_usbport_port_path1;
+static int hf_usbport_port_path2;
+static int hf_usbport_port_path3;
+static int hf_usbport_port_path4;
+static int hf_usbport_port_path5;
+static int hf_usbport_device_handle;
+static int hf_usbport_device_speed;
+static int hf_usbport_endpoint;
+static int hf_usbport_pipehandle;
+static int hf_usbport_endpoint_desc_length;
+static int hf_usbport_endpoint_desc_type;
+static int hf_usbport_endpoint_address;
+static int hf_usbport_bm_attributes;
+static int hf_usbport_max_packet_size;
+static int hf_usbport_interval;
+static int hf_usbport_irp;
+static int hf_usbport_urb;
+static int hf_usbport_urb_transfer_data;
+static int hf_usbport_urb_header_length;
+static int hf_usbport_urb_header_function;
+static int hf_usbport_urb_header_status;
+static int hf_usbport_urb_header_usbddevice_handle;
+static int hf_usbport_urb_header_usbdflags;
+static int hf_usbport_urb_configuration_desc;
+static int hf_usbport_urb_configuration_handle;
+static int hf_usbport_urb_pipe_handle;
+static int hf_usbport_urb_xferflags;
+static int hf_usbport_urb_transfer_buffer_length;
+static int hf_usbport_urb_transfer_buffer;
+static int hf_usbport_urb_transfer_buffer_mdl;
+static int hf_usbport_urb_reserved_mbz;
+static int hf_usbport_urb_reserved_hcd;
+static int hf_usbport_urb_reserved;
+static int hf_usbport_keyword;
+static int hf_usbport_keyword_diagnostic;
+static int hf_usbport_keyword_power_diagnostics;
+static int hf_usbport_keyword_perf_diagnostics;
+static int hf_usbport_keyword_reserved1;
+
+static int ett_usb_hdr;
+static int ett_usb_setup_hdr;
+static int ett_usb_isodesc;
+static int ett_usb_win32_iso_packet;
+static int ett_usb_endpoint;
+static int ett_usb_setup_bmrequesttype;
+static int ett_usb_usbpcap_info;
+static int ett_descriptor_device;
+static int ett_configuration_bmAttributes;
+static int ett_configuration_bEndpointAddress;
+static int ett_endpoint_bmAttributes;
+static int ett_endpoint_wMaxPacketSize;
+static int ett_usb_xferflags;
+static int ett_usb_xferstatus;
+static int ett_usb_frame;
+static int ett_usb_frame_flags;
+static int ett_usbport;
+static int ett_usbport_host_controller;
+static int ett_usbport_path;
+static int ett_usbport_device;
+static int ett_usbport_endpoint;
+static int ett_usbport_endpoint_desc;
+static int ett_usbport_urb;
+static int ett_usbport_keyword;
+static int ett_transfer_flags;
+static int ett_usb20ext_bmAttributes;
+
+static expert_field ei_usb_undecoded;
+static expert_field ei_usb_bLength_even;
+static expert_field ei_usb_bLength_too_short;
+static expert_field ei_usb_desc_length_invalid;
+static expert_field ei_usb_invalid_setup;
+static expert_field ei_usb_ss_ep_companion_before_ep;
+static expert_field ei_usb_usbpcap_unknown_urb;
+static expert_field ei_usb_bad_length;
+static expert_field ei_usb_invalid_max_packet_size;
+static expert_field ei_usb_invalid_max_packet_size0;
+static expert_field ei_usb_invalid_endpoint_type;
+static expert_field ei_usb_unexpected_desc_type;
+
+static expert_field ei_usbport_invalid_path_depth;
static int usb_address_type = -1;
@@ -422,8 +422,8 @@ static int * const usb_usbpcap_info_fields[] = {
NULL
};
-static int usb_tap = -1;
-static gboolean try_heuristics = TRUE;
+static int usb_tap;
+static bool try_heuristics = true;
static dissector_table_t usb_bulk_dissector_table;
static dissector_table_t usb_control_dissector_table;
@@ -434,39 +434,39 @@ static heur_dissector_list_t heur_bulk_subdissector_list;
static heur_dissector_list_t heur_control_subdissector_list;
static heur_dissector_list_t heur_interrupt_subdissector_list;
-static wmem_tree_t *device_to_protocol_table = NULL;
-static wmem_tree_t *device_to_product_table = NULL;
-static wmem_tree_t *usbpcap_setup_data = NULL;
+static wmem_tree_t *device_to_protocol_table;
+static wmem_tree_t *device_to_product_table;
+static wmem_tree_t *usbpcap_setup_data;
static dissector_table_t device_to_dissector;
static dissector_table_t protocol_to_dissector;
static dissector_table_t product_to_dissector;
typedef struct _device_product_data_t {
- guint16 vendor;
- guint16 product;
- guint16 device;
- guint bus_id;
- guint device_address;
+ uint16_t vendor;
+ uint16_t product;
+ uint16_t device;
+ unsigned bus_id;
+ unsigned device_address;
} device_product_data_t;
typedef struct _device_protocol_data_t {
- guint32 protocol;
- guint bus_id;
- guint device_address;
+ uint32_t protocol;
+ unsigned bus_id;
+ unsigned device_address;
} device_protocol_data_t;
typedef struct _usb_alt_setting_t {
- guint8 altSetting;
- guint8 interfaceClass;
- guint8 interfaceSubclass;
- guint8 interfaceProtocol;
- guint8 interfaceNum;
+ uint8_t altSetting;
+ uint8_t interfaceClass;
+ uint8_t interfaceSubclass;
+ uint8_t interfaceProtocol;
+ uint8_t interfaceNum;
} usb_alt_setting_t;
typedef struct {
- guint64 usb_id;
- guint8 setup_data[8];
+ uint64_t usb_id;
+ uint8_t setup_data[8];
} usbpcap_setup_data_t;
static const value_string usb_speed_vals[] = {
@@ -648,6 +648,11 @@ static const value_string usb_class_vals[] = {
{IF_CLASS_VIDEO, "Video"},
{IF_CLASS_PERSONAL_HEALTHCARE, "Personal Healthcare"},
{IF_CLASS_AUDIO_VIDEO, "Audio/Video Devices"},
+ {IF_CLASS_BILLBOARD, "Billboard Device"},
+ {IF_CLASS_USB_C_BRIDGE, "USB Type-C Bridge"},
+ {IF_CLASS_BULK_DISPLAY_PROTO, "USB Bulk Display Protocol Device"},
+ {IF_CLASS_MCTP_USB_EP, "MCTP over USB Protocol Endpoint Device"},
+ {IF_CLASS_I3C, "I3C Device"},
{IF_CLASS_DIAGNOSTIC_DEVICE, "Diagnostic Device"},
{IF_CLASS_WIRELESS_CONTROLLER, "Wireless Controller"},
{IF_CLASS_MISCELLANEOUS, "Miscellaneous"},
@@ -671,7 +676,19 @@ static const value_string usb_protocols[] = {
{0x100100, "AVControl Interface"},
{0x100200, "AVData Video Streaming Interface"},
{0x100300, "AVData Audio Streaming Interface"},
+ {0x140001, "MCTP 1.x - MCTP Management-controller and Managed-Device endpoints"},
+ {0x140002, "MCTP 2.x - MCTP Management-controller and Managed-Device endpoints"},
+ {0x140101, "MCTP 1.x - MCTP Host Interface endpoint"},
+ {0x140102, "MCTP 2.x - MCTP Host Interface endpoint"},
{0xDC0101, "USB2 Compliance Device"},
+ {0xDC0200, "Debug Target vendor defined"},
+ {0xDC0201, "GNU Remote Debug Command Set"},
+ {0xDC0301, "Vendor defined Trace protocol on DbC"},
+ {0xDC0401, "Vendor defined Dfx protocol on DbC"},
+ {0xDC0500, "Vendor defined Trace protocol over General Purpose (GP) endpoint on DvC"},
+ {0xDC0501, "GNU Protocol protocol over General Purpose (GP) endpoint on DvC"},
+ {0xDC0601, "Vendor defined Dfx protocol on DvC"},
+ {0xDC0701, "Vendor defined Trace protocol on DvC"},
{0xE00101, "Bluetooth Programming Interface"},
{0xE00102, "UWB Radio Control Interface"},
{0xE00103, "Remote NDIS"},
@@ -684,6 +701,21 @@ static const value_string usb_protocols[] = {
{0xEF0201, "Interface Association Descriptor"},
{0xEF0202, "Wire Adapter Multifunction Peripheral programming interface"},
{0xEF0301, "Cable Based Association Framework"},
+ {0xEF0401, "RNDIS over Ethernet"},
+ {0xEF0402, "RNDIS over WiFi"},
+ {0xEF0403, "RNDIS over WiMAX"},
+ {0xEF0404, "RNDIS over WWAN"},
+ {0xEF0405, "RNDIS for Raw IPv4"},
+ {0xEF0406, "RNDIS for Raw IPv6"},
+ {0xEF0407, "RNDIS for GPRS"},
+ {0xEF0500, "USB3 Vision Control Interface"},
+ {0xEF0501, "USB3 Vision Event Interface"},
+ {0xEF0502, "USB3 Vision Streaming Interface"},
+ {0xEF0601, "Stream Transport Efficient Protocol for content protection"},
+ {0xEF0602, "Stream Transport Efficient Protocol for Raw content protection"},
+ {0xEF0700, "Command Interface in IAD"},
+ {0xEF0702, "Command Interface in Interface Descriptor"},
+ {0xEF0703, "Media Interface in Interface Descriptor"},
{0xFE0101, "Device Firmware Upgrade"},
{0xFE0200, "IRDA Bridge device"},
{0xFE0300, "USB Test and Measurement Device"},
@@ -1476,7 +1508,7 @@ static const value_string darwin_usb_status_vals[] = {
{0, NULL}
};
-static const guint32 darwin_endpoint_to_linux[] =
+static const uint32_t darwin_endpoint_to_linux[] =
{
URB_CONTROL,
URB_ISOCHRONOUS,
@@ -1725,15 +1757,15 @@ void proto_register_usb(void);
void proto_reg_handoff_usb(void);
/* USB address handling */
-static int usb_addr_to_str(const address* addr, gchar *buf, int buf_len _U_)
+static int usb_addr_to_str(const address* addr, char *buf, int buf_len _U_)
{
- const guint8 *addrp = (const guint8 *)addr->data;
+ const uint8_t *addrp = (const uint8_t *)addr->data;
if(pletoh32(&addrp[0])==0xffffffff){
(void) g_strlcpy(buf, "host", buf_len);
} else {
snprintf(buf, buf_len, "%d.%d.%d", pletoh16(&addrp[8]),
- pletoh32(&addrp[0]), pletoh32(&addrp[4]));
+ pletoh32(&addrp[0]), pletoh32(&addrp[4]) & 0x0f);
}
return (int)(strlen(buf)+1);
@@ -1756,39 +1788,39 @@ static int usb_addr_str_len(const address* addr _U_)
#define USB_DEVICE_PROTOCOL 6
static void
-usb_device_prompt(packet_info *pinfo, gchar* result)
+usb_device_prompt(packet_info *pinfo, char* result)
{
snprintf(result, MAX_DECODE_AS_PROMPT_LEN, "Bus ID %u \nDevice Address %u\nas ",
GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_BUS_ID)),
GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_ADDRESS)));
}
-static gpointer
+static void *
usb_device_value(packet_info *pinfo)
{
- guint32 value = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_BUS_ID)) << 16;
+ uint32_t value = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_BUS_ID)) << 16;
value |= GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_ADDRESS));
return GUINT_TO_POINTER(value);
}
static void
-usb_product_prompt(packet_info *pinfo, gchar* result)
+usb_product_prompt(packet_info *pinfo, char* result)
{
snprintf(result, MAX_DECODE_AS_PROMPT_LEN, "Vendor ID 0x%04x \nProduct ID 0x%04x\nas ",
GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_VENDOR_ID)),
GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_PRODUCT_ID)));
}
-static gpointer
+static void *
usb_product_value(packet_info *pinfo)
{
- guint32 value = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_VENDOR_ID)) << 16;
+ uint32_t value = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_VENDOR_ID)) << 16;
value |= GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_PRODUCT_ID));
return GUINT_TO_POINTER(value);
}
static void
-usb_protocol_prompt(packet_info *pinfo, gchar* result)
+usb_protocol_prompt(packet_info *pinfo, char* result)
{
snprintf(result, MAX_DECODE_AS_PROMPT_LEN, "Class ID 0x%04x \nSubclass ID 0x%04x\nProtocol 0x%04x\nas ",
GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_CLASS)),
@@ -1796,10 +1828,10 @@ usb_protocol_prompt(packet_info *pinfo, gchar* result)
GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_PROTOCOL)));
}
-static gpointer
+static void *
usb_protocol_value(packet_info *pinfo)
{
- guint32 value = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_CLASS)) << 16;
+ uint32_t value = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_CLASS)) << 16;
value |= GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_SUBCLASS)) << 8;
value |= GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_PROTOCOL));
return GUINT_TO_POINTER(value);
@@ -1858,19 +1890,19 @@ get_usb_conv_info(conversation_t *conversation)
}
-/* usb_conv_info_t contains some components that are valid only for one specific packet
+/* urb_info_t contains some components that are valid only for one specific packet
clear_usb_conv_tmp_data() clears these components, it should be called
before we dissect a new packet */
-static void clear_usb_conv_tmp_data(usb_conv_info_t *usb_conv_info)
+static void clear_usb_conv_tmp_data(urb_info_t *urb)
{
- /* caller must have checked that usb_conv_info!= NULL */
+ /* caller must have checked that urb!= NULL */
- usb_conv_info->direction = P2P_DIR_UNKNOWN;
- usb_conv_info->transfer_type = URB_UNKNOWN;
- usb_conv_info->is_request = FALSE;
- usb_conv_info->is_setup = FALSE;
- usb_conv_info->setup_requesttype = 0;
- usb_conv_info->speed = USB_SPEED_UNKNOWN;
+ urb->direction = P2P_DIR_UNKNOWN;
+ urb->transfer_type = URB_UNKNOWN;
+ urb->is_request = false;
+ urb->is_setup = false;
+ urb->setup_requesttype = 0;
+ urb->speed = USB_SPEED_UNKNOWN;
/* when we parse the configuration, interface and endpoint
descriptors, we store the current interface class in endpoint 0's
@@ -1882,17 +1914,17 @@ static void clear_usb_conv_tmp_data(usb_conv_info_t *usb_conv_info)
we used to clear these info in dissect_usb_configuration_descriptor()
this doesn't work when the descriptor parsing throws an exception */
- if (usb_conv_info->endpoint==0) {
- usb_conv_info->interfaceClass = IF_CLASS_UNKNOWN;
- usb_conv_info->interfaceSubclass = IF_SUBCLASS_UNKNOWN;
- usb_conv_info->interfaceProtocol = IF_PROTOCOL_UNKNOWN;
+ if (urb->conv && (urb->endpoint == 0)) {
+ urb->conv->interfaceClass = IF_CLASS_UNKNOWN;
+ urb->conv->interfaceSubclass = IF_SUBCLASS_UNKNOWN;
+ urb->conv->interfaceProtocol = IF_PROTOCOL_UNKNOWN;
}
}
static conversation_t *
get_usb_conversation(packet_info *pinfo,
address *src_addr, address *dst_addr,
- guint32 src_endpoint, guint32 dst_endpoint)
+ uint32_t src_endpoint, uint32_t dst_endpoint)
{
conversation_t *conversation;
@@ -1917,10 +1949,10 @@ get_usb_conversation(packet_info *pinfo,
/* Fetch or create usb_conv_info for a specified interface. */
usb_conv_info_t *
-get_usb_iface_conv_info(packet_info *pinfo, guint8 interface_num)
+get_usb_iface_conv_info(packet_info *pinfo, uint8_t interface_num)
{
conversation_t *conversation;
- guint32 if_port;
+ uint32_t if_port;
if_port = GUINT32_TO_LE(INTERFACE_PORT | interface_num);
@@ -1935,7 +1967,7 @@ get_usb_iface_conv_info(packet_info *pinfo, guint8 interface_num)
/* Fetch usb_conv_info for specified endpoint, return NULL if not found */
usb_conv_info_t *
-get_existing_usb_ep_conv_info(packet_info* pinfo, guint16 bus_id, guint16 device_address, int endpoint)
+get_existing_usb_ep_conv_info(packet_info* pinfo, uint16_t bus_id, uint16_t device_address, int endpoint)
{
usb_address_t *src_addr = wmem_new0(pinfo->pool, usb_address_t),
*dst_addr = wmem_new0(pinfo->pool, usb_address_t);
@@ -1999,7 +2031,7 @@ static const char* usb_endpoint_get_filter_type(endpoint_item_t* endpoint, conv_
}
static const char*
-usb_col_filter_str(const address* addr _U_, gboolean is_src)
+usb_col_filter_str(const address* addr _U_, bool is_src)
{
return is_src ? "usb.src" : "usb.dst";
}
@@ -2015,8 +2047,8 @@ usb_endpoint_packet(void *pit, packet_info *pinfo, epan_dissect_t *edt _U_, cons
/* Take two "add" passes per packet, adding for each direction, ensures that all
packets are counted properly (even if address is sending to itself)
XXX - this could probably be done more efficiently inside endpoint_table */
- add_endpoint_table_data(hash, &pinfo->src, 0, TRUE, 1, pinfo->fd->pkt_len, &usb_endpoint_dissector_info, ENDPOINT_NONE);
- add_endpoint_table_data(hash, &pinfo->dst, 0, FALSE, 1, pinfo->fd->pkt_len, &usb_endpoint_dissector_info, ENDPOINT_NONE);
+ add_endpoint_table_data(hash, &pinfo->src, 0, true, 1, pinfo->fd->pkt_len, &usb_endpoint_dissector_info, ENDPOINT_NONE);
+ add_endpoint_table_data(hash, &pinfo->dst, 0, false, 1, pinfo->fd->pkt_len, &usb_endpoint_dissector_info, ENDPOINT_NONE);
return TAP_PACKET_REDRAW;
}
@@ -2034,12 +2066,12 @@ usb_endpoint_packet(void *pit, packet_info *pinfo, epan_dissect_t *edt _U_, cons
static int
dissect_usb_setup_clear_feature_request(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
- guint8 recip;
+ uint8_t recip;
- if (usb_conv_info) {
- recip = USB_RECIPIENT(usb_conv_info->usb_trans_info->setup.requesttype);
+ if (urb) {
+ recip = USB_RECIPIENT(urb->usb_trans_info->setup.requesttype);
/* feature selector, zero/interface/endpoint */
switch (recip) {
@@ -2086,7 +2118,7 @@ dissect_usb_setup_clear_feature_request(packet_info *pinfo _U_, proto_tree *tree
static int
dissect_usb_setup_clear_feature_response(packet_info *pinfo _U_, proto_tree *tree _U_,
tvbuff_t *tvb _U_, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
return offset;
}
@@ -2102,7 +2134,7 @@ dissect_usb_setup_clear_feature_response(packet_info *pinfo _U_, proto_tree *tre
static int
dissect_usb_setup_get_configuration_response(packet_info *pinfo _U_, proto_tree *tree _U_,
tvbuff_t *tvb _U_, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
proto_tree_add_item(tree, hf_usb_bConfigurationValue, tvb, offset, 1, ENC_LITTLE_ENDIAN);
offset += 1;
@@ -2120,7 +2152,7 @@ proto_item * dissect_usb_descriptor_header(proto_tree *tree,
tvbuff_t *tvb, int offset,
value_string_ext *type_val_str)
{
- guint8 desc_type;
+ uint8_t desc_type;
proto_item *length_item;
@@ -2128,7 +2160,7 @@ proto_item * dissect_usb_descriptor_header(proto_tree *tree,
tvb, offset, 1, ENC_LITTLE_ENDIAN);
offset++;
- desc_type = tvb_get_guint8(tvb, offset);
+ desc_type = tvb_get_uint8(tvb, offset);
/* if the caller provided no class specific value string, we're
* using the standard descriptor types */
if (!type_val_str)
@@ -2144,12 +2176,12 @@ proto_item * dissect_usb_descriptor_header(proto_tree *tree,
static void
dissect_max_packet_size0(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info, gboolean other_speed)
+ urb_info_t *urb, bool other_speed)
{
proto_item *item;
- guint32 max_packet_size;
+ uint32_t max_packet_size;
unsigned int sanitized_max_packet_size;
- usb_speed_t speed = usb_conv_info->speed;
+ usb_speed_t speed = urb->speed;
item = proto_tree_add_item_ret_uint(tree, hf_usb_bMaxPacketSize0, tvb, offset, 1, ENC_LITTLE_ENDIAN, &max_packet_size);
if (other_speed) {
@@ -2170,14 +2202,14 @@ dissect_max_packet_size0(packet_info *pinfo, proto_tree *tree,
static int
dissect_usb_device_qualifier_descriptor(packet_info *pinfo, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
proto_item *item;
proto_tree *tree;
proto_item *nitem;
int old_offset = offset;
- guint32 protocol;
- const gchar *description;
+ uint32_t protocol;
+ const char *description;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "DEVICE QUALIFIER DESCRIPTOR");
@@ -2206,15 +2238,15 @@ dissect_usb_device_qualifier_descriptor(packet_info *pinfo, proto_tree *parent_t
offset += 1;
if (!pinfo->fd->visited) {
- guint k_bus_id;
- guint k_device_address;
- guint k_frame_number;
+ unsigned k_bus_id;
+ unsigned k_device_address;
+ unsigned k_frame_number;
wmem_tree_key_t key[4];
device_protocol_data_t *device_protocol_data;
k_frame_number = pinfo->num;
- k_device_address = usb_conv_info->device_address;
- k_bus_id = usb_conv_info->bus_id;
+ k_device_address = urb->device_address;
+ k_bus_id = urb->bus_id;
key[0].length = 1;
key[0].key = &k_device_address;
@@ -2227,13 +2259,13 @@ dissect_usb_device_qualifier_descriptor(packet_info *pinfo, proto_tree *parent_t
device_protocol_data = wmem_new(wmem_file_scope(), device_protocol_data_t);
device_protocol_data->protocol = protocol;
- device_protocol_data->bus_id = usb_conv_info->bus_id;
- device_protocol_data->device_address = usb_conv_info->device_address;
+ device_protocol_data->bus_id = urb->bus_id;
+ device_protocol_data->device_address = urb->device_address;
wmem_tree_insert32_array(device_to_protocol_table, key, device_protocol_data);
}
/* bMaxPacketSize0 */
- dissect_max_packet_size0(pinfo, tree, tvb, offset, usb_conv_info, TRUE);
+ dissect_max_packet_size0(pinfo, tree, tvb, offset, urb, true);
offset += 1;
/* bNumConfigurations */
@@ -2252,17 +2284,17 @@ dissect_usb_device_qualifier_descriptor(packet_info *pinfo, proto_tree *parent_t
static int
dissect_usb_device_descriptor(packet_info *pinfo, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
proto_item *item;
proto_tree *tree;
proto_item *nitem;
int old_offset = offset;
- guint32 protocol;
- const gchar *description;
- guint32 vendor_id;
- guint32 product;
- guint16 product_id;
+ uint32_t protocol;
+ const char *description;
+ uint32_t vendor_id;
+ uint32_t product;
+ uint16_t product_id;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "DEVICE DESCRIPTOR");
@@ -2291,25 +2323,25 @@ dissect_usb_device_descriptor(packet_info *pinfo, proto_tree *parent_tree,
offset += 1;
/* bMaxPacketSize0 */
- dissect_max_packet_size0(pinfo, tree, tvb, offset, usb_conv_info, FALSE);
+ dissect_max_packet_size0(pinfo, tree, tvb, offset, urb, false);
offset += 1;
/* if request was only for the first 8 bytes */
/* per 5.5.3 of USB2.0 Spec */
- if (8 == usb_conv_info->usb_trans_info->setup.wLength) {
+ if (8 == urb->usb_trans_info->setup.wLength) {
proto_item_set_len(item, offset-old_offset);
return offset;
}
/* idVendor */
proto_tree_add_item_ret_uint(tree, hf_usb_idVendor, tvb, offset, 2, ENC_LITTLE_ENDIAN, &vendor_id);
- usb_conv_info->deviceVendor = (guint16)vendor_id;
+ urb->conv->deviceVendor = (uint16_t)vendor_id;
offset += 2;
/* idProduct */
product_id = tvb_get_letohs(tvb, offset);
- usb_conv_info->deviceProduct = product_id;
- product = (guint16)vendor_id << 16 | product_id;
+ urb->conv->deviceProduct = product_id;
+ product = (uint16_t)vendor_id << 16 | product_id;
proto_tree_add_uint_format_value(tree, hf_usb_idProduct, tvb, offset, 2, product_id, "%s (0x%04x)",
val_to_str_ext_const(product, &ext_usb_products_vals, "Unknown"),
@@ -2317,21 +2349,21 @@ dissect_usb_device_descriptor(packet_info *pinfo, proto_tree *parent_tree,
offset += 2;
/* bcdDevice */
- usb_conv_info->deviceVersion = tvb_get_letohs(tvb, offset);
+ urb->conv->deviceVersion = tvb_get_letohs(tvb, offset);
proto_tree_add_item(tree, hf_usb_bcdDevice, tvb, offset, 2, ENC_LITTLE_ENDIAN);
offset += 2;
if (!pinfo->fd->visited) {
- guint k_bus_id;
- guint k_device_address;
- guint k_frame_number;
+ unsigned k_bus_id;
+ unsigned k_device_address;
+ unsigned k_frame_number;
wmem_tree_key_t key[4];
device_product_data_t *device_product_data;
device_protocol_data_t *device_protocol_data;
k_frame_number = pinfo->num;
- k_device_address = usb_conv_info->device_address;
- k_bus_id = usb_conv_info->bus_id;
+ k_device_address = urb->device_address;
+ k_bus_id = urb->bus_id;
key[0].length = 1;
key[0].key = &k_device_address;
@@ -2345,15 +2377,15 @@ dissect_usb_device_descriptor(packet_info *pinfo, proto_tree *parent_tree,
device_product_data = wmem_new(wmem_file_scope(), device_product_data_t);
device_product_data->vendor = vendor_id;
device_product_data->product = product_id;
- device_product_data->device = usb_conv_info->deviceVersion;
- device_product_data->bus_id = usb_conv_info->bus_id;
- device_product_data->device_address = usb_conv_info->device_address;
+ device_product_data->device = urb->conv->deviceVersion;
+ device_product_data->bus_id = urb->bus_id;
+ device_product_data->device_address = urb->device_address;
wmem_tree_insert32_array(device_to_product_table, key, device_product_data);
device_protocol_data = wmem_new(wmem_file_scope(), device_protocol_data_t);
device_protocol_data->protocol = protocol;
- device_protocol_data->bus_id = usb_conv_info->bus_id;
- device_protocol_data->device_address = usb_conv_info->device_address;
+ device_protocol_data->bus_id = urb->bus_id;
+ device_protocol_data->device_address = urb->device_address;
wmem_tree_insert32_array(device_to_protocol_table, key, device_protocol_data);
}
@@ -2367,7 +2399,7 @@ dissect_usb_device_descriptor(packet_info *pinfo, proto_tree *parent_tree,
offset += 1;
/* iSerialNumber */
- usb_conv_info->iSerialNumber = tvb_get_guint8(tvb, offset);
+ urb->conv->iSerialNumber = tvb_get_uint8(tvb, offset);
proto_tree_add_item(tree, hf_usb_iSerialNumber, tvb, offset, 1, ENC_LITTLE_ENDIAN);
offset += 1;
@@ -2384,20 +2416,20 @@ dissect_usb_device_descriptor(packet_info *pinfo, proto_tree *parent_tree,
static int
dissect_usb_string_descriptor(packet_info *pinfo _U_, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
proto_item *item;
proto_tree *tree;
int old_offset = offset;
- guint8 len;
+ uint8_t len;
proto_item *len_item;
usb_trans_info_t *usb_trans_info;
- usb_trans_info = usb_conv_info->usb_trans_info;
+ usb_trans_info = urb->usb_trans_info;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "STRING DESCRIPTOR");
- len = tvb_get_guint8(tvb, offset);
+ len = tvb_get_uint8(tvb, offset);
/* The USB spec says that the languages / the string are UTF16 and not
0-terminated, i.e. the length field must contain an even number */
if (len & 0x1) {
@@ -2419,7 +2451,7 @@ dissect_usb_string_descriptor(packet_info *pinfo _U_, proto_tree *parent_tree,
}
if (!usb_trans_info->u.get_descriptor.usb_index) {
- /* list of languanges */
+ /* list of languages */
while (offset >= old_offset && len > (offset - old_offset)) {
/* wLANGID */
proto_tree_add_item(tree, hf_usb_wLANGID, tvb, offset, 2, ENC_LITTLE_ENDIAN);
@@ -2428,7 +2460,7 @@ dissect_usb_string_descriptor(packet_info *pinfo _U_, proto_tree *parent_tree,
} else {
/* UTF-16 string */
/* handle case of host requesting only substring */
- guint8 len_str = MIN(len-2, usb_trans_info->setup.wLength -2);
+ uint8_t len_str = MIN(len-2, usb_trans_info->setup.wLength -2);
proto_tree_add_item(tree, hf_usb_bString, tvb, offset, len_str, ENC_UTF_16 | ENC_LITTLE_ENDIAN);
offset += len_str;
}
@@ -2444,33 +2476,33 @@ dissect_usb_string_descriptor(packet_info *pinfo _U_, proto_tree *parent_tree,
static int
dissect_usb_interface_descriptor(packet_info *pinfo, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
proto_item *item;
proto_tree *tree;
const char *class_str = NULL;
int old_offset = offset;
- guint8 len;
- guint8 interface_num;
- guint8 alt_setting;
+ uint8_t len;
+ uint8_t interface_num;
+ uint8_t alt_setting;
usb_trans_info_t *usb_trans_info;
- usb_trans_info = usb_conv_info->usb_trans_info;
+ usb_trans_info = urb->usb_trans_info;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "INTERFACE DESCRIPTOR");
- len = tvb_get_guint8(tvb, offset);
+ len = tvb_get_uint8(tvb, offset);
dissect_usb_descriptor_header(tree, tvb, offset, NULL);
offset += 2;
/* bInterfaceNumber */
- interface_num = tvb_get_guint8(tvb, offset);
+ interface_num = tvb_get_uint8(tvb, offset);
proto_tree_add_item(tree, hf_usb_bInterfaceNumber, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- usb_conv_info->interfaceNum = interface_num;
+ urb->conv->interfaceNum = interface_num;
offset += 1;
/* bAlternateSetting */
- alt_setting = tvb_get_guint8(tvb, offset);
+ alt_setting = tvb_get_uint8(tvb, offset);
proto_tree_add_item(tree, hf_usb_bAlternateSetting, tvb, offset, 1, ENC_LITTLE_ENDIAN);
offset += 1;
@@ -2481,9 +2513,9 @@ dissect_usb_interface_descriptor(packet_info *pinfo, proto_tree *parent_tree,
/* bInterfaceClass */
proto_tree_add_item(tree, hf_usb_bInterfaceClass, tvb, offset, 1, ENC_LITTLE_ENDIAN);
/* save the class so we can access it later in the endpoint descriptor */
- usb_conv_info->interfaceClass = tvb_get_guint8(tvb, offset);
+ urb->conv->interfaceClass = tvb_get_uint8(tvb, offset);
- class_str = val_to_str_ext(usb_conv_info->interfaceClass, &usb_class_vals_ext, "unknown (0x%X)");
+ class_str = val_to_str_ext(urb->conv->interfaceClass, &usb_class_vals_ext, "unknown (0x%X)");
proto_item_append_text(item, " (%u.%u): class %s", interface_num, alt_setting, class_str);
if (!pinfo->fd->visited) {
@@ -2491,35 +2523,30 @@ dissect_usb_interface_descriptor(packet_info *pinfo, proto_tree *parent_tree,
/* Register conversation for this interface in case CONTROL messages are sent to it */
usb_trans_info->interface_info = get_usb_iface_conv_info(pinfo, interface_num);
- usb_trans_info->interface_info->bus_id = usb_conv_info->bus_id;
- usb_trans_info->interface_info->device_address = usb_conv_info->device_address;
alternate_setting.altSetting = alt_setting;
- alternate_setting.interfaceClass = tvb_get_guint8(tvb, offset);
- alternate_setting.interfaceSubclass = tvb_get_guint8(tvb, offset+1);
- alternate_setting.interfaceProtocol = tvb_get_guint8(tvb, offset+2);
+ alternate_setting.interfaceClass = tvb_get_uint8(tvb, offset);
+ alternate_setting.interfaceSubclass = tvb_get_uint8(tvb, offset+1);
+ alternate_setting.interfaceProtocol = tvb_get_uint8(tvb, offset+2);
alternate_setting.interfaceNum = interface_num;
wmem_array_append_one(usb_trans_info->interface_info->alt_settings, alternate_setting);
if (alt_setting == 0) {
/* By default let's assume alternate setting 0 will be used */
- /* in interface conversations, endpoint has no meaning */
- usb_trans_info->interface_info->endpoint = NO_ENDPOINT8;
-
usb_trans_info->interface_info->interfaceClass = alternate_setting.interfaceClass;
usb_trans_info->interface_info->interfaceSubclass = alternate_setting.interfaceSubclass;
usb_trans_info->interface_info->interfaceProtocol = alternate_setting.interfaceProtocol;
usb_trans_info->interface_info->interfaceNum = alternate_setting.interfaceNum;
- usb_trans_info->interface_info->deviceVendor = usb_conv_info->deviceVendor;
- usb_trans_info->interface_info->deviceProduct = usb_conv_info->deviceProduct;
- usb_trans_info->interface_info->deviceVersion = usb_conv_info->deviceVersion;
+ usb_trans_info->interface_info->deviceVendor = urb->conv->deviceVendor;
+ usb_trans_info->interface_info->deviceProduct = urb->conv->deviceProduct;
+ usb_trans_info->interface_info->deviceVersion = urb->conv->deviceVersion;
}
}
offset += 1;
/* bInterfaceSubClass */
- switch (usb_conv_info->interfaceClass) {
+ switch (urb->conv->interfaceClass) {
case IF_CLASS_AUDIO:
proto_tree_add_item(tree, hf_usb_bInterfaceSubClass_audio, tvb, offset, 1, ENC_LITTLE_ENDIAN);
break;
@@ -2543,11 +2570,11 @@ dissect_usb_interface_descriptor(packet_info *pinfo, proto_tree *parent_tree,
}
/* save the subclass so we can access it later in class-specific descriptors */
- usb_conv_info->interfaceSubclass = tvb_get_guint8(tvb, offset);
+ urb->conv->interfaceSubclass = tvb_get_uint8(tvb, offset);
offset += 1;
/* bInterfaceProtocol */
- switch (usb_conv_info->interfaceClass) {
+ switch (urb->conv->interfaceClass) {
case IF_CLASS_COMMUNICATIONS:
proto_tree_add_item(tree, hf_usb_bInterfaceProtocol_cdc, tvb, offset, 1, ENC_LITTLE_ENDIAN);
break;
@@ -2558,7 +2585,7 @@ dissect_usb_interface_descriptor(packet_info *pinfo, proto_tree *parent_tree,
proto_tree_add_item(tree, hf_usb_bInterfaceProtocol_cdc_data, tvb, offset, 1, ENC_LITTLE_ENDIAN);
break;
case IF_CLASS_APPLICATION_SPECIFIC:
- switch (usb_conv_info->interfaceSubclass) {
+ switch (urb->conv->interfaceSubclass) {
case 0x01:
proto_tree_add_item(tree, hf_usb_bInterfaceProtocol_app_dfu, tvb, offset, 1, ENC_LITTLE_ENDIAN);
break;
@@ -2573,7 +2600,7 @@ dissect_usb_interface_descriptor(packet_info *pinfo, proto_tree *parent_tree,
}
break;
case IF_CLASS_HID:
- if (usb_conv_info->interfaceSubclass == 1) {
+ if (urb->conv->interfaceSubclass == 1) {
proto_tree_add_item(tree, hf_usb_bInterfaceProtocol_hid_boot, tvb, offset, 1, ENC_LITTLE_ENDIAN);
break;
}
@@ -2585,7 +2612,7 @@ dissect_usb_interface_descriptor(packet_info *pinfo, proto_tree *parent_tree,
proto_tree_add_item(tree, hf_usb_bInterfaceProtocol, tvb, offset, 1, ENC_LITTLE_ENDIAN);
}
- usb_conv_info->interfaceProtocol = tvb_get_guint8(tvb, offset);
+ urb->conv->interfaceProtocol = tvb_get_uint8(tvb, offset);
offset += 1;
/* iInterface */
@@ -2612,33 +2639,35 @@ void dissect_usb_endpoint_address(proto_tree *tree, tvbuff_t *tvb, int offset)
{
proto_item *endpoint_item;
proto_tree *endpoint_tree;
- guint8 endpoint;
+ uint8_t endpoint;
endpoint_item = proto_tree_add_item(tree, hf_usb_bEndpointAddress, tvb, offset, 1, ENC_LITTLE_ENDIAN);
endpoint_tree = proto_item_add_subtree(endpoint_item, ett_configuration_bEndpointAddress);
- endpoint = tvb_get_guint8(tvb, offset)&0x0f;
+ endpoint = tvb_get_uint8(tvb, offset);
proto_tree_add_item(endpoint_tree, hf_usb_bEndpointAddress_direction, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- proto_item_append_text(endpoint_item, " %s", (tvb_get_guint8(tvb, offset)&0x80)?"IN":"OUT");
+ proto_item_append_text(endpoint_item, " %s", (endpoint&0x80)?"IN":"OUT");
proto_tree_add_item(endpoint_tree, hf_usb_bEndpointAddress_number, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- proto_item_append_text(endpoint_item, " Endpoint:%d", endpoint);
+ proto_item_append_text(endpoint_item, " Endpoint:%d", endpoint&0x0f);
}
unsigned int
-sanitize_usb_max_packet_size(guint8 ep_type, usb_speed_t speed,
+sanitize_usb_max_packet_size(uint8_t ep_type, usb_speed_t speed,
unsigned int max_packet_size)
{
- unsigned int sanitized = max_packet_size;
+ unsigned int sanitized_ep_size = USB_MPS_EP_SIZE(max_packet_size);
+ unsigned int sanitized_adtnl = USB_MPS_ADDNL(max_packet_size);
switch (speed) {
case USB_SPEED_LOW:
+ sanitized_adtnl = 0;
switch (ep_type) {
case ENDPOINT_TYPE_CONTROL:
/* 8 is the only allowed value */
- sanitized = 8;
+ sanitized_ep_size = 8;
break;
case ENDPOINT_TYPE_INTERRUPT:
if (max_packet_size > 8)
- sanitized = 8;
+ sanitized_ep_size = 8;
break;
default:
/* Not allowed */
@@ -2646,26 +2675,27 @@ sanitize_usb_max_packet_size(guint8 ep_type, usb_speed_t speed,
}
break;
case USB_SPEED_FULL:
+ sanitized_adtnl = 0;
switch (ep_type) {
case ENDPOINT_TYPE_CONTROL:
case ENDPOINT_TYPE_BULK:
/* Allowed values are: 8, 16, 32 and 64 */
if (max_packet_size > 32)
- sanitized = 64;
+ sanitized_ep_size = 64;
else if (max_packet_size > 16)
- sanitized = 32;
+ sanitized_ep_size = 32;
else if (max_packet_size > 8)
- sanitized = 16;
+ sanitized_ep_size = 16;
else
- sanitized = 8;
+ sanitized_ep_size = 8;
break;
case ENDPOINT_TYPE_INTERRUPT:
if (max_packet_size > 64)
- sanitized = 64;
+ sanitized_ep_size = 64;
break;
case ENDPOINT_TYPE_ISOCHRONOUS:
if (max_packet_size > 1023)
- sanitized = 1023;
+ sanitized_ep_size = 1023;
break;
default:
break;
@@ -2674,17 +2704,26 @@ sanitize_usb_max_packet_size(guint8 ep_type, usb_speed_t speed,
case USB_SPEED_HIGH:
switch (ep_type) {
case ENDPOINT_TYPE_CONTROL:
+ sanitized_adtnl = 0;
/* 64 is the only allowed value */
- sanitized = 64;
+ sanitized_ep_size = 64;
break;
case ENDPOINT_TYPE_BULK:
+ sanitized_adtnl = 0;
/* 512 is the only allowed value */
- sanitized = 512;
+ sanitized_ep_size = 512;
break;
case ENDPOINT_TYPE_INTERRUPT:
case ENDPOINT_TYPE_ISOCHRONOUS:
+ /* If endpoint max packet size is out of range for high-bandwidth
+ * endpoint, treat the endpoint as a standard one.
+ */
+ if ((sanitized_adtnl > 2) ||
+ ((sanitized_adtnl == 2) && (max_packet_size < 683)) ||
+ ((sanitized_adtnl == 1) && (max_packet_size < 513)))
+ sanitized_adtnl = 0;
if (max_packet_size > 1024)
- sanitized = 1024;
+ sanitized_ep_size = 1024;
break;
default:
break;
@@ -2695,14 +2734,27 @@ sanitize_usb_max_packet_size(guint8 ep_type, usb_speed_t speed,
break;
}
- return sanitized;
+ return USB_MPS(sanitized_ep_size, sanitized_adtnl);
+}
+
+static char *usb_max_packet_size_str(unsigned int max_packet_size)
+{
+ unsigned int ep_size = USB_MPS_EP_SIZE(max_packet_size);
+ unsigned int addnl = USB_MPS_ADDNL(max_packet_size);
+
+ if (addnl == 1 || addnl == 2) {
+ return wmem_strdup_printf(wmem_packet_scope(), "%u * %u = %u",
+ addnl + 1, ep_size, (addnl + 1) * ep_size);
+ } else {
+ return wmem_strdup_printf(wmem_packet_scope(), "%u", ep_size);
+ }
}
int
dissect_usb_endpoint_descriptor(packet_info *pinfo, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info,
- guint8 *out_ep_type, usb_speed_t speed)
+ urb_info_t *urb,
+ uint8_t *out_ep_type, usb_speed_t speed)
{
proto_item *item;
proto_tree *tree;
@@ -2712,24 +2764,25 @@ dissect_usb_endpoint_descriptor(packet_info *pinfo, proto_tree *parent_tree,
proto_item *ep_pktsize_item;
proto_tree *ep_pktsize_tree;
int old_offset = offset;
- guint8 endpoint;
- guint8 ep_type;
- guint8 len;
- guint32 max_packet_size;
+ uint8_t endpoint;
+ uint8_t ep_type;
+ uint8_t len;
+ uint32_t max_packet_size;
+ char *max_packet_size_str;
unsigned int sanitized_max_packet_size;
usb_trans_info_t *usb_trans_info = NULL;
conversation_t *conversation = NULL;
- if (usb_conv_info)
- usb_trans_info = usb_conv_info->usb_trans_info;
+ if (urb)
+ usb_trans_info = urb->usb_trans_info;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "ENDPOINT DESCRIPTOR");
- len = tvb_get_guint8(tvb, offset);
+ len = tvb_get_uint8(tvb, offset);
dissect_usb_descriptor_header(tree, tvb, offset, NULL);
offset += 2;
- endpoint = tvb_get_guint8(tvb, offset)&0x0f;
+ endpoint = tvb_get_uint8(tvb, offset);
dissect_usb_endpoint_address(tree, tvb, offset);
offset += 1;
@@ -2758,13 +2811,13 @@ dissect_usb_endpoint_descriptor(packet_info *pinfo, proto_tree *parent_tree,
}
if (conversation) {
- usb_trans_info->interface_info->endpoint = endpoint;
+ usb_trans_info->interface_endpoint = endpoint;
conversation_add_proto_data(conversation, proto_usb, usb_trans_info->interface_info);
}
}
/* bmAttributes */
- ep_type = ENDPOINT_TYPE(tvb_get_guint8(tvb, offset));
+ ep_type = ENDPOINT_TYPE(tvb_get_uint8(tvb, offset));
if (out_ep_type) {
*out_ep_type = ep_type;
}
@@ -2785,25 +2838,28 @@ dissect_usb_endpoint_descriptor(packet_info *pinfo, proto_tree *parent_tree,
offset += 1;
/* wMaxPacketSize */
- ep_pktsize_item = proto_tree_add_item(tree, hf_usb_wMaxPacketSize, tvb, offset, 2, ENC_LITTLE_ENDIAN);
+ max_packet_size = tvb_get_uint16(tvb, offset, ENC_LITTLE_ENDIAN);
+ max_packet_size_str = usb_max_packet_size_str(max_packet_size);
+ ep_pktsize_item = proto_tree_add_uint_format_value(tree, hf_usb_wMaxPacketSize,
+ tvb, offset, 2, max_packet_size, "%s", max_packet_size_str);
ep_pktsize_tree = proto_item_add_subtree(ep_pktsize_item, ett_endpoint_wMaxPacketSize);
if ((ep_type == ENDPOINT_TYPE_INTERRUPT) || (ep_type == ENDPOINT_TYPE_ISOCHRONOUS)) {
proto_tree_add_item(ep_pktsize_tree, hf_usb_wMaxPacketSize_slots, tvb, offset, 2, ENC_LITTLE_ENDIAN);
}
- proto_tree_add_item_ret_uint(ep_pktsize_tree, hf_usb_wMaxPacketSize_size, tvb, offset, 2, ENC_LITTLE_ENDIAN, &max_packet_size);
+ proto_tree_add_item(ep_pktsize_tree, hf_usb_wMaxPacketSize_size, tvb, offset, 2, ENC_LITTLE_ENDIAN);
sanitized_max_packet_size = sanitize_usb_max_packet_size(ep_type, speed, max_packet_size);
if (sanitized_max_packet_size != max_packet_size) {
expert_add_info_format(pinfo, ep_pktsize_item, &ei_usb_invalid_max_packet_size,
- "%s %s endpoint max packet size cannot be %u, using %d instead.",
+ "%s %s endpoint max packet size cannot be %s, using %s instead.",
try_val_to_str(speed, usb_speed_vals), try_val_to_str(ep_type, usb_bmAttributes_transfer_vals),
- max_packet_size, sanitized_max_packet_size);
+ max_packet_size_str, usb_max_packet_size_str(sanitized_max_packet_size));
max_packet_size = sanitized_max_packet_size;
}
offset+=2;
if (conversation) {
usb_conv_info_t* endpoint_conv_info = get_usb_conv_info(conversation);
- guint8 transfer_type;
+ uint8_t transfer_type;
switch(ep_type) {
case ENDPOINT_TYPE_CONTROL:
@@ -2832,7 +2888,7 @@ dissect_usb_endpoint_descriptor(packet_info *pinfo, proto_tree *parent_tree,
/* bRefresh and bSynchAddress are present only in the Audio 1.0
* Endpoint Descriptors, so observe the descriptor size */
- if (usb_conv_info && (usb_conv_info->interfaceClass == IF_CLASS_AUDIO)
+ if (urb && urb->conv && (urb->conv->interfaceClass == IF_CLASS_AUDIO)
&& (len >= 9)) {
proto_tree_add_item(tree, hf_usb_audio_bRefresh, tvb, offset, 1, ENC_LITTLE_ENDIAN);
offset += 1;
@@ -2855,19 +2911,19 @@ dissect_usb_endpoint_descriptor(packet_info *pinfo, proto_tree *parent_tree,
static int
dissect_usb_endpoint_companion_descriptor(packet_info *pinfo, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_,
- guint8 ep_type)
+ urb_info_t *urb _U_,
+ uint8_t ep_type)
{
proto_item *item;
proto_tree *tree;
proto_item *ep_attrib_item;
proto_tree *ep_attrib_tree;
int old_offset = offset;
- guint8 len;
+ uint8_t len;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "SUPERSPEED ENDPOINT COMPANION DESCRIPTOR");
- len = tvb_get_guint8(tvb, offset);
+ len = tvb_get_uint8(tvb, offset);
dissect_usb_descriptor_header(tree, tvb, offset, NULL);
offset += 2;
@@ -2915,7 +2971,7 @@ dissect_usb_endpoint_companion_descriptor(packet_info *pinfo, proto_tree *parent
static int
dissect_usb_interface_assn_descriptor(packet_info *pinfo _U_, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
proto_item *item;
proto_tree *tree;
@@ -2958,15 +3014,15 @@ dissect_usb_interface_assn_descriptor(packet_info *pinfo _U_, proto_tree *parent
int
dissect_usb_unknown_descriptor(packet_info *pinfo _U_, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
proto_item *item;
proto_tree *tree;
- guint8 bLength;
+ uint8_t bLength;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "UNKNOWN DESCRIPTOR");
- bLength = tvb_get_guint8(tvb, offset);
+ bLength = tvb_get_uint8(tvb, offset);
dissect_usb_descriptor_header(tree, tvb, offset, NULL);
offset += bLength;
@@ -2991,26 +3047,26 @@ static const true_false_string tfs_remotewakeup = {
static int
dissect_usb_configuration_descriptor(packet_info *pinfo _U_, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info, usb_speed_t speed)
+ urb_info_t *urb, usb_speed_t speed)
{
proto_item *item;
proto_tree *tree;
int old_offset = offset;
- guint16 len;
+ uint16_t len;
proto_item *flags_item;
proto_tree *flags_tree;
- guint8 flags;
- guint8 last_ep_type = ENDPOINT_TYPE_NOT_SET;
+ uint8_t flags;
+ uint8_t last_ep_type = ENDPOINT_TYPE_NOT_SET;
proto_item *power_item;
- guint8 power;
- gboolean truncation_expected;
+ uint8_t power;
+ bool truncation_expected;
usb_trans_info_t *usb_trans_info;
- usb_trans_info = usb_conv_info->usb_trans_info;
+ usb_trans_info = urb->usb_trans_info;
- usb_conv_info->interfaceClass = IF_CLASS_UNKNOWN;
- usb_conv_info->interfaceSubclass = IF_SUBCLASS_UNKNOWN;
- usb_conv_info->interfaceProtocol = IF_PROTOCOL_UNKNOWN;
+ urb->conv->interfaceClass = IF_CLASS_UNKNOWN;
+ urb->conv->interfaceSubclass = IF_SUBCLASS_UNKNOWN;
+ urb->conv->interfaceProtocol = IF_PROTOCOL_UNKNOWN;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "CONFIGURATION DESCRIPTOR");
@@ -3038,7 +3094,7 @@ dissect_usb_configuration_descriptor(packet_info *pinfo _U_, proto_tree *parent_
flags_item = proto_tree_add_item(tree, hf_usb_configuration_bmAttributes, tvb, offset, 1, ENC_LITTLE_ENDIAN);
flags_tree = proto_item_add_subtree(flags_item, ett_configuration_bmAttributes);
- flags = tvb_get_guint8(tvb, offset);
+ flags = tvb_get_uint8(tvb, offset);
proto_tree_add_item(flags_tree, hf_usb_configuration_legacy10buspowered, tvb, offset, 1, ENC_LITTLE_ENDIAN);
proto_tree_add_item(flags_tree, hf_usb_configuration_selfpowered, tvb, offset, 1, ENC_LITTLE_ENDIAN);
proto_item_append_text(flags_item, " %sSELF-POWERED", (flags&0x40)?"":"NOT ");
@@ -3048,7 +3104,7 @@ dissect_usb_configuration_descriptor(packet_info *pinfo _U_, proto_tree *parent_
/* bMaxPower */
power_item = proto_tree_add_item(tree, hf_usb_bMaxPower, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- power = tvb_get_guint8(tvb, offset);
+ power = tvb_get_uint8(tvb, offset);
proto_item_append_text(power_item, " (%dmA)", power*2);
offset += 1;
@@ -3059,15 +3115,15 @@ dissect_usb_configuration_descriptor(packet_info *pinfo _U_, proto_tree *parent_
/* decode any additional interface and endpoint descriptors */
while(len>(offset-old_offset)) {
- guint8 next_type;
- guint8 next_len = 0;
- gint remaining_tvb, remaining_len;
+ uint8_t next_type;
+ uint8_t next_len = 0;
+ int remaining_tvb, remaining_len;
tvbuff_t *next_tvb = NULL;
/* Handle truncated descriptors appropriately */
remaining_tvb = tvb_reported_length_remaining(tvb, offset);
if (remaining_tvb > 0) {
- next_len = tvb_get_guint8(tvb, offset);
+ next_len = tvb_get_uint8(tvb, offset);
remaining_len = len - (offset - old_offset);
if ((next_len < 3) || (next_len > remaining_len)) {
proto_tree_add_expert_format(parent_tree, pinfo, &ei_usb_desc_length_invalid,
@@ -3082,26 +3138,26 @@ dissect_usb_configuration_descriptor(packet_info *pinfo _U_, proto_tree *parent_
break;
}
- next_type = tvb_get_guint8(tvb, offset+1);
+ next_type = tvb_get_uint8(tvb, offset+1);
switch(next_type) {
case USB_DT_INTERFACE:
- offset = dissect_usb_interface_descriptor(pinfo, parent_tree, tvb, offset, usb_conv_info);
+ offset = dissect_usb_interface_descriptor(pinfo, parent_tree, tvb, offset, urb);
break;
case USB_DT_ENDPOINT:
- offset = dissect_usb_endpoint_descriptor(pinfo, parent_tree, tvb, offset, usb_conv_info, &last_ep_type, speed);
+ offset = dissect_usb_endpoint_descriptor(pinfo, parent_tree, tvb, offset, urb, &last_ep_type, speed);
break;
case USB_DT_INTERFACE_ASSOCIATION:
- offset = dissect_usb_interface_assn_descriptor(pinfo, parent_tree, tvb, offset, usb_conv_info);
+ offset = dissect_usb_interface_assn_descriptor(pinfo, parent_tree, tvb, offset, urb);
break;
case USB_DT_SUPERSPEED_EP_COMPANION:
- offset = dissect_usb_endpoint_companion_descriptor(pinfo, parent_tree, tvb, offset, usb_conv_info, last_ep_type);
+ offset = dissect_usb_endpoint_companion_descriptor(pinfo, parent_tree, tvb, offset, urb, last_ep_type);
break;
default:
next_tvb = tvb_new_subset_length(tvb, offset, next_len);
- if (dissector_try_uint_new(usb_descriptor_dissector_table, usb_conv_info->interfaceClass, next_tvb, pinfo, parent_tree, TRUE, usb_conv_info)) {
+ if (dissector_try_uint_new(usb_descriptor_dissector_table, urb->conv->interfaceClass, next_tvb, pinfo, parent_tree, true, urb)) {
offset += next_len;
} else {
- offset = dissect_usb_unknown_descriptor(pinfo, parent_tree, tvb, offset, usb_conv_info);
+ offset = dissect_usb_unknown_descriptor(pinfo, parent_tree, tvb, offset, urb);
}
break;
/* was: return offset; */
@@ -3117,7 +3173,7 @@ dissect_usb_configuration_descriptor(packet_info *pinfo _U_, proto_tree *parent_
static int
dissect_webusb_platform_descriptor(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
proto_tree_add_item(tree, hf_usb_webusb_bcdVersion, tvb, offset, 2, ENC_LITTLE_ENDIAN);
offset += 2;
@@ -3135,7 +3191,7 @@ dissect_webusb_platform_descriptor(packet_info *pinfo _U_, proto_tree *tree,
static int
dissect_msos20_platform_descriptor(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
proto_tree_add_item(tree, hf_usb_msos20_dwWindowsVersion, tvb, offset, 4, ENC_LITTLE_ENDIAN);
offset += 4;
@@ -3154,10 +3210,10 @@ dissect_msos20_platform_descriptor(packet_info *pinfo _U_, proto_tree *tree,
static struct {
e_guid_t uuid;
- const gchar *text;
+ const char *text;
int (*dissect)(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info);
+ urb_info_t *urb);
} bos_platform_uuids[] = {
{ {0x3408b638, 0x09a9, 0x47a0, {0x8b, 0xfd, 0xa0, 0x76, 0x88, 0x15, 0xb6, 0x65}},
"WebUSB Platform Capability descriptor",
@@ -3172,15 +3228,15 @@ static struct {
static int
dissect_usb_device_capability_descriptor(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
- guint8 cap_type;
- const gchar *cap_text;
+ uint8_t cap_type;
+ const char *cap_text;
e_guid_t uuid;
unsigned int i;
proto_tree_add_item(tree, hf_usb_bDevCapabilityType, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- cap_type = tvb_get_guint8(tvb, offset);
+ cap_type = tvb_get_uint8(tvb, offset);
offset += 1;
cap_text = try_val_to_str_ext(cap_type, &usb_capability_vals_ext);
@@ -3210,7 +3266,7 @@ dissect_usb_device_capability_descriptor(packet_info *pinfo, proto_tree *tree,
for (i = 0; i < array_length(bos_platform_uuids); i++) {
if (guid_cmp(&bos_platform_uuids[i].uuid, &uuid) == 0) {
- offset = bos_platform_uuids[i].dissect(pinfo, tree, tvb, offset, usb_conv_info);
+ offset = bos_platform_uuids[i].dissect(pinfo, tree, tvb, offset, urb);
cap_text = bos_platform_uuids[i].text;
break;
}
@@ -3228,15 +3284,15 @@ dissect_usb_device_capability_descriptor(packet_info *pinfo, proto_tree *tree,
static int
dissect_usb_bos_descriptor(packet_info *pinfo, proto_tree *parent_tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
proto_item *item;
proto_tree *tree;
int old_offset = offset;
- guint16 total_len;
+ uint16_t total_len;
usb_trans_info_t *usb_trans_info;
- usb_trans_info = usb_conv_info->usb_trans_info;
+ usb_trans_info = urb->usb_trans_info;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &item, "BOS DESCRIPTOR");
@@ -3265,12 +3321,12 @@ dissect_usb_bos_descriptor(packet_info *pinfo, proto_tree *parent_tree,
while (total_len > (offset - old_offset)) {
proto_item *desc_item;
int prev_offset = offset;
- guint8 desc_len, desc_type;
+ uint8_t desc_len, desc_type;
tree = proto_tree_add_subtree(parent_tree, tvb, offset, -1, ett_descriptor_device, &desc_item, "DEVICE CAPABILITY DESCRIPTOR");
item = proto_tree_add_item(tree, hf_usb_bLength, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- desc_len = tvb_get_guint8(tvb, offset);
+ desc_len = tvb_get_uint8(tvb, offset);
offset += 1;
if (desc_len < 3) {
expert_add_info_format(pinfo, item, &ei_usb_bLength_too_short, "Invalid Length (must be 3 or larger)");
@@ -3278,11 +3334,11 @@ dissect_usb_bos_descriptor(packet_info *pinfo, proto_tree *parent_tree,
}
item = proto_tree_add_item(tree, hf_usb_bDescriptorType, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- desc_type = tvb_get_guint8(tvb, offset);
+ desc_type = tvb_get_uint8(tvb, offset);
offset += 1;
if (desc_type == USB_DT_DEVICE_CAPABILITY) {
tvbuff_t *desc_tvb = tvb_new_subset_length(tvb, offset, desc_len - 2);
- offset += dissect_usb_device_capability_descriptor(pinfo, tree, desc_tvb, 0, usb_conv_info);
+ offset += dissect_usb_device_capability_descriptor(pinfo, tree, desc_tvb, 0, urb);
} else {
expert_add_info(pinfo, item, &ei_usb_unexpected_desc_type);
/* Already reported unexpected type, do not mark rest as undecoded */
@@ -3305,23 +3361,23 @@ dissect_usb_bos_descriptor(packet_info *pinfo, proto_tree *parent_tree,
static int
dissect_usb_setup_get_descriptor_request(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
usb_trans_info_t *usb_trans_info, trans_info;
- if (usb_conv_info)
- usb_trans_info = usb_conv_info->usb_trans_info;
+ if (urb)
+ usb_trans_info = urb->usb_trans_info;
else
usb_trans_info = &trans_info;
/* descriptor index */
proto_tree_add_item(tree, hf_usb_descriptor_index, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- usb_trans_info->u.get_descriptor.usb_index = tvb_get_guint8(tvb, offset);
+ usb_trans_info->u.get_descriptor.usb_index = tvb_get_uint8(tvb, offset);
offset += 1;
/* descriptor type */
proto_tree_add_item(tree, hf_usb_bDescriptorType, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- usb_trans_info->u.get_descriptor.type = tvb_get_guint8(tvb, offset);
+ usb_trans_info->u.get_descriptor.type = tvb_get_uint8(tvb, offset);
offset += 1;
col_append_fstr(pinfo->cinfo, COL_INFO, " %s",
val_to_str_ext(usb_trans_info->u.get_descriptor.type, &std_descriptor_type_vals_ext, "Unknown type %u"));
@@ -3340,13 +3396,13 @@ dissect_usb_setup_get_descriptor_request(packet_info *pinfo, proto_tree *tree,
static int
dissect_usb_setup_get_descriptor_response(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
usb_trans_info_t *usb_trans_info;
usb_speed_t speed;
- usb_trans_info = usb_conv_info->usb_trans_info;
- speed = usb_conv_info->speed;
+ usb_trans_info = urb->usb_trans_info;
+ speed = urb->speed;
col_append_fstr(pinfo->cinfo, COL_INFO, " %s",
val_to_str_ext(usb_trans_info->u.get_descriptor.type, &std_descriptor_type_vals_ext, "Unknown type %u"));
@@ -3358,7 +3414,7 @@ dissect_usb_setup_get_descriptor_response(packet_info *pinfo, proto_tree *tree,
as part of a configuration descriptor */
break;
case USB_DT_DEVICE:
- offset = dissect_usb_device_descriptor(pinfo, tree, tvb, offset, usb_conv_info);
+ offset = dissect_usb_device_descriptor(pinfo, tree, tvb, offset, urb);
break;
case USB_DT_OTHER_SPEED_CONFIG:
/* USB 2.0 Specification: 9.2.6.6 Speed Dependent Descriptors */
@@ -3368,21 +3424,21 @@ dissect_usb_setup_get_descriptor_response(packet_info *pinfo, proto_tree *tree,
speed = USB_SPEED_FULL;
/* fall-through */
case USB_DT_CONFIG:
- offset = dissect_usb_configuration_descriptor(pinfo, tree, tvb, offset, usb_conv_info, speed);
+ offset = dissect_usb_configuration_descriptor(pinfo, tree, tvb, offset, urb, speed);
break;
case USB_DT_STRING:
- offset = dissect_usb_string_descriptor(pinfo, tree, tvb, offset, usb_conv_info);
+ offset = dissect_usb_string_descriptor(pinfo, tree, tvb, offset, urb);
break;
case USB_DT_DEVICE_QUALIFIER:
- offset = dissect_usb_device_qualifier_descriptor(pinfo, tree, tvb, offset, usb_conv_info);
+ offset = dissect_usb_device_qualifier_descriptor(pinfo, tree, tvb, offset, urb);
break;
case USB_DT_BOS:
- offset = dissect_usb_bos_descriptor(pinfo, tree, tvb, offset, usb_conv_info);
+ offset = dissect_usb_bos_descriptor(pinfo, tree, tvb, offset, urb);
break;
default:
/* XXX dissect the descriptor coming back from the device */
{
- guint len = tvb_reported_length_remaining(tvb, offset);
+ unsigned len = tvb_reported_length_remaining(tvb, offset);
proto_tree_add_bytes_format(tree, hf_usb_get_descriptor_resp_generic, tvb, offset, len, NULL,
"GET DESCRIPTOR Response data (unknown descriptor type %u): %s",
usb_trans_info->u.get_descriptor.type,
@@ -3406,7 +3462,7 @@ dissect_usb_setup_get_descriptor_response(packet_info *pinfo, proto_tree *tree,
static int
dissect_usb_setup_get_interface_request(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* zero */
proto_tree_add_item(tree, hf_usb_value, tvb, offset, 2, ENC_LITTLE_ENDIAN);
@@ -3426,7 +3482,7 @@ dissect_usb_setup_get_interface_request(packet_info *pinfo _U_, proto_tree *tree
static int
dissect_usb_setup_get_interface_response(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* alternate setting */
proto_tree_add_item(tree, hf_usb_bAlternateSetting, tvb, offset, 1, ENC_LITTLE_ENDIAN);
@@ -3446,17 +3502,17 @@ dissect_usb_setup_get_interface_response(packet_info *pinfo _U_, proto_tree *tre
static int
dissect_usb_setup_get_status_request(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* zero */
proto_tree_add_item(tree, hf_usb_value, tvb, offset, 2, ENC_LITTLE_ENDIAN);
offset += 2;
/* zero/interface/endpoint */
- if (usb_conv_info) {
- guint8 recip;
+ if (urb) {
+ uint8_t recip;
- recip = USB_RECIPIENT(usb_conv_info->usb_trans_info->setup.requesttype);
+ recip = USB_RECIPIENT(urb->usb_trans_info->setup.requesttype);
switch (recip) {
case RQT_SETUP_RECIPIENT_INTERFACE:
@@ -3488,7 +3544,7 @@ dissect_usb_setup_get_status_request(packet_info *pinfo _U_, proto_tree *tree,
static int
dissect_usb_setup_get_status_response(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* status */
/* XXX - show bits */
@@ -3509,7 +3565,7 @@ dissect_usb_setup_get_status_response(packet_info *pinfo _U_, proto_tree *tree,
static int
dissect_usb_setup_set_address_request(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* device address */
proto_tree_add_item(tree, hf_usb_device_address, tvb, offset, 2, ENC_LITTLE_ENDIAN);
@@ -3529,7 +3585,7 @@ dissect_usb_setup_set_address_request(packet_info *pinfo _U_, proto_tree *tree,
static int
dissect_usb_setup_set_address_response(packet_info *pinfo _U_, proto_tree *tree _U_,
tvbuff_t *tvb _U_, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
return offset;
}
@@ -3545,7 +3601,7 @@ dissect_usb_setup_set_address_response(packet_info *pinfo _U_, proto_tree *tree
static int
dissect_usb_setup_set_configuration_request(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* configuration value */
proto_tree_add_item(tree, hf_usb_bConfigurationValue, tvb, offset, 1, ENC_LITTLE_ENDIAN);
@@ -3565,7 +3621,7 @@ dissect_usb_setup_set_configuration_request(packet_info *pinfo _U_, proto_tree *
static int
dissect_usb_setup_set_configuration_response(packet_info *pinfo _U_, proto_tree *tree _U_,
tvbuff_t *tvb _U_, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
return offset;
}
@@ -3581,12 +3637,12 @@ dissect_usb_setup_set_configuration_response(packet_info *pinfo _U_, proto_tree
static int
dissect_usb_setup_set_feature_request(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
- guint8 recip;
+ uint8_t recip;
- if (usb_conv_info) {
- recip = USB_RECIPIENT(usb_conv_info->usb_trans_info->setup.requesttype);
+ if (urb) {
+ recip = USB_RECIPIENT(urb->usb_trans_info->setup.requesttype);
/* feature selector, zero/interface/endpoint */
switch (recip) {
@@ -3633,7 +3689,7 @@ dissect_usb_setup_set_feature_request(packet_info *pinfo _U_, proto_tree *tree,
static int
dissect_usb_setup_set_feature_response(packet_info *pinfo _U_, proto_tree *tree _U_,
tvbuff_t *tvb _U_, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
return offset;
}
@@ -3649,17 +3705,17 @@ dissect_usb_setup_set_feature_response(packet_info *pinfo _U_, proto_tree *tree
static int
dissect_usb_setup_set_interface_request(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
- guint8 alt_setting, interface_num;
+ uint8_t alt_setting, interface_num;
/* alternate setting */
- alt_setting = tvb_get_guint8(tvb, offset);
+ alt_setting = tvb_get_uint8(tvb, offset);
proto_tree_add_uint(tree, hf_usb_bAlternateSetting, tvb, offset, 2, alt_setting);
offset += 2;
/* interface */
- interface_num = tvb_get_guint8(tvb, offset);
+ interface_num = tvb_get_uint8(tvb, offset);
proto_tree_add_uint(tree, hf_usb_wInterface, tvb, offset, 2, interface_num);
offset += 2;
@@ -3668,7 +3724,7 @@ dissect_usb_setup_set_interface_request(packet_info *pinfo, proto_tree *tree,
offset += 2;
if (!PINFO_FD_VISITED(pinfo)) {
- guint i, count;
+ unsigned i, count;
usb_conv_info_t *iface_conv_info = get_usb_iface_conv_info(pinfo, interface_num);
/* update the conversation info with the selected alternate setting */
@@ -3692,7 +3748,7 @@ dissect_usb_setup_set_interface_request(packet_info *pinfo, proto_tree *tree,
static int
dissect_usb_setup_set_interface_response(packet_info *pinfo _U_, proto_tree *tree _U_,
tvbuff_t *tvb _U_, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
return offset;
}
@@ -3708,7 +3764,7 @@ dissect_usb_setup_set_interface_response(packet_info *pinfo _U_, proto_tree *tre
static int
dissect_usb_setup_synch_frame_request(packet_info *pinfo _U_, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* zero */
proto_tree_add_item(tree, hf_usb_value, tvb, offset, 2, ENC_LITTLE_ENDIAN);
@@ -3728,7 +3784,7 @@ dissect_usb_setup_synch_frame_request(packet_info *pinfo _U_, proto_tree *tree,
static int
dissect_usb_setup_synch_frame_response(packet_info *pinfo _U_, proto_tree *tree _U_,
tvbuff_t *tvb _U_, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
/* frame number */
proto_tree_add_item(tree, hf_usb_wFrameNumber, tvb, offset, 2, ENC_LITTLE_ENDIAN);
@@ -3741,7 +3797,7 @@ dissect_usb_setup_synch_frame_response(packet_info *pinfo _U_, proto_tree *tree
static int
dissect_usb_setup_generic(packet_info *pinfo _U_, proto_tree *tree ,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info _U_)
+ urb_info_t *urb _U_)
{
proto_tree_add_item(tree, hf_usb_value, tvb, offset, 2, ENC_LITTLE_ENDIAN);
@@ -3758,10 +3814,10 @@ dissect_usb_setup_generic(packet_info *pinfo _U_, proto_tree *tree ,
typedef int (*usb_setup_dissector)(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info);
+ urb_info_t *urb);
typedef struct _usb_setup_dissector_table_t {
- guint8 request;
+ uint8_t request;
usb_setup_dissector dissector;
} usb_setup_dissector_table_t;
@@ -3834,10 +3890,10 @@ static const value_string bmrequesttype_recipient_vals[] = {
/* Dissector used for standard usb setup requests */
static int
dissect_usb_standard_setup_request(packet_info *pinfo, proto_tree *tree ,
- tvbuff_t *tvb, usb_conv_info_t *usb_conv_info,
+ tvbuff_t *tvb, urb_info_t *urb,
usb_trans_info_t *usb_trans_info)
{
- gint offset = 0;
+ int offset = 0;
const usb_setup_dissector_table_t *tmp;
usb_setup_dissector dissector;
@@ -3859,7 +3915,7 @@ dissect_usb_standard_setup_request(packet_info *pinfo, proto_tree *tree ,
dissector = &dissect_usb_setup_generic;
}
- offset = dissector(pinfo, tree, tvb, offset, usb_conv_info);
+ offset = dissector(pinfo, tree, tvb, offset, urb);
return offset;
@@ -3869,20 +3925,20 @@ dissect_usb_standard_setup_request(packet_info *pinfo, proto_tree *tree ,
static int
dissect_usb_standard_setup_response(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- usb_conv_info_t *usb_conv_info)
+ urb_info_t *urb)
{
const usb_setup_dissector_table_t *tmp;
usb_setup_dissector dissector;
- gint length_remaining;
+ int length_remaining;
col_add_fstr(pinfo->cinfo, COL_INFO, "%s Response",
- val_to_str_ext(usb_conv_info->usb_trans_info->setup.request,
+ val_to_str_ext(urb->usb_trans_info->setup.request,
&setup_request_names_vals_ext, "Unknown type %x"));
dissector = NULL;
for(tmp = setup_response_dissectors;tmp->dissector;tmp++) {
- if (tmp->request == usb_conv_info->usb_trans_info->setup.request) {
+ if (tmp->request == urb->usb_trans_info->setup.request) {
dissector = tmp->dissector;
break;
}
@@ -3894,7 +3950,7 @@ dissect_usb_standard_setup_response(packet_info *pinfo, proto_tree *tree,
return offset;
if (dissector) {
- offset = dissector(pinfo, tree, tvb, offset, usb_conv_info);
+ offset = dissector(pinfo, tree, tvb, offset, urb);
} else {
proto_tree_add_item(tree, hf_usb_control_response_generic,
tvb, offset, length_remaining, ENC_NA);
@@ -3906,31 +3962,31 @@ dissect_usb_standard_setup_response(packet_info *pinfo, proto_tree *tree,
static void
-usb_tap_queue_packet(packet_info *pinfo, guint8 urb_type,
- usb_conv_info_t *usb_conv_info)
+usb_tap_queue_packet(packet_info *pinfo, uint8_t urb_type,
+ urb_info_t *urb)
{
usb_tap_data_t *tap_data;
tap_data = wmem_new(pinfo->pool, usb_tap_data_t);
tap_data->urb_type = urb_type;
- tap_data->transfer_type = (guint8)(usb_conv_info->transfer_type);
- tap_data->conv_info = usb_conv_info;
- tap_data->trans_info = usb_conv_info->usb_trans_info;
+ tap_data->transfer_type = (uint8_t)(urb->transfer_type);
+ tap_data->urb = urb;
+ tap_data->trans_info = urb->usb_trans_info;
tap_queue_packet(usb_tap, pinfo, tap_data);
}
-static gboolean
+static bool
is_usb_standard_setup_request(usb_trans_info_t *usb_trans_info)
{
- guint8 type, recip;
+ uint8_t type, recip;
type = USB_TYPE(usb_trans_info->setup.requesttype);
recip = USB_RECIPIENT(usb_trans_info->setup.requesttype);
if (type != RQT_SETUP_TYPE_STANDARD)
- return FALSE;
+ return false;
/* the USB standards defines the GET_DESCRIPTOR request only as a
request to a device
@@ -3938,24 +3994,23 @@ is_usb_standard_setup_request(usb_trans_info_t *usb_trans_info)
should be handled by a class-specific dissector */
if (usb_trans_info->setup.request == USB_SETUP_GET_DESCRIPTOR &&
recip != RQT_SETUP_RECIPIENT_DEVICE) {
- return FALSE;
+ return false;
}
- return TRUE;
+ return true;
}
-static gint
+static int
try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pinfo,
- usb_conv_info_t *usb_conv_info, guint8 urb_type, proto_tree *urb_tree,
+ urb_info_t *urb, uint8_t urb_type, proto_tree *urb_tree,
proto_tree *setup_tree)
{
int ret;
wmem_tree_key_t key[4];
- guint32 k_frame_number;
- guint32 k_device_address;
- guint32 k_bus_id;
- usb_conv_info_t *old_conv_info = usb_conv_info;
+ uint32_t k_frame_number;
+ uint32_t k_device_address;
+ uint32_t k_bus_id;
usb_trans_info_t *usb_trans_info;
heur_dtbl_entry_t *hdtbl_entry;
heur_dissector_list_t heur_subdissector_list = NULL;
@@ -3963,14 +4018,15 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
proto_item *sub_item;
device_product_data_t *device_product_data;
device_protocol_data_t *device_protocol_data;
- guint8 ctrl_recip;
+ uint8_t ctrl_recip;
/* if we select the next dissector based on a class,
this is the (device or interface) class we're using */
- guint32 usb_class;
- guint8 transfer_type;
- gboolean use_setup_tree = FALSE;
+ uint32_t usb_class;
+ uint32_t protocol;
+ uint8_t transfer_type;
+ bool use_setup_tree = false;
- if (!usb_conv_info) {
+ if (!urb) {
/*
* Not enough information to choose the next protocol.
* XXX - is there something we can still do here?
@@ -3983,14 +4039,14 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
/* try dissect by "usb.device" */
ret = dissector_try_uint_new(device_to_dissector,
- (guint32)(usb_conv_info->bus_id<<16 | usb_conv_info->device_address),
- next_tvb, pinfo, tree, TRUE, usb_conv_info);
+ (uint32_t)(urb->bus_id<<16 | urb->device_address),
+ next_tvb, pinfo, tree, true, urb);
if (ret)
return tvb_captured_length(next_tvb);
k_frame_number = pinfo->num;
- k_device_address = usb_conv_info->device_address;
- k_bus_id = usb_conv_info->bus_id;
+ k_device_address = urb->device_address;
+ k_bus_id = urb->bus_id;
key[0].length = 1;
key[0].key = &k_device_address;
@@ -4005,29 +4061,29 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
device_protocol_data = (device_protocol_data_t *)wmem_tree_lookup32_array_le(device_to_protocol_table, key);
if (device_protocol_data &&
- device_protocol_data->bus_id == usb_conv_info->bus_id &&
- device_protocol_data->device_address == usb_conv_info->device_address) {
+ device_protocol_data->bus_id == urb->bus_id &&
+ device_protocol_data->device_address == urb->device_address) {
ret = dissector_try_uint_new(protocol_to_dissector,
- (guint32)device_protocol_data->protocol,
- next_tvb, pinfo, tree, TRUE, usb_conv_info);
+ (uint32_t)device_protocol_data->protocol,
+ next_tvb, pinfo, tree, true, urb);
if (ret)
return tvb_captured_length(next_tvb);
}
device_product_data = (device_product_data_t *)wmem_tree_lookup32_array_le(device_to_product_table, key);
- if (device_product_data && device_product_data->bus_id == usb_conv_info->bus_id &&
- device_product_data->device_address == usb_conv_info->device_address) {
+ if (device_product_data && device_product_data->bus_id == urb->bus_id &&
+ device_product_data->device_address == urb->device_address) {
ret = dissector_try_uint_new(product_to_dissector,
- (guint32)(device_product_data->vendor<<16 | device_product_data->product),
- next_tvb, pinfo, tree, TRUE, usb_conv_info);
+ (uint32_t)(device_product_data->vendor<<16 | device_product_data->product),
+ next_tvb, pinfo, tree, true, urb);
if (ret)
return tvb_captured_length(next_tvb);
}
- transfer_type = usb_conv_info->transfer_type;
+ transfer_type = urb->transfer_type;
if (transfer_type == URB_UNKNOWN)
- transfer_type = usb_conv_info->descriptor_transfer_type;
+ transfer_type = urb->conv->descriptor_transfer_type;
switch(transfer_type) {
case URB_BULK:
@@ -4041,7 +4097,7 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
break;
case URB_CONTROL:
- usb_trans_info = usb_conv_info->usb_trans_info;
+ usb_trans_info = urb->usb_trans_info;
if (!usb_trans_info)
break;
@@ -4052,35 +4108,44 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
/* When dissecting requests, and Setup Data tree is created,
pass it to next dissector instead of parent. */
- if (usb_conv_info->is_request && setup_tree)
- use_setup_tree = TRUE;
+ if (urb->is_request && setup_tree)
+ use_setup_tree = true;
ctrl_recip = USB_RECIPIENT(usb_trans_info->setup.requesttype);
if (ctrl_recip == RQT_SETUP_RECIPIENT_INTERFACE) {
- guint8 interface_num = usb_trans_info->setup.wIndex & 0xff;
+ uint8_t interface_num = usb_trans_info->setup.wIndex & 0xff;
+ urb_info_t *new_urb = wmem_new(pinfo->pool, urb_info_t);
+
+ memcpy(new_urb, urb, sizeof(urb_info_t));
+ urb = new_urb;
heur_subdissector_list = heur_control_subdissector_list;
usb_dissector_table = usb_control_dissector_table;
- usb_conv_info = get_usb_iface_conv_info(pinfo, interface_num);
- usb_conv_info->usb_trans_info = usb_trans_info;
+ urb->conv = get_usb_iface_conv_info(pinfo, interface_num);
+ urb->usb_trans_info = usb_trans_info;
+ urb->endpoint = NO_ENDPOINT8;
}
else if (ctrl_recip == RQT_SETUP_RECIPIENT_ENDPOINT) {
address endpoint_addr;
- gint endpoint;
- guint32 src_endpoint, dst_endpoint;
+ int endpoint;
+ uint32_t src_endpoint, dst_endpoint;
conversation_t *conversation;
+ urb_info_t *new_urb = wmem_new(pinfo->pool, urb_info_t);
+
+ memcpy(new_urb, urb, sizeof(urb_info_t));
+ urb = new_urb;
heur_subdissector_list = heur_control_subdissector_list;
usb_dissector_table = usb_control_dissector_table;
- endpoint = usb_trans_info->setup.wIndex & 0x0f;
+ endpoint = usb_trans_info->setup.wIndex & 0xff;
- if (usb_conv_info->is_request) {
+ if (urb->is_request) {
usb_address_t *dst_addr = wmem_new0(pinfo->pool, usb_address_t);
- dst_addr->bus_id = usb_conv_info->bus_id;
- dst_addr->device = usb_conv_info->device_address;
+ dst_addr->bus_id = urb->bus_id;
+ dst_addr->device = urb->device_address;
dst_addr->endpoint = dst_endpoint = GUINT32_TO_LE(endpoint);
set_address(&endpoint_addr, usb_address_type, USB_ADDR_LEN, (char *)dst_addr);
@@ -4088,16 +4153,16 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
}
else {
usb_address_t *src_addr = wmem_new0(pinfo->pool, usb_address_t);
- src_addr->bus_id = usb_conv_info->bus_id;
- src_addr->device = usb_conv_info->device_address;
+ src_addr->bus_id = urb->bus_id;
+ src_addr->device = urb->device_address;
src_addr->endpoint = src_endpoint = GUINT32_TO_LE(endpoint);
set_address(&endpoint_addr, usb_address_type, USB_ADDR_LEN, (char *)src_addr);
conversation = get_usb_conversation(pinfo, &endpoint_addr, &pinfo->dst, src_endpoint, pinfo->destport);
}
- usb_conv_info = get_usb_conv_info(conversation);
- usb_conv_info->usb_trans_info = usb_trans_info;
+ urb->conv = get_usb_conv_info(conversation);
+ urb->usb_trans_info = usb_trans_info;
}
else {
/* the recipient is "device" or "other" or "reserved"
@@ -4109,16 +4174,8 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
usb_dissector_table = usb_control_dissector_table;
}
- if (old_conv_info != usb_conv_info) {
- /* Preserve URB specific information */
- usb_conv_info->is_setup = old_conv_info->is_setup;
- usb_conv_info->is_request = old_conv_info->is_request;
- usb_conv_info->setup_requesttype = old_conv_info->setup_requesttype;
- usb_conv_info->speed = old_conv_info->speed;
- }
-
- usb_tap_queue_packet(pinfo, urb_type, usb_conv_info);
- sub_item = proto_tree_add_uint(urb_tree, hf_usb_bInterfaceClass, next_tvb, 0, 0, usb_conv_info->interfaceClass);
+ usb_tap_queue_packet(pinfo, urb_type, urb);
+ sub_item = proto_tree_add_uint(urb_tree, hf_usb_bInterfaceClass, next_tvb, 0, 0, urb->conv->interfaceClass);
proto_item_set_generated(sub_item);
break;
@@ -4126,10 +4183,19 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
break;
}
+ /* try "usb.protocol" on interface level */
+ protocol = (urb->conv->interfaceClass & 0xFF) << 16 |
+ (urb->conv->interfaceSubclass & 0xFF) << 8 |
+ (urb->conv->interfaceProtocol & 0xFF);
+ ret = dissector_try_uint_new(protocol_to_dissector, protocol,
+ next_tvb, pinfo, tree, true, urb);
+ if (ret)
+ return tvb_captured_length(next_tvb);
+
if (try_heuristics && heur_subdissector_list) {
- ret = dissector_try_heuristic(heur_subdissector_list,
- next_tvb, pinfo, use_setup_tree ? setup_tree : tree, &hdtbl_entry, usb_conv_info);
- if (ret)
+ bool dissector_found = dissector_try_heuristic(heur_subdissector_list,
+ next_tvb, pinfo, use_setup_tree ? setup_tree : tree, &hdtbl_entry, urb);
+ if (dissector_found)
return tvb_captured_length(next_tvb);
}
@@ -4137,24 +4203,24 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
/* we prefer the interface class unless it says we should refer
to the device class
XXX - use the device class if the interface class is unknown */
- if (usb_conv_info->interfaceClass == IF_CLASS_DEVICE) {
- usb_class = (usb_conv_info->device_protocol>>16) & 0xFF;
+ if (urb->conv->interfaceClass == IF_CLASS_DEVICE) {
+ usb_class = (urb->device_protocol>>16) & 0xFF;
}
else {
- usb_class = usb_conv_info->interfaceClass;
+ usb_class = urb->conv->interfaceClass;
}
ret = dissector_try_uint_new(usb_dissector_table, usb_class,
- next_tvb, pinfo, use_setup_tree ? setup_tree : tree, TRUE, usb_conv_info);
+ next_tvb, pinfo, use_setup_tree ? setup_tree : tree, true, urb);
if (ret)
return tvb_captured_length(next_tvb);
/* try protocol specific dissector if there is one */
- usb_class = USB_PROTOCOL_KEY(usb_conv_info->interfaceClass,
- usb_conv_info->interfaceSubclass,
- usb_conv_info->interfaceProtocol);
+ usb_class = USB_PROTOCOL_KEY(urb->conv->interfaceClass,
+ urb->conv->interfaceSubclass,
+ urb->conv->interfaceProtocol);
ret = dissector_try_uint_new(usb_dissector_table, usb_class,
- next_tvb, pinfo, use_setup_tree ? setup_tree : tree, TRUE, usb_conv_info);
+ next_tvb, pinfo, use_setup_tree ? setup_tree : tree, true, urb);
if (ret)
return tvb_captured_length(next_tvb);
}
@@ -4166,21 +4232,21 @@ try_dissect_next_protocol(proto_tree *tree, tvbuff_t *next_tvb, packet_info *pin
static int
dissect_usb_setup_response(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- guint8 urb_type, usb_conv_info_t *usb_conv_info)
+ uint8_t urb_type, urb_info_t *urb)
{
proto_tree *parent;
tvbuff_t *next_tvb = NULL;
- gint length_remaining;
+ int length_remaining;
parent = proto_tree_get_parent_tree(tree);
- if (usb_conv_info) {
- if (usb_conv_info->usb_trans_info && is_usb_standard_setup_request(usb_conv_info->usb_trans_info)) {
- offset = dissect_usb_standard_setup_response(pinfo, parent, tvb, offset, usb_conv_info);
+ if (urb) {
+ if (urb->usb_trans_info && is_usb_standard_setup_request(urb->usb_trans_info)) {
+ offset = dissect_usb_standard_setup_response(pinfo, parent, tvb, offset, urb);
}
else {
next_tvb = tvb_new_subset_remaining(tvb, offset);
- offset += try_dissect_next_protocol(parent, next_tvb, pinfo, usb_conv_info, urb_type, tree, NULL);
+ offset += try_dissect_next_protocol(parent, next_tvb, pinfo, urb, urb_type, tree, NULL);
length_remaining = tvb_reported_length_remaining(tvb, offset);
if (length_remaining > 0) {
@@ -4205,9 +4271,9 @@ dissect_usb_setup_response(packet_info *pinfo, proto_tree *tree,
static int
-dissect_usb_bmrequesttype(proto_tree *parent_tree, tvbuff_t *tvb, int offset, guint8 *byte)
+dissect_usb_bmrequesttype(proto_tree *parent_tree, tvbuff_t *tvb, int offset, uint8_t *byte)
{
- guint64 val;
+ uint64_t val;
static int * const bmRequestType_bits[] = {
&hf_usb_bmRequestType_direction,
@@ -4218,7 +4284,7 @@ dissect_usb_bmrequesttype(proto_tree *parent_tree, tvbuff_t *tvb, int offset, gu
proto_tree_add_bitmask_with_flags_ret_uint64(parent_tree, tvb, offset, hf_usb_bmRequestType, ett_usb_setup_bmrequesttype,
bmRequestType_bits, ENC_LITTLE_ENDIAN, BMT_NO_APPEND, &val);
- *byte = (guint8) val;
+ *byte = (uint8_t) val;
return ++offset;
}
@@ -4252,20 +4318,20 @@ dissect_linux_usb_pseudo_header_ext(tvbuff_t *tvb, int offset,
static int
dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
tvbuff_t *tvb, int offset,
- guint8 urb_type, usb_conv_info_t *usb_conv_info,
- usb_header_t header_type, guint64 usb_id)
+ uint8_t urb_type, urb_info_t *urb,
+ usb_header_t header_type, uint64_t usb_id)
{
- gint setup_offset;
- gint req_type;
- gint ret;
+ int setup_offset;
+ int req_type;
+ int ret;
proto_tree *parent, *setup_tree;
usb_trans_info_t *usb_trans_info, trans_info;
tvbuff_t *next_tvb, *data_tvb = NULL;
- guint8 bm_request_type;
+ uint8_t bm_request_type;
/* we should do the NULL check in all non-static functions */
- if (usb_conv_info)
- usb_trans_info = usb_conv_info->usb_trans_info;
+ if (urb)
+ usb_trans_info = urb->usb_trans_info;
else
usb_trans_info = &trans_info;
@@ -4273,12 +4339,12 @@ dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
setup_tree = proto_tree_add_subtree(parent, tvb, offset, 8, ett_usb_setup_hdr, NULL, "Setup Data");
- req_type = USB_TYPE(tvb_get_guint8(tvb, offset));
- usb_trans_info->setup.requesttype = tvb_get_guint8(tvb, offset);
- if (usb_conv_info) {
- usb_conv_info->setup_requesttype = tvb_get_guint8(tvb, offset);
+ req_type = USB_TYPE(tvb_get_uint8(tvb, offset));
+ usb_trans_info->setup.requesttype = tvb_get_uint8(tvb, offset);
+ if (urb) {
+ urb->setup_requesttype = tvb_get_uint8(tvb, offset);
if (req_type != RQT_SETUP_TYPE_CLASS)
- usb_tap_queue_packet(pinfo, urb_type, usb_conv_info);
+ usb_tap_queue_packet(pinfo, urb_type, urb);
}
offset = dissect_usb_bmrequesttype(setup_tree, tvb, offset, &bm_request_type);
@@ -4289,7 +4355,7 @@ dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
all subsequent dissection routines work on this tvb */
setup_offset = offset;
- usb_trans_info->setup.request = tvb_get_guint8(tvb, offset);
+ usb_trans_info->setup.request = tvb_get_uint8(tvb, offset);
offset++;
usb_trans_info->setup.wValue = tvb_get_letohs(tvb, offset);
offset += 2;
@@ -4312,7 +4378,7 @@ dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
setup_data->usb_id = usb_id;
tvb_memcpy(tvb, setup_data->setup_data, setup_offset-1, 8);
key[0].length = 2;
- key[0].key = (guint32 *)&usb_id;
+ key[0].key = (uint32_t *)&usb_id;
key[1].length = 1;
key[1].key = &pinfo->num;
key[2].length = 0;
@@ -4320,7 +4386,7 @@ dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
wmem_tree_insert32_array(usbpcap_setup_data, key, setup_data);
}
proto_tree_add_item(setup_tree, hf_usb_request_unknown_class, tvb, setup_offset, 1, ENC_LITTLE_ENDIAN);
- dissect_usb_setup_generic(pinfo, setup_tree, tvb, setup_offset+1, usb_conv_info);
+ dissect_usb_setup_generic(pinfo, setup_tree, tvb, setup_offset+1, urb);
return offset;
}
}
@@ -4335,7 +4401,7 @@ dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
offset += tvb_captured_length(data_tvb);
tvb_composite_finalize(next_tvb);
next_tvb = tvb_new_child_real_data(tvb,
- (const guint8 *) tvb_memdup(pinfo->pool, next_tvb, 0, tvb_captured_length(next_tvb)),
+ (const uint8_t *) tvb_memdup(pinfo->pool, next_tvb, 0, tvb_captured_length(next_tvb)),
tvb_captured_length(next_tvb),
tvb_captured_length(next_tvb));
add_new_data_source(pinfo, next_tvb, "USB Control");
@@ -4350,21 +4416,21 @@ dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
/* there's no point in checking the return value as there's no
fallback for standard setup requests */
dissect_usb_standard_setup_request(pinfo, setup_tree,
- next_tvb, usb_conv_info, usb_trans_info);
+ next_tvb, urb, usb_trans_info);
}
else {
/* no standard request - pass it on to class-specific dissectors */
ret = try_dissect_next_protocol(
- parent, next_tvb, pinfo, usb_conv_info, urb_type, tree, setup_tree);
+ parent, next_tvb, pinfo, urb, urb_type, tree, setup_tree);
if (ret <= 0) {
/* no class-specific dissector could handle it,
dissect it as generic setup request */
proto_tree_add_item(setup_tree, hf_usb_request_unknown_class,
next_tvb, 0, 1, ENC_LITTLE_ENDIAN);
dissect_usb_setup_generic(pinfo, setup_tree,
- next_tvb, 1, usb_conv_info);
+ next_tvb, 1, urb);
}
- /* at this point, non-standard request has been dissectored */
+ /* at this point, non-standard request has been dissected */
}
if (data_tvb)
@@ -4376,35 +4442,35 @@ dissect_usb_setup_request(packet_info *pinfo, proto_tree *tree,
/* dissect the linux-specific USB pseudo header and fill the conversation struct
return the number of dissected bytes */
-static gint
+static int
dissect_linux_usb_pseudo_header(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- usb_conv_info_t *usb_conv_info, guint64 *urb_id)
+ urb_info_t *urb, uint64_t *urb_id)
{
- guint8 transfer_type;
- guint8 endpoint_byte;
- guint8 transfer_type_and_direction;
- guint8 urb_type;
- guint32 flag;
- guint32 bus_id;
-
- *urb_id = tvb_get_guint64(tvb, 0, ENC_HOST_ENDIAN);
+ uint8_t transfer_type;
+ uint8_t endpoint_byte;
+ uint8_t transfer_type_and_direction;
+ uint8_t urb_type;
+ uint32_t flag;
+ uint32_t bus_id;
+
+ *urb_id = tvb_get_uint64(tvb, 0, ENC_HOST_ENDIAN);
proto_tree_add_uint64(tree, hf_usb_urb_id, tvb, 0, 8, *urb_id);
/* show the urb type of this URB as string and as a character */
- urb_type = tvb_get_guint8(tvb, 8);
- usb_conv_info->is_request = (urb_type==URB_SUBMIT);
+ urb_type = tvb_get_uint8(tvb, 8);
+ urb->is_request = (urb_type==URB_SUBMIT);
proto_tree_add_uint(tree, hf_usb_linux_urb_type, tvb, 8, 1, urb_type);
proto_tree_add_item(tree, hf_usb_linux_transfer_type, tvb, 9, 1, ENC_LITTLE_ENDIAN);
- transfer_type = tvb_get_guint8(tvb, 9);
- usb_conv_info->transfer_type = transfer_type;
+ transfer_type = tvb_get_uint8(tvb, 9);
+ urb->transfer_type = transfer_type;
- endpoint_byte = tvb_get_guint8(tvb, 10); /* direction bit | endpoint */
- usb_conv_info->endpoint = endpoint_byte & 0x7F;
+ endpoint_byte = tvb_get_uint8(tvb, 10); /* direction bit | endpoint */
+ urb->endpoint = endpoint_byte;
if (endpoint_byte & URB_TRANSFER_IN)
- usb_conv_info->direction = P2P_DIR_RECV;
+ urb->direction = P2P_DIR_RECV;
else
- usb_conv_info->direction = P2P_DIR_SENT;
+ urb->direction = P2P_DIR_SENT;
transfer_type_and_direction = (transfer_type & 0x7F) | (endpoint_byte & 0x80);
col_append_str(pinfo->cinfo, COL_INFO,
@@ -4412,10 +4478,10 @@ dissect_linux_usb_pseudo_header(tvbuff_t *tvb, packet_info *pinfo, proto_tree *t
proto_tree_add_bitmask(tree, tvb, 10, hf_usb_endpoint_address, ett_usb_endpoint, usb_endpoint_fields, ENC_NA);
proto_tree_add_item(tree, hf_usb_device_address, tvb, 11, 1, ENC_LITTLE_ENDIAN);
- usb_conv_info->device_address = (guint16)tvb_get_guint8(tvb, 11);
+ urb->device_address = (uint16_t)tvb_get_uint8(tvb, 11);
proto_tree_add_item_ret_uint(tree, hf_usb_bus_id, tvb, 12, 2, ENC_HOST_ENDIAN, &bus_id);
- usb_conv_info->bus_id = (guint16) bus_id;
+ urb->bus_id = (uint16_t) bus_id;
/* Right after the pseudo header we always have
* sizeof(struct usb_device_setup_hdr) bytes. The content of these
@@ -4423,11 +4489,11 @@ dissect_linux_usb_pseudo_header(tvbuff_t *tvb, packet_info *pinfo, proto_tree *t
*/
proto_tree_add_item_ret_uint(tree, hf_usb_setup_flag, tvb, 14, 1, ENC_NA, &flag);
if (flag == 0) {
- usb_conv_info->is_setup = TRUE;
- if (usb_conv_info->transfer_type!=URB_CONTROL)
+ urb->is_setup = true;
+ if (urb->transfer_type!=URB_CONTROL)
proto_tree_add_expert(tree, pinfo, &ei_usb_invalid_setup, tvb, 14, 1);
} else {
- usb_conv_info->is_setup = FALSE;
+ urb->is_setup = false;
}
proto_tree_add_item(tree, hf_usb_data_flag, tvb, 15, 1, ENC_NA);
@@ -4444,53 +4510,53 @@ dissect_linux_usb_pseudo_header(tvbuff_t *tvb, packet_info *pinfo, proto_tree *t
/* dissect the usbpcap_buffer_packet_header and fill the conversation struct
this function does not handle the transfer-specific headers
return the number of bytes processed */
-static gint
+static int
dissect_usbpcap_buffer_packet_header(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- usb_conv_info_t *usb_conv_info, guint32 *win32_data_len, guint64 *irp_id)
+ urb_info_t *urb, uint32_t *win32_data_len, uint64_t *irp_id)
{
proto_item *item;
- guint32 function_code;
- guint8 transfer_type;
- guint8 endpoint_byte;
- guint8 transfer_type_and_direction;
- guint8 tmp_val8;
+ uint32_t function_code;
+ uint8_t transfer_type;
+ uint8_t endpoint_byte;
+ uint8_t transfer_type_and_direction;
+ uint8_t tmp_val8;
proto_tree_add_item(tree, hf_usb_win32_header_len, tvb, 0, 2, ENC_LITTLE_ENDIAN);
- *irp_id = tvb_get_guint64(tvb, 2, ENC_LITTLE_ENDIAN);
+ *irp_id = tvb_get_uint64(tvb, 2, ENC_LITTLE_ENDIAN);
proto_tree_add_uint64(tree, hf_usb_irp_id, tvb, 2, 8, *irp_id);
proto_tree_add_item(tree, hf_usb_usbd_status, tvb, 10, 4, ENC_LITTLE_ENDIAN);
proto_tree_add_item_ret_uint(tree, hf_usb_function, tvb, 14, 2, ENC_LITTLE_ENDIAN, &function_code);
proto_tree_add_bitmask(tree, tvb, 16, hf_usb_info, ett_usb_usbpcap_info, usb_usbpcap_info_fields, ENC_LITTLE_ENDIAN);
- tmp_val8 = tvb_get_guint8(tvb, 16);
+ tmp_val8 = tvb_get_uint8(tvb, 16);
/* TODO: Handle errors */
if (tmp_val8 & 0x01) {
- usb_conv_info->is_request = FALSE;
+ urb->is_request = false;
} else {
- usb_conv_info->is_request = TRUE;
+ urb->is_request = true;
}
proto_tree_add_item(tree, hf_usb_bus_id, tvb, 17, 2, ENC_LITTLE_ENDIAN);
- usb_conv_info->bus_id = tvb_get_letohs(tvb, 17);
+ urb->bus_id = tvb_get_letohs(tvb, 17);
proto_tree_add_item(tree, hf_usb_win32_device_address, tvb, 19, 2, ENC_LITTLE_ENDIAN);
- usb_conv_info->device_address = tvb_get_letohs(tvb, 19);
+ urb->device_address = tvb_get_letohs(tvb, 19);
- endpoint_byte = tvb_get_guint8(tvb, 21);
- usb_conv_info->direction = endpoint_byte&URB_TRANSFER_IN ? P2P_DIR_RECV : P2P_DIR_SENT;
- usb_conv_info->endpoint = endpoint_byte&0x7F;
+ endpoint_byte = tvb_get_uint8(tvb, 21);
+ urb->direction = endpoint_byte&URB_TRANSFER_IN ? P2P_DIR_RECV : P2P_DIR_SENT;
+ urb->endpoint = endpoint_byte;
proto_tree_add_bitmask(tree, tvb, 21, hf_usb_endpoint_address, ett_usb_endpoint, usb_endpoint_fields, ENC_LITTLE_ENDIAN);
- transfer_type = tvb_get_guint8(tvb, 22);
- usb_conv_info->transfer_type = transfer_type;
+ transfer_type = tvb_get_uint8(tvb, 22);
+ urb->transfer_type = transfer_type;
item = proto_tree_add_item(tree, hf_usb_win32_transfer_type, tvb, 22, 1, ENC_LITTLE_ENDIAN);
if (transfer_type == URB_UNKNOWN) {
expert_add_info(pinfo, item, &ei_usb_usbpcap_unknown_urb);
}
/* Workaround bug in captures created with USBPcap earlier than 1.3.0.0 */
- if ((endpoint_byte == 0x00) && (transfer_type == URB_CONTROL) && (tvb_get_guint8(tvb, 27) == USB_CONTROL_STAGE_DATA)) {
- usb_conv_info->is_request = TRUE;
+ if ((endpoint_byte == 0x00) && (transfer_type == URB_CONTROL) && (tvb_get_uint8(tvb, 27) == USB_CONTROL_STAGE_DATA)) {
+ urb->is_request = true;
}
if (transfer_type != USBPCAP_URB_IRP_INFO) {
@@ -4507,31 +4573,31 @@ dissect_usbpcap_buffer_packet_header(tvbuff_t *tvb, packet_info *pinfo, proto_tr
/* by default, we assume it's no setup packet
the correct values will be set when we parse the control header */
- usb_conv_info->is_setup = FALSE;
- usb_conv_info->setup_requesttype = 0;
+ urb->is_setup = false;
+ urb->setup_requesttype = 0;
/* we don't handle the transfer-specific headers here */
return 27;
}
-static gint
+static int
dissect_darwin_buffer_packet_header(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- usb_conv_info_t *usb_conv_info, guint64 *id)
+ urb_info_t *urb, uint64_t *id)
{
- guint8 transfer_type;
- guint8 request_type;
- guint8 endpoint_byte;
- guint8 transfer_type_and_direction;
- guint8 header_length;
+ uint8_t transfer_type;
+ uint8_t request_type;
+ uint8_t endpoint_byte;
+ uint8_t transfer_type_and_direction;
+ uint8_t header_length;
proto_tree_add_item(tree, hf_usb_darwin_bcd_version, tvb, 0, 2, ENC_LITTLE_ENDIAN);
- header_length = tvb_get_guint8(tvb, 2);
+ header_length = tvb_get_uint8(tvb, 2);
proto_tree_add_item(tree, hf_usb_darwin_header_len, tvb, 2, 1, ENC_LITTLE_ENDIAN);
- request_type = tvb_get_guint8(tvb, 3);
- usb_conv_info->is_request = (request_type == DARWIN_IO_SUBMIT);
+ request_type = tvb_get_uint8(tvb, 3);
+ urb->is_request = (request_type == DARWIN_IO_SUBMIT);
proto_tree_add_uint(tree, hf_usb_darwin_request_type, tvb, 3, 1, request_type);
proto_tree_add_item(tree, hf_usb_darwin_io_len, tvb, 4, 4, ENC_LITTLE_ENDIAN);
@@ -4540,43 +4606,43 @@ dissect_darwin_buffer_packet_header(tvbuff_t *tvb, packet_info *pinfo, proto_tre
proto_tree_add_item(tree, hf_usb_darwin_iso_num_packets, tvb, 12, 4, ENC_LITTLE_ENDIAN);
- *id = tvb_get_guint64(tvb, 16, ENC_LITTLE_ENDIAN);
+ *id = tvb_get_uint64(tvb, 16, ENC_LITTLE_ENDIAN);
proto_tree_add_uint64(tree, hf_usb_darwin_io_id, tvb, 16, 8, *id);
proto_tree_add_item(tree, hf_usb_darwin_device_location, tvb, 24, 4, ENC_LITTLE_ENDIAN);
- usb_conv_info->bus_id = tvb_get_letohl(tvb, 24) >> 24;
+ urb->bus_id = tvb_get_letohl(tvb, 24) >> 24;
proto_tree_add_item(tree, hf_usb_darwin_speed, tvb, 28, 1, ENC_LITTLE_ENDIAN);
- usb_conv_info->device_address = (guint16)tvb_get_guint8(tvb, 29);
- proto_tree_add_uint(tree, hf_usb_darwin_device_address, tvb, 29, 1, usb_conv_info->device_address);
+ urb->device_address = (uint16_t)tvb_get_uint8(tvb, 29);
+ proto_tree_add_uint(tree, hf_usb_darwin_device_address, tvb, 29, 1, urb->device_address);
- endpoint_byte = tvb_get_guint8(tvb, 30); /* direction bit | endpoint */
- usb_conv_info->endpoint = endpoint_byte & 0x7F;
+ endpoint_byte = tvb_get_uint8(tvb, 30); /* direction bit | endpoint */
+ urb->endpoint = endpoint_byte;
if (endpoint_byte & URB_TRANSFER_IN) {
- usb_conv_info->direction = P2P_DIR_RECV;
+ urb->direction = P2P_DIR_RECV;
}
else {
- usb_conv_info->direction = P2P_DIR_SENT;
+ urb->direction = P2P_DIR_SENT;
}
proto_tree_add_uint(tree, hf_usb_darwin_endpoint_address, tvb, 30, 1, endpoint_byte);
proto_tree_add_bitmask(tree, tvb, 30, hf_usb_endpoint_number, ett_usb_endpoint, usb_endpoint_fields, ENC_LITTLE_ENDIAN);
- transfer_type = MIN(tvb_get_guint8(tvb, 31), G_N_ELEMENTS(darwin_endpoint_to_linux) - 1);
- usb_conv_info->transfer_type = darwin_endpoint_to_linux[transfer_type];
+ transfer_type = MIN(tvb_get_uint8(tvb, 31), G_N_ELEMENTS(darwin_endpoint_to_linux) - 1);
+ urb->transfer_type = darwin_endpoint_to_linux[transfer_type];
proto_tree_add_uint(tree, hf_usb_darwin_endpoint_type, tvb, 31, 1, transfer_type);
transfer_type_and_direction = (darwin_endpoint_to_linux[transfer_type] & 0x7F) | (endpoint_byte & 0x80);
col_append_str(pinfo->cinfo, COL_INFO,
val_to_str(transfer_type_and_direction, usb_transfer_type_and_direction_vals, "Unknown type %x"));
- col_append_str(pinfo->cinfo, COL_INFO, usb_conv_info->is_request == TRUE ? " (submitted)" : " (completed)");
+ col_append_str(pinfo->cinfo, COL_INFO, urb->is_request == true ? " (submitted)" : " (completed)");
- usb_conv_info->is_setup = FALSE;
- if ((usb_conv_info->is_request == TRUE) && (usb_conv_info->transfer_type == URB_CONTROL)) {
- usb_conv_info->is_setup = TRUE;
+ urb->is_setup = false;
+ if ((urb->is_request == true) && (urb->transfer_type == URB_CONTROL)) {
+ urb->is_setup = true;
}
- usb_conv_info->setup_requesttype = 0;
+ urb->setup_requesttype = 0;
/* we don't handle the transfer-specific headers here */
return header_length;
@@ -4584,14 +4650,14 @@ dissect_darwin_buffer_packet_header(tvbuff_t *tvb, packet_info *pinfo, proto_tre
/* Set the usb_address_t fields based on the direction of the urb */
static void
-usb_set_addr(proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, guint16 bus_id, guint16 device_address,
- int endpoint, gboolean req)
+usb_set_addr(proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, uint16_t bus_id, uint16_t device_address,
+ int endpoint, bool req)
{
proto_item *sub_item;
usb_address_t *src_addr = wmem_new0(pinfo->pool, usb_address_t),
*dst_addr = wmem_new0(pinfo->pool, usb_address_t);
- guint8 *str_src_addr;
- guint8 *str_dst_addr;
+ uint8_t *str_src_addr;
+ uint8_t *str_dst_addr;
if (req) {
/* request */
@@ -4642,7 +4708,7 @@ usb_set_addr(proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, guint16 bus_id
* Also adds request/response info to the tree for the given packet */
static usb_trans_info_t
*usb_get_trans_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- usb_header_t header_type, usb_conv_info_t *usb_conv_info, guint64 usb_id)
+ usb_header_t header_type, urb_info_t *urb, uint64_t usb_id)
{
usb_trans_info_t *usb_trans_info;
proto_item *ti;
@@ -4653,15 +4719,15 @@ static usb_trans_info_t
* data.
*/
key[0].length = 2;
- key[0].key = (guint32 *)&usb_id;
+ key[0].key = (uint32_t *)&usb_id;
key[1].length = 1;
key[1].key = &pinfo->num;
key[2].length = 0;
key[2].key = NULL;
- if (usb_conv_info->is_request) {
+ if (urb->is_request) {
/* this is a request */
- usb_trans_info = (usb_trans_info_t *)wmem_tree_lookup32_array(usb_conv_info->transactions, key);
+ usb_trans_info = (usb_trans_info_t *)wmem_tree_lookup32_array(urb->conv->transactions, key);
if (!usb_trans_info) {
usb_trans_info = wmem_new0(wmem_file_scope(), usb_trans_info_t);
usb_trans_info->request_in = pinfo->num;
@@ -4669,7 +4735,7 @@ static usb_trans_info_t
usb_trans_info->header_type = header_type;
usb_trans_info->usb_id = usb_id;
- wmem_tree_insert32_array(usb_conv_info->transactions, key, usb_trans_info);
+ wmem_tree_insert32_array(urb->conv->transactions, key, usb_trans_info);
}
if (usb_trans_info->response_in) {
@@ -4680,17 +4746,17 @@ static usb_trans_info_t
} else {
/* this is a response */
if (pinfo->fd->visited) {
- usb_trans_info = (usb_trans_info_t *)wmem_tree_lookup32_array(usb_conv_info->transactions, key);
+ usb_trans_info = (usb_trans_info_t *)wmem_tree_lookup32_array(urb->conv->transactions, key);
} else {
- usb_trans_info = (usb_trans_info_t *)wmem_tree_lookup32_array_le(usb_conv_info->transactions, key);
+ usb_trans_info = (usb_trans_info_t *)wmem_tree_lookup32_array_le(urb->conv->transactions, key);
if (usb_trans_info) {
if (usb_trans_info->usb_id == usb_id) {
if (usb_trans_info->response_in == 0) {
/* USBPcap generates 2 frames for response; store the first one */
usb_trans_info->response_in = pinfo->num;
}
- wmem_tree_insert32_array(usb_conv_info->transactions, key, usb_trans_info);
+ wmem_tree_insert32_array(urb->conv->transactions, key, usb_trans_info);
} else {
usb_trans_info = NULL;
}
@@ -4716,12 +4782,12 @@ static usb_trans_info_t
/* dissect a group of isochronous packets inside an usb packet in
usbpcap format */
#define MAX_ISO_PACKETS 100000 // Arbitrary
-static gint
-dissect_usbpcap_iso_packets(packet_info *pinfo _U_, proto_tree *urb_tree, guint8 urb_type,
- tvbuff_t *tvb, gint offset, guint32 win32_data_len, usb_conv_info_t *usb_conv_info)
+static int
+dissect_usbpcap_iso_packets(packet_info *pinfo _U_, proto_tree *urb_tree, uint8_t urb_type,
+ tvbuff_t *tvb, int offset, uint32_t win32_data_len, urb_info_t *urb)
{
- guint32 i;
- guint32 num_packets;
+ uint32_t i;
+ uint32_t num_packets;
int data_start_offset;
proto_item *num_packets_ti, *urb_tree_ti;
@@ -4745,9 +4811,9 @@ dissect_usbpcap_iso_packets(packet_info *pinfo _U_, proto_tree *urb_tree, guint8
proto_item_set_len(urb_tree_ti, data_start_offset);
for (i = 0; i < num_packets; i++) {
- guint32 this_offset;
- guint32 next_offset;
- guint32 iso_len;
+ uint32_t this_offset;
+ uint32_t next_offset;
+ uint32_t iso_len;
proto_item *iso_packet_ti, *ti;
proto_tree *iso_packet_tree;
@@ -4771,9 +4837,9 @@ dissect_usbpcap_iso_packets(packet_info *pinfo _U_, proto_tree *urb_tree, guint8
iso_len = 0;
}
- /* If this packet does not contain isochrounous data, do not try to display it */
- if (!((usb_conv_info->is_request && usb_conv_info->direction==P2P_DIR_SENT) ||
- (!usb_conv_info->is_request && usb_conv_info->direction==P2P_DIR_RECV))) {
+ /* If this packet does not contain isochronous data, do not try to display it */
+ if (!((urb->is_request && urb->direction==P2P_DIR_SENT) ||
+ (!urb->is_request && urb->direction==P2P_DIR_RECV))) {
iso_len = 0;
}
@@ -4781,14 +4847,14 @@ dissect_usbpcap_iso_packets(packet_info *pinfo _U_, proto_tree *urb_tree, guint8
offset += 4;
ti = proto_tree_add_item(iso_packet_tree, hf_usb_win32_iso_length, tvb, offset, 4, ENC_LITTLE_ENDIAN);
- if (usb_conv_info->direction==P2P_DIR_SENT) {
+ if (urb->direction==P2P_DIR_SENT) {
/* Isochronous OUT transfer */
proto_item_append_text(ti, " (not used)");
} else {
/* Isochronous IN transfer.
* Length field is being set by host controller.
*/
- if (usb_conv_info->is_request) {
+ if (urb->is_request) {
/* Length was not yet set */
proto_item_append_text(ti, " (irrelevant)");
} else {
@@ -4808,13 +4874,13 @@ dissect_usbpcap_iso_packets(packet_info *pinfo _U_, proto_tree *urb_tree, guint8
offset += 4;
if (iso_len && data_start_offset + this_offset + iso_len <= tvb_captured_length(tvb)) {
- proto_tree_add_item(iso_packet_tree, hf_usb_iso_data, tvb, (gint)(data_start_offset + this_offset), (gint)iso_len, ENC_NA);
- proto_tree_set_appendix(iso_packet_tree, tvb, (gint)(data_start_offset + this_offset), (gint)iso_len);
+ proto_tree_add_item(iso_packet_tree, hf_usb_iso_data, tvb, (int)(data_start_offset + this_offset), (int)iso_len, ENC_NA);
+ proto_tree_set_appendix(iso_packet_tree, tvb, (int)(data_start_offset + this_offset), (int)iso_len);
}
}
- if ((usb_conv_info->is_request && usb_conv_info->direction==P2P_DIR_SENT) ||
- (!usb_conv_info->is_request && usb_conv_info->direction==P2P_DIR_RECV)) {
+ if ((urb->is_request && urb->direction==P2P_DIR_SENT) ||
+ (!urb->is_request && urb->direction==P2P_DIR_RECV)) {
/* We have dissected all the isochronous data */
offset += win32_data_len;
}
@@ -4823,20 +4889,20 @@ dissect_usbpcap_iso_packets(packet_info *pinfo _U_, proto_tree *urb_tree, guint8
}
-static gint
+static int
dissect_linux_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *urb_tree,
- usb_header_t header_type, tvbuff_t *tvb, gint offset,
- usb_conv_info_t *usb_conv_info)
+ usb_header_t header_type, tvbuff_t *tvb, int offset,
+ urb_info_t *urb)
{
- guint32 iso_numdesc = 0;
+ uint32_t iso_numdesc = 0;
proto_item *tii;
- guint32 i;
- guint data_base;
- guint32 iso_status;
- guint32 iso_off = 0;
- guint32 iso_len = 0;
+ uint32_t i;
+ unsigned data_base;
+ uint32_t iso_status;
+ uint32_t iso_off = 0;
+ uint32_t iso_len = 0;
- tii = proto_tree_add_uint(urb_tree, hf_usb_bInterfaceClass, tvb, offset, 0, usb_conv_info->interfaceClass);
+ tii = proto_tree_add_uint(urb_tree, hf_usb_bInterfaceClass, tvb, offset, 0, urb->conv->interfaceClass);
proto_item_set_generated(tii);
/* All fields which belong to Linux usbmon headers are in host-endian
@@ -4890,7 +4956,7 @@ dissect_linux_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *urb_tree,
if ((pinfo->p2p_dir==P2P_DIR_SENT || !iso_status) &&
iso_len && data_base + iso_off + iso_len <= tvb_captured_length(tvb)) {
proto_tree_add_item(iso_desc_tree, hf_usb_iso_data, tvb, data_base + iso_off, iso_len, ENC_NA);
- proto_tree_set_appendix(iso_desc_tree, tvb, (gint)(data_base+iso_off), (gint)iso_len);
+ proto_tree_set_appendix(iso_desc_tree, tvb, (int)(data_base+iso_off), (int)iso_len);
}
proto_tree_add_item(iso_desc_tree, hf_usb_iso_pad, tvb, offset, 4, ENC_HOST_ENDIAN);
@@ -4906,18 +4972,18 @@ dissect_linux_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *urb_tree,
return data_base+iso_off+iso_len;
}
-static gint
+static int
dissect_usbip_iso_transfer(packet_info *pinfo _U_, proto_tree *urb_tree,
- tvbuff_t *tvb, gint offset, guint32 iso_numdesc, guint32 desc_offset,
- usb_conv_info_t *usb_conv_info)
+ tvbuff_t *tvb, int offset, uint32_t iso_numdesc, uint32_t desc_offset,
+ urb_info_t *urb)
{
proto_item *tii;
- guint32 i;
- guint data_base;
- guint32 iso_off = 0;
- guint32 iso_len = 0;
+ uint32_t i;
+ unsigned data_base;
+ uint32_t iso_off = 0;
+ uint32_t iso_len = 0;
- tii = proto_tree_add_uint(urb_tree, hf_usb_bInterfaceClass, tvb, offset, 0, usb_conv_info->interfaceClass);
+ tii = proto_tree_add_uint(urb_tree, hf_usb_bInterfaceClass, tvb, offset, 0, urb->conv->interfaceClass);
proto_item_set_generated(tii);
/* All fields which belong to usbip are in big-endian byte order.
@@ -4931,7 +4997,7 @@ dissect_usbip_iso_transfer(packet_info *pinfo _U_, proto_tree *urb_tree,
for (i = 0; i<iso_numdesc; i++) {
proto_item *iso_desc_ti;
proto_tree *iso_desc_tree;
- gint32 iso_status;
+ int32_t iso_status;
iso_desc_ti = proto_tree_add_protocol_format(urb_tree, proto_usb, tvb, desc_offset,
16, "USB isodesc %u", i);
@@ -4960,34 +5026,34 @@ dissect_usbip_iso_transfer(packet_info *pinfo _U_, proto_tree *urb_tree,
*/
if ((pinfo->p2p_dir==P2P_DIR_SENT || !iso_status) &&
iso_len && data_base + iso_off + iso_len <= tvb_reported_length(tvb)) {
- proto_tree_add_item(iso_desc_tree, hf_usb_iso_data, tvb, (guint) data_base + iso_off, iso_len, ENC_NA);
- proto_tree_set_appendix(iso_desc_tree, tvb, (guint) data_base + iso_off, (gint)iso_len);
+ proto_tree_add_item(iso_desc_tree, hf_usb_iso_data, tvb, (unsigned) data_base + iso_off, iso_len, ENC_NA);
+ proto_tree_set_appendix(iso_desc_tree, tvb, (unsigned) data_base + iso_off, (int)iso_len);
}
}
return desc_offset;
}
-static gint
+static int
dissect_darwin_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *tree, usb_header_t header_type _U_,
- guint8 urb_type _U_, tvbuff_t *tvb, gint32 offset, usb_conv_info_t *usb_conv_info)
+ uint8_t urb_type _U_, tvbuff_t *tvb, int32_t offset, urb_info_t *urb)
{
- guint32 frame_length;
- guint32 frame_header_length;
- guint32 status;
- guint32 iso_tree_start;
- guint32 i;
- guint32 iso_numdesc;
- guint32 len;
+ uint32_t frame_length;
+ uint32_t frame_header_length;
+ uint32_t status;
+ uint32_t iso_tree_start;
+ uint32_t i;
+ uint32_t iso_numdesc;
+ uint32_t len;
proto_item *tii;
- len = (gint32)tvb_captured_length(tvb);
+ len = (int32_t)tvb_captured_length(tvb);
len -= offset;
- tii = proto_tree_add_uint(tree, hf_usb_bInterfaceClass, tvb, offset, 0, usb_conv_info->interfaceClass);
+ tii = proto_tree_add_uint(tree, hf_usb_bInterfaceClass, tvb, offset, 0, urb->conv->interfaceClass);
proto_item_set_generated(tii);
- status = tvb_get_guint32(tvb, 8, ENC_LITTLE_ENDIAN);
- iso_numdesc = tvb_get_guint32(tvb, 12, ENC_LITTLE_ENDIAN);
+ status = tvb_get_uint32(tvb, 8, ENC_LITTLE_ENDIAN);
+ iso_numdesc = tvb_get_uint32(tvb, 12, ENC_LITTLE_ENDIAN);
iso_tree_start = offset;
for (i = 0; (i < iso_numdesc) && (len > 8 /* header len + frame len */); i++) {
@@ -4995,8 +5061,8 @@ dissect_darwin_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *tree, usb_he
proto_tree *iso_desc_tree;
/* Fetch ISO descriptor fields stored in little-endian byte order. */
- frame_header_length = tvb_get_guint32(tvb, offset, ENC_LITTLE_ENDIAN);
- frame_length = tvb_get_guint32(tvb, offset + 4, ENC_LITTLE_ENDIAN);
+ frame_header_length = tvb_get_uint32(tvb, offset, ENC_LITTLE_ENDIAN);
+ frame_length = tvb_get_uint32(tvb, offset + 4, ENC_LITTLE_ENDIAN);
if ((len < frame_header_length) || (frame_header_length < 20)) {
break;
@@ -5011,7 +5077,7 @@ dissect_darwin_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *tree, usb_he
proto_tree_add_item(iso_desc_tree, hf_usb_iso_len, tvb, offset + 4, 4, ENC_LITTLE_ENDIAN);
- if (usb_conv_info->is_request == FALSE) {
+ if (urb->is_request == false) {
proto_tree_add_item(iso_desc_tree, hf_usb_darwin_iso_timestamp, tvb, offset + 20, 8, ENC_LITTLE_ENDIAN);
proto_tree_add_item_ret_uint(iso_desc_tree, hf_usb_darwin_iso_status, tvb, offset + 8, 4, ENC_LITTLE_ENDIAN, &status);
@@ -5023,7 +5089,7 @@ dissect_darwin_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *tree, usb_he
}
proto_tree_add_item(iso_desc_tree, hf_usb_iso_data, tvb, offset + frame_header_length, frame_length, ENC_NA);
- proto_tree_set_appendix(iso_desc_tree, tvb, (gint)iso_tree_start, (gint)(offset - iso_tree_start));
+ proto_tree_set_appendix(iso_desc_tree, tvb, (int)iso_tree_start, (int)(offset - iso_tree_start));
len -= frame_length;
offset += frame_length;
@@ -5040,23 +5106,23 @@ dissect_darwin_usb_iso_transfer(packet_info *pinfo _U_, proto_tree *tree, usb_he
return offset;
}
-static gint
+static int
dissect_usb_payload(tvbuff_t *tvb, packet_info *pinfo,
proto_tree *parent, proto_tree *tree,
- usb_conv_info_t *usb_conv_info, guint8 urb_type,
- gint offset, guint16 device_address)
+ urb_info_t *urb, uint8_t urb_type,
+ int offset, uint16_t device_address)
{
wmem_tree_key_t key[4];
- guint32 k_frame_number;
- guint32 k_device_address;
- guint32 k_bus_id;
+ uint32_t k_frame_number;
+ uint32_t k_device_address;
+ uint32_t k_bus_id;
device_product_data_t *device_product_data = NULL;
device_protocol_data_t *device_protocol_data = NULL;
tvbuff_t *next_tvb = NULL;
k_frame_number = pinfo->num;
k_device_address = device_address;
- k_bus_id = usb_conv_info->bus_id;
+ k_bus_id = urb->bus_id;
key[0].length = 1;
key[0].key = &k_device_address;
@@ -5068,30 +5134,30 @@ dissect_usb_payload(tvbuff_t *tvb, packet_info *pinfo,
key[3].key = NULL;
device_product_data = (device_product_data_t *) wmem_tree_lookup32_array_le(device_to_product_table, key);
- if (device_product_data && device_product_data->bus_id == usb_conv_info->bus_id &&
+ if (device_product_data && device_product_data->bus_id == urb->bus_id &&
device_product_data->device_address == device_address) {
- p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_VENDOR_ID, GUINT_TO_POINTER((guint)device_product_data->vendor));
- p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_PRODUCT_ID, GUINT_TO_POINTER((guint)device_product_data->product));
- usb_conv_info->deviceVendor = device_product_data->vendor;
- usb_conv_info->deviceProduct = device_product_data->product;
- usb_conv_info->deviceVersion = device_product_data->device;
+ p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_VENDOR_ID, GUINT_TO_POINTER((unsigned)device_product_data->vendor));
+ p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_PRODUCT_ID, GUINT_TO_POINTER((unsigned)device_product_data->product));
+ urb->conv->deviceVendor = device_product_data->vendor;
+ urb->conv->deviceProduct = device_product_data->product;
+ urb->conv->deviceVersion = device_product_data->device;
}
device_protocol_data = (device_protocol_data_t *) wmem_tree_lookup32_array_le(device_to_protocol_table, key);
- if (device_protocol_data && device_protocol_data->bus_id == usb_conv_info->bus_id &&
+ if (device_protocol_data && device_protocol_data->bus_id == urb->bus_id &&
device_protocol_data->device_address == device_address) {
p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_CLASS, GUINT_TO_POINTER(device_protocol_data->protocol >> 16));
p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_SUBCLASS, GUINT_TO_POINTER((device_protocol_data->protocol >> 8) & 0xFF));
p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_PROTOCOL, GUINT_TO_POINTER(device_protocol_data->protocol & 0xFF));
- usb_conv_info->device_protocol = device_protocol_data->protocol;
+ urb->device_protocol = device_protocol_data->protocol;
}
- p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_BUS_ID, GUINT_TO_POINTER((guint)usb_conv_info->bus_id));
- p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_ADDRESS, GUINT_TO_POINTER((guint)device_address));
+ p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_BUS_ID, GUINT_TO_POINTER((unsigned)urb->bus_id));
+ p_add_proto_data(pinfo->pool, pinfo, proto_usb, USB_DEVICE_ADDRESS, GUINT_TO_POINTER((unsigned)device_address));
if (tvb_captured_length_remaining(tvb, offset) > 0) {
next_tvb = tvb_new_subset_remaining(tvb, offset);
- offset += try_dissect_next_protocol(parent, next_tvb, pinfo, usb_conv_info, urb_type, tree, NULL);
+ offset += try_dissect_next_protocol(parent, next_tvb, pinfo, urb, urb_type, tree, NULL);
}
if (tvb_captured_length_remaining(tvb, offset) > 0) {
@@ -5108,8 +5174,8 @@ dissect_freebsd_usb(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent, void
int offset = 0;
proto_item *ti;
proto_tree *tree = NULL, *frame_tree = NULL;
- guint32 nframes;
- guint32 i;
+ uint32_t nframes;
+ uint32_t i;
col_set_str(pinfo->cinfo, COL_PROTOCOL, "USB");
@@ -5140,8 +5206,8 @@ dissect_freebsd_usb(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent, void
offset += 128;
for (i = 0; i < nframes; i++) {
- guint32 framelen;
- guint64 frameflags;
+ uint32_t framelen;
+ uint64_t frameflags;
frame_tree = proto_tree_add_subtree_format(tree, tvb, offset, -1,
ett_usb_frame, &ti,
@@ -5171,7 +5237,7 @@ dissect_freebsd_usb(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent, void
}
static int
-netmon_HostController2(proto_tree *tree, tvbuff_t *tvb, int offset, guint16 flags)
+netmon_HostController2(proto_tree *tree, tvbuff_t *tvb, int offset, uint16_t flags)
{
proto_tree *host_tree;
@@ -5197,7 +5263,7 @@ netmon_UsbPortPath(proto_tree *tree, tvbuff_t *tvb, int offset, packet_info *pin
{
proto_item *path_item, *depth_item;
proto_tree *path_tree;
- guint32 path_depth, path0, path1, path2, path3, path4, path5;
+ uint32_t path_depth, path0, path1, path2, path3, path4, path5;
path_tree = proto_tree_add_subtree(tree, tvb, offset, 28, ett_usbport_path, &path_item, "PortPath: ");
depth_item = proto_tree_add_item_ret_uint(path_tree, hf_usbport_port_path_depth, tvb, offset, 4, ENC_LITTLE_ENDIAN, &path_depth);
@@ -5243,7 +5309,7 @@ netmon_UsbPortPath(proto_tree *tree, tvbuff_t *tvb, int offset, packet_info *pin
}
static int
-netmon_fid_USBPORT_Device(proto_tree *tree, tvbuff_t *tvb, int offset, guint16 flags, packet_info *pinfo)
+netmon_fid_USBPORT_Device(proto_tree *tree, tvbuff_t *tvb, int offset, uint16_t flags, packet_info *pinfo)
{
proto_item *device_item;
proto_tree *device_tree;
@@ -5264,7 +5330,7 @@ netmon_fid_USBPORT_Device(proto_tree *tree, tvbuff_t *tvb, int offset, guint16 f
}
static int
-netmon_fid_USBPORT_Endpoint(proto_tree *tree, tvbuff_t *tvb, int offset, guint16 flags)
+netmon_fid_USBPORT_Endpoint(proto_tree *tree, tvbuff_t *tvb, int offset, uint16_t flags)
{
proto_tree *endpoint_tree;
@@ -5299,11 +5365,11 @@ netmon_fid_USBPORT_Endpoint_Descriptor(proto_tree *tree, tvbuff_t *tvb, int offs
}
static int
-netmon_URB(proto_tree *tree, tvbuff_t *tvb, int offset, guint16 flags)
+netmon_URB(proto_tree *tree, tvbuff_t *tvb, int offset, uint16_t flags)
{
proto_item *urb_item;
proto_tree *urb_tree;
- guint32 func;
+ uint32_t func;
int i, start_offset = offset;
urb_tree = proto_tree_add_subtree(tree, tvb, offset, 8, ett_usbport_urb, &urb_item, "URB");
@@ -5388,10 +5454,10 @@ netmon_URB(proto_tree *tree, tvbuff_t *tvb, int offset, guint16 flags)
return offset;
}
-#define USBPORT_KEYWORD_DIAGNOSTIC G_GUINT64_CONSTANT(0x0000000000000001)
-#define USBPORT_KEYWORD_POWER_DIAGNOSTICS G_GUINT64_CONSTANT(0x0000000000000002)
-#define USBPORT_KEYWORD_PERF_DIAGNOSTICS G_GUINT64_CONSTANT(0x0000000000000004)
-#define USBPORT_KEYWORD_RESERVED1 G_GUINT64_CONSTANT(0xFFFFFFFFFFFFFFF8)
+#define USBPORT_KEYWORD_DIAGNOSTIC UINT64_C(0x0000000000000001)
+#define USBPORT_KEYWORD_POWER_DIAGNOSTICS UINT64_C(0x0000000000000002)
+#define USBPORT_KEYWORD_PERF_DIAGNOSTICS UINT64_C(0x0000000000000004)
+#define USBPORT_KEYWORD_RESERVED1 UINT64_C(0xFFFFFFFFFFFFFFF8)
static int
dissect_netmon_usb_port(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent, void* data)
@@ -5442,22 +5508,22 @@ void
dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
usb_header_t header_type, void *extra_data)
{
- gint offset = 0;
+ int offset = 0;
int endpoint;
- guint8 urb_type;
- guint32 win32_data_len = 0;
- guint32 iso_numdesc = 0;
- guint32 desc_offset = 0;
- guint32 location = 0;
+ uint8_t urb_type;
+ uint32_t win32_data_len = 0;
+ uint32_t iso_numdesc = 0;
+ uint32_t desc_offset = 0;
+ uint32_t location = 0;
proto_item *urb_tree_ti;
proto_tree *tree;
proto_item *item;
- usb_conv_info_t *usb_conv_info;
+ urb_info_t *urb;
conversation_t *conversation;
- guint16 device_address;
- guint16 bus_id;
- guint8 usbpcap_control_stage = 0;
- guint64 usb_id;
+ uint16_t device_address;
+ uint16_t bus_id;
+ uint8_t usbpcap_control_stage = 0;
+ uint64_t usb_id;
struct mausb_header *ma_header = NULL;
struct usbip_header *ip_header = NULL;
usb_pseudo_urb_t *pseudo_urb = NULL;
@@ -5470,22 +5536,21 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
case USB_HEADER_LINUX_48_BYTES:
case USB_HEADER_LINUX_64_BYTES:
- urb_type = tvb_get_guint8(tvb, 8);
- endpoint = tvb_get_guint8(tvb, 10) & 0x7F;
- device_address = (guint16)tvb_get_guint8(tvb, 11);
+ urb_type = tvb_get_uint8(tvb, 8);
+ endpoint = tvb_get_uint8(tvb, 10);
+ device_address = (uint16_t)tvb_get_uint8(tvb, 11);
bus_id = tvb_get_letohs(tvb, 12);
break;
case USB_HEADER_USBPCAP:
- urb_type = tvb_get_guint8(tvb, 16) & 0x01 ? URB_COMPLETE : URB_SUBMIT;
+ urb_type = tvb_get_uint8(tvb, 16) & 0x01 ? URB_COMPLETE : URB_SUBMIT;
device_address = tvb_get_letohs(tvb, 19);
- endpoint = tvb_get_guint8(tvb, 21);
- if ((endpoint == 0x00) && (tvb_get_guint8(tvb, 22) == URB_CONTROL) &&
- (tvb_get_guint8(tvb, 27) == USB_CONTROL_STAGE_DATA)) {
+ endpoint = tvb_get_uint8(tvb, 21);
+ if ((endpoint == 0x00) && (tvb_get_uint8(tvb, 22) == URB_CONTROL) &&
+ (tvb_get_uint8(tvb, 27) == USB_CONTROL_STAGE_DATA)) {
/* USBPcap before 1.3.0.0 DATA OUT packet (the info at offset 16 is wrong) */
urb_type = URB_SUBMIT;
}
- endpoint &= 0x7F; /* Clear the direction flag */
bus_id = tvb_get_letohs(tvb, 17);
break;
@@ -5495,6 +5560,10 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
device_address = mausb_ep_handle_dev_addr(ma_header->handle);
endpoint = mausb_ep_handle_ep_num(ma_header->handle);
bus_id = mausb_ep_handle_bus_num(ma_header->handle);
+ if (mausb_ep_handle_ep_d(ma_header->handle)) {
+ /* IN endpoint */
+ endpoint |= 0x80;
+ }
break;
case USB_HEADER_USBIP:
@@ -5503,12 +5572,16 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
device_address = ip_header->devid;
bus_id = ip_header->busid;
endpoint = ip_header->ep;
+ if (ip_header->dir == 1) {
+ /* IN endpoint */
+ endpoint |= 0x80;
+ }
break;
case USB_HEADER_DARWIN:
- urb_type = tvb_get_guint8(tvb, 3) ? URB_COMPLETE : URB_SUBMIT;
- endpoint = tvb_get_guint8(tvb, 30) & 0x7F;
- device_address = (guint16)tvb_get_guint8(tvb, 29);
+ urb_type = tvb_get_uint8(tvb, 3) ? URB_COMPLETE : URB_SUBMIT;
+ endpoint = tvb_get_uint8(tvb, 30);
+ device_address = (uint16_t)tvb_get_uint8(tvb, 29);
location = tvb_get_letohl(tvb, 24);
bus_id = location >> 24;
break;
@@ -5529,12 +5602,21 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
urb_tree_ti = proto_tree_add_protocol_format(parent, proto_usb, tvb, 0, -1, "USB URB");
tree = proto_item_add_subtree(urb_tree_ti, ett_usb_hdr);
+ if (endpoint == 0x80) {
+ /* Control endpoint is only bidirectional endpoint, use 0 to look up
+ * correct conversation.
+ */
+ endpoint = 0;
+ }
+
usb_set_addr(tree, tvb, pinfo, bus_id, device_address, endpoint,
(urb_type == URB_SUBMIT));
conversation = get_usb_conversation(pinfo, &pinfo->src, &pinfo->dst, pinfo->srcport, pinfo->destport);
- usb_conv_info = get_usb_conv_info(conversation);
- clear_usb_conv_tmp_data(usb_conv_info);
+ urb = wmem_new0(pinfo->pool, urb_info_t);
+ urb->conv = get_usb_conv_info(conversation);
+ urb->endpoint = endpoint;
+ clear_usb_conv_tmp_data(urb);
switch (header_type) {
@@ -5542,11 +5624,11 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
case USB_HEADER_LINUX_48_BYTES:
case USB_HEADER_LINUX_64_BYTES:
proto_item_set_len(urb_tree_ti, (header_type == USB_HEADER_LINUX_64_BYTES) ? 64 : 48);
- offset = dissect_linux_usb_pseudo_header(tvb, pinfo, tree, usb_conv_info, &usb_id);
+ offset = dissect_linux_usb_pseudo_header(tvb, pinfo, tree, urb, &usb_id);
break;
case USB_HEADER_USBPCAP:
- offset = dissect_usbpcap_buffer_packet_header(tvb, pinfo, tree, usb_conv_info, &win32_data_len, &usb_id);
+ offset = dissect_usbpcap_buffer_packet_header(tvb, pinfo, tree, urb, &win32_data_len, &usb_id);
/* the length that we're setting here might have to be corrected
if there's a transfer-specific pseudo-header following */
proto_item_set_len(urb_tree_ti, offset);
@@ -5555,21 +5637,21 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
case USB_HEADER_MAUSB:
/* MA USB header gets dissected earlier, just set conversation variables */
offset = MAUSB_DPH_LENGTH;
- mausb_set_usb_conv_info(usb_conv_info, ma_header);
+ mausb_set_urb_info(urb, ma_header);
usb_id = 0;
break;
case USB_HEADER_USBIP:
iso_numdesc = tvb_get_ntohl(tvb, 0x20);
- usb_conv_info->transfer_type = endpoint == 0 ? URB_CONTROL : (iso_numdesc != 0xffffffff ? URB_ISOCHRONOUS : URB_UNKNOWN);
- usb_conv_info->direction = ip_header->dir == USBIP_DIR_OUT ? P2P_DIR_SENT : P2P_DIR_RECV;
- usb_conv_info->is_setup = endpoint == 0 ? (tvb_get_ntoh64(tvb, 0x28) != G_GUINT64_CONSTANT(0)) : FALSE;
- usb_conv_info->is_request = (urb_type==URB_SUBMIT);
- offset = usb_conv_info->is_setup ? USBIP_HEADER_WITH_SETUP_LEN : USBIP_HEADER_LEN;
+ urb->transfer_type = endpoint == 0 ? URB_CONTROL : (iso_numdesc != 0xffffffff ? URB_ISOCHRONOUS : URB_UNKNOWN);
+ urb->direction = ip_header->dir == USBIP_DIR_OUT ? P2P_DIR_SENT : P2P_DIR_RECV;
+ urb->is_setup = endpoint == 0 ? (tvb_get_ntoh64(tvb, 0x28) != UINT64_C(0)) : false;
+ urb->is_request = (urb_type==URB_SUBMIT);
+ offset = urb->is_setup ? USBIP_HEADER_WITH_SETUP_LEN : USBIP_HEADER_LEN;
/* The ISOC descriptor is located at the end of the isoc frame behind the isoc data. */
- if ((usb_conv_info->is_request && usb_conv_info->direction == USBIP_DIR_OUT) ||
- (!usb_conv_info->is_request && usb_conv_info->direction == USBIP_DIR_IN)) {
+ if ((urb->is_request && urb->direction == USBIP_DIR_OUT) ||
+ (!urb->is_request && urb->direction == USBIP_DIR_IN)) {
desc_offset += tvb_get_ntohl(tvb, 0x18);
}
@@ -5578,16 +5660,16 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
break;
case USB_HEADER_DARWIN:
- offset = dissect_darwin_buffer_packet_header(tvb, pinfo, tree, usb_conv_info, &usb_id);
+ offset = dissect_darwin_buffer_packet_header(tvb, pinfo, tree, urb, &usb_id);
proto_item_set_len(urb_tree_ti, offset);
break;
case USB_HEADER_PSEUDO_URB:
- usb_conv_info->transfer_type = pseudo_urb->transfer_type;
- usb_conv_info->direction = pseudo_urb->from_host ? P2P_DIR_SENT : P2P_DIR_RECV;
- usb_conv_info->is_setup = pseudo_urb->from_host && (pseudo_urb->transfer_type == URB_CONTROL);
- usb_conv_info->is_request = pseudo_urb->from_host;
- usb_conv_info->speed = pseudo_urb->speed;
+ urb->transfer_type = pseudo_urb->transfer_type;
+ urb->direction = pseudo_urb->from_host ? P2P_DIR_SENT : P2P_DIR_RECV;
+ urb->is_setup = pseudo_urb->from_host && (pseudo_urb->transfer_type == URB_CONTROL);
+ urb->is_request = pseudo_urb->from_host;
+ urb->speed = pseudo_urb->speed;
usb_id = 0;
break;
@@ -5596,16 +5678,16 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
break;
}
- usb_conv_info->usb_trans_info = usb_get_trans_info(tvb, pinfo, tree, header_type, usb_conv_info, usb_id);
+ urb->usb_trans_info = usb_get_trans_info(tvb, pinfo, tree, header_type, urb, usb_id);
- if (usb_conv_info->transfer_type != URB_CONTROL) {
- usb_tap_queue_packet(pinfo, urb_type, usb_conv_info);
+ if (urb->transfer_type != URB_CONTROL) {
+ usb_tap_queue_packet(pinfo, urb_type, urb);
}
- switch(usb_conv_info->transfer_type) {
+ switch(urb->transfer_type) {
case URB_BULK:
case URB_INTERRUPT:
- item = proto_tree_add_uint(tree, hf_usb_bInterfaceClass, tvb, 0, 0, usb_conv_info->interfaceClass);
+ item = proto_tree_add_uint(tree, hf_usb_bInterfaceClass, tvb, 0, 0, urb->conv->interfaceClass);
proto_item_set_generated(item);
switch (header_type) {
@@ -5640,16 +5722,16 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
case URB_CONTROL:
if (header_type == USB_HEADER_USBPCAP) {
proto_tree_add_item(tree, hf_usb_win32_control_stage, tvb, offset, 1, ENC_LITTLE_ENDIAN);
- usbpcap_control_stage = tvb_get_guint8(tvb, offset);
+ usbpcap_control_stage = tvb_get_uint8(tvb, offset);
offset++;
proto_item_set_len(urb_tree_ti, offset);
if (usbpcap_control_stage == USB_CONTROL_STAGE_SETUP) {
- usb_conv_info->is_setup = TRUE;
+ urb->is_setup = true;
} else if (usbpcap_control_stage == USB_CONTROL_STAGE_DATA && urb_type == URB_SUBMIT) {
/* USBPcap before 1.5.0.0 */
wmem_tree_key_t key[3];
key[0].length = 2;
- key[0].key = (guint32 *)&usb_id;
+ key[0].key = (uint32_t *)&usb_id;
key[1].length = 1;
key[1].key = &pinfo->num;
key[2].length = 0;
@@ -5661,17 +5743,17 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
tvb_composite_append(reassembled_tvb, tvb_new_subset_remaining(tvb, offset));
tvb_composite_finalize(reassembled_tvb);
add_new_data_source(pinfo, reassembled_tvb, "USBPcap reassembled setup");
- usb_conv_info->is_setup = TRUE;
+ urb->is_setup = true;
tvb = reassembled_tvb;
offset = 0;
}
}
}
- if (usb_conv_info->is_request) {
- if (usb_conv_info->is_setup) {
+ if (urb->is_request) {
+ if (urb->is_setup) {
offset = dissect_usb_setup_request(pinfo, tree, tvb, offset, urb_type,
- usb_conv_info, header_type, usb_id);
+ urb, header_type, usb_id);
} else {
switch (header_type) {
@@ -5718,11 +5800,11 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
case USB_HEADER_USBPCAP:
/* Check if this is status stage */
- if ((usb_conv_info->usb_trans_info) &&
+ if ((urb->usb_trans_info) &&
(usbpcap_control_stage == USB_CONTROL_STAGE_STATUS)) {
- const gchar *description;
- if (USB_TYPE(usb_conv_info->usb_trans_info->setup.requesttype) == RQT_SETUP_TYPE_STANDARD) {
- description = val_to_str_ext(usb_conv_info->usb_trans_info->setup.request,
+ const char *description;
+ if (USB_TYPE(urb->usb_trans_info->setup.requesttype) == RQT_SETUP_TYPE_STANDARD) {
+ description = val_to_str_ext(urb->usb_trans_info->setup.request,
&setup_request_names_vals_ext, "Unknown type %x") ;
} else {
description = "URB_CONTROL";
@@ -5747,7 +5829,7 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
}
offset = dissect_usb_setup_response(pinfo, tree, tvb, offset,
- urb_type, usb_conv_info);
+ urb_type, urb);
}
break;
case URB_ISOCHRONOUS:
@@ -5756,12 +5838,12 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
case USB_HEADER_LINUX_48_BYTES:
case USB_HEADER_LINUX_64_BYTES:
offset = dissect_linux_usb_iso_transfer(pinfo, tree, header_type,
- tvb, offset, usb_conv_info);
+ tvb, offset, urb);
break;
case USB_HEADER_USBPCAP:
offset = dissect_usbpcap_iso_packets(pinfo, tree,
- urb_type, tvb, offset, win32_data_len, usb_conv_info);
+ urb_type, tvb, offset, win32_data_len, urb);
break;
case USB_HEADER_MAUSB:
@@ -5769,12 +5851,12 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
case USB_HEADER_USBIP:
offset = dissect_usbip_iso_transfer(pinfo, tree,
- tvb, offset, iso_numdesc, desc_offset, usb_conv_info);
+ tvb, offset, iso_numdesc, desc_offset, urb);
break;
case USB_HEADER_DARWIN:
offset = dissect_darwin_usb_iso_transfer(pinfo, tree, header_type,
- urb_type, tvb, offset, usb_conv_info);
+ urb_type, tvb, offset, urb);
break;
case USB_HEADER_PSEUDO_URB:
@@ -5812,7 +5894,7 @@ dissect_usb_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent,
break;
}
- dissect_usb_payload(tvb, pinfo, parent, tree, usb_conv_info, urb_type,
+ dissect_usb_payload(tvb, pinfo, parent, tree, urb, urb_type,
offset, device_address);
}
@@ -6793,7 +6875,7 @@ proto_register_usb(void)
{ &hf_usb_wMaxPacketSize_size,
{ "Maximum Packet Size", "usb.wMaxPacketSize.size",
- FT_UINT16, BASE_DEC, NULL, 0x03FF,
+ FT_UINT16, BASE_DEC, NULL, 0x07FF,
NULL, HFILL }},
{ &hf_usb_wMaxPacketSize_slots,
@@ -7277,7 +7359,7 @@ proto_register_usb(void)
},
};
- static gint *usb_subtrees[] = {
+ static int *usb_subtrees[] = {
&ett_usb_hdr,
&ett_usb_setup_hdr,
&ett_usb_isodesc,
@@ -7298,7 +7380,7 @@ proto_register_usb(void)
&ett_usb20ext_bmAttributes,
};
- static gint *usbport_subtrees[] = {
+ static int *usbport_subtrees[] = {
&ett_usbport,
&ett_usbport_host_controller,
&ett_usbport_path,
@@ -7351,13 +7433,13 @@ proto_register_usb(void)
usb_bulk_dissector_table = register_dissector_table("usb.bulk",
"USB bulk endpoint", proto_usb, FT_UINT32, BASE_HEX);
- heur_bulk_subdissector_list = register_heur_dissector_list("usb.bulk", proto_usb);
+ heur_bulk_subdissector_list = register_heur_dissector_list_with_description("usb.bulk", "USB bulk fallback", proto_usb);
usb_control_dissector_table = register_dissector_table("usb.control",
"USB control endpoint", proto_usb, FT_UINT32, BASE_HEX);
- heur_control_subdissector_list = register_heur_dissector_list("usb.control", proto_usb);
+ heur_control_subdissector_list = register_heur_dissector_list_with_description("usb.control", "USB control fallback", proto_usb);
usb_interrupt_dissector_table = register_dissector_table("usb.interrupt",
"USB interrupt endpoint", proto_usb, FT_UINT32, BASE_HEX);
- heur_interrupt_subdissector_list = register_heur_dissector_list("usb.interrupt", proto_usb);
+ heur_interrupt_subdissector_list = register_heur_dissector_list_with_description("usb.interrupt", "USB interrupt fallback", proto_usb);
usb_descriptor_dissector_table = register_dissector_table("usb.descriptor",
"USB descriptor", proto_usb, FT_UINT8, BASE_DEC);
@@ -7383,7 +7465,7 @@ proto_register_usb(void)
usb_address_type = address_type_dissector_register("AT_USB", "USB Address", usb_addr_to_str, usb_addr_str_len, NULL, usb_col_filter_str, NULL, NULL, NULL);
- register_conversation_table(proto_usb, TRUE, usb_conversation_packet, usb_endpoint_packet);
+ register_conversation_table(proto_usb, true, usb_conversation_packet, usb_endpoint_packet);
}
void