return conversation;
}
+/* 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)
+{
+ conversation_t *conversation;
+ guint32 if_port;
+
+ if_port = htolel(INTERFACE_PORT | interface_num);
+
+ if (pinfo->srcport == NO_ENDPOINT) {
+ conversation = get_usb_conversation(pinfo, &pinfo->src, &pinfo->dst, pinfo->srcport, if_port);
+ } else {
+ conversation = get_usb_conversation(pinfo, &pinfo->src, &pinfo->dst, if_port, pinfo->destport);
+ }
+
+ return get_usb_conv_info(conversation);
+}
/* SETUP dissectors */
/* bInterfaceNumber */
interface_num = tvb_get_guint8(tvb, offset);
proto_tree_add_item(tree, hf_usb_bInterfaceNumber, tvb, offset, 1, ENC_LITTLE_ENDIAN);
+ usb_conv_info->interfaceNum = interface_num;
offset += 1;
/* bAlternateSetting */
proto_item_append_text(item, " (%u.%u): class %s", interface_num, alt_setting, class_str);
if (!pinfo->fd->flags.visited && (alt_setting == 0)) {
- conversation_t *conversation;
- guint32 if_port;
-
- usb_trans_info->interface_info = se_alloc0(sizeof(usb_conv_info_t));
+ /* 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->interfaceClass = tvb_get_guint8(tvb, offset);
/* save the subclass so we can access it later in class-specific descriptors */
usb_trans_info->interface_info->interfaceSubclass = tvb_get_guint8(tvb, offset+1);
- usb_trans_info->interface_info->transactions = se_tree_create_non_persistent(EMEM_TREE_TYPE_RED_BLACK, "usb transactions");
-
- /* Register conversation for this interface in case CONTROL messages are sent to it */
- if_port = htolel(INTERFACE_PORT | interface_num);
- conversation = get_usb_conversation(pinfo, &pinfo->src, &pinfo->dst, if_port, pinfo->destport);
- conversation_add_proto_data(conversation, proto_usb, usb_trans_info->interface_info);
}
offset += 1;
case RQT_SETUP_TYPE_CLASS:
/* Make sure we have the proper conversation */
if (USB_RECIPIENT(usb_trans_info->setup.requesttype) == RQT_SETUP_RECIPIENT_INTERFACE) {
- guint16 interface_num = usb_trans_info->setup.wIndex & 0xff;
- guint32 if_port = htolel(INTERFACE_PORT | interface_num);
- conversation = get_usb_conversation(pinfo, &pinfo->src, &pinfo->dst, pinfo->srcport, if_port);
- usb_conv_info = get_usb_conv_info(conversation);
+ guint8 interface_num = usb_trans_info->setup.wIndex & 0xff;
+ usb_conv_info = get_usb_iface_conv_info(pinfo, interface_num);
usb_conv_info->usb_trans_info = usb_trans_info;
pinfo->usb_conv_info = usb_conv_info;
} else if (USB_RECIPIENT(usb_trans_info->setup.requesttype) == RQT_SETUP_RECIPIENT_ENDPOINT) {
if (usb_trans_info) {
if (USB_TYPE(usb_trans_info->setup.requesttype) == RQT_SETUP_TYPE_CLASS) {
if (USB_RECIPIENT(usb_trans_info->setup.requesttype) == RQT_SETUP_RECIPIENT_INTERFACE) {
- guint32 if_port = htolel(INTERFACE_PORT | (usb_trans_info->setup.wIndex & 0xff));
- conversation = get_usb_conversation(pinfo, &pinfo->src, &pinfo->dst, if_port, pinfo->destport);
- usb_conv_info = get_usb_conv_info(conversation);
+ guint8 interface_num = usb_trans_info->setup.wIndex & 0xff;
+ usb_conv_info = get_usb_iface_conv_info(pinfo, interface_num);
usb_conv_info->usb_trans_info = usb_trans_info;
pinfo->usb_conv_info = usb_conv_info;
} else if (USB_RECIPIENT(usb_trans_info->setup.requesttype) == RQT_SETUP_RECIPIENT_ENDPOINT) {
struct _usb_conv_info_t {
guint16 interfaceClass; /* class for this conversation */
guint16 interfaceSubclass; /* Most recent interface descriptor subclass */
+ guint8 interfaceNum; /* Most recent interface number */
emem_tree_t *transactions;
usb_trans_info_t *usb_trans_info; /* pointer to the current transaction */
void *class_data; /* private class/id decode data */
#define ENDPOINT_TYPE_BULK 2
#define ENDPOINT_TYPE_INTERRUPT 3
+usb_conv_info_t *get_usb_iface_conv_info(packet_info *pinfo, guint8 interface_num);
+
void dissect_usb_descriptor_header(proto_tree *tree, tvbuff_t *tvb, int offset);
void dissect_usb_endpoint_address(proto_tree *tree, tvbuff_t *tvb, int offset);