2 NOEMIT CommPktChangeOrderCommand.file_name
5 HF_FIELD hf_frsrpc_CommPktChangeOrderCommand_file_name "File Name" "frsrpc.CommPktChangeOrderCommand.file_name" FT_STRING BASE_NONE NULL 0 "" "" ""
6 HF_FIELD hf_CommPktChunk "Chunk" "frsrpc.chunk.ctr.chunk" FT_NONE BASE_NONE NULL 0 "" "" ""
8 MANUAL frsrpc_dissect_struct_frsrpc_CommPktChunkCtr
9 MANUAL frsrpc_dissect_element_CommPktChangeOrderCommand_file_name
10 MANUAL frsrpc_dissect_enum_CommPktCommand
11 MANUAL frsrpc_dissect_struct_CommPktChunk
15 frsrpc_dissect_element_CommPktChangeOrderCommand_file_name(tvbuff_t *tvb _U_, int offset _U_, packet_info *pinfo _U_, proto_tree *tree _U_, dcerpc_info* di, uint8_t *drep _U_)
17 int conformant = di->conformant_run;
20 uint32_t soffset = dissect_null_term_wstring(tvb, offset, pinfo, tree, drep, hf_frsrpc_CommPktChangeOrderCommand_file_name, 0);
21 /* The difference has to be 4 due to the uint16 of the length + null terminator utf16*/
22 DISSECTOR_ASSERT(soffset - offset < 261);
30 frsrpc_dissect_struct_CommPktChunk(tvbuff_t *tvb _U_, int offset _U_, packet_info *pinfo _U_, proto_tree *parent_tree _U_, dcerpc_info* di, uint8_t *drep _U_, int hf_index _U_, uint32_t param _U_)
35 proto_item *item = NULL;
36 proto_tree *tree = NULL;
43 item = proto_tree_add_item(parent_tree, hf_index, tvb, offset, -1, ENC_NA);
44 tree = proto_item_add_subtree(item, ett_frsrpc_frsrpc_CommPktChunk);
47 offset = frsrpc_dissect_element_CommPktChunk_type(tvb, offset, pinfo, tree, di, drep, &type);
49 offset = frsrpc_dissect_element_CommPktChunk_data(tvb, offset, pinfo, tree, di, drep, type);
51 for (i=0; frsrpc_frsrpc_CommPktChunkType_vals[i].strptr; i++) {
52 if (frsrpc_frsrpc_CommPktChunkType_vals[i].value == type) {
53 s = frsrpc_frsrpc_CommPktChunkType_vals[i].strptr;
57 proto_item_append_text(item, ", type = %s", s);
59 proto_item_set_len(item, offset-old_offset);
62 if (di->call_data->flags & DCERPC_IS_NDR64) {
70 frsrpc_dissect_enum_CommPktCommand(tvbuff_t *tvb _U_, int offset _U_, packet_info *pinfo _U_, proto_tree *tree _U_, dcerpc_info* di, uint8_t *drep _U_, int hf_index _U_, uint32_t *param _U_)
76 parameter=(uint32_t)*param;
78 offset = dissect_ndr_uint32(tvb, offset, pinfo, tree, di, drep, hf_index, ¶meter);
80 for (i=0; frsrpc_frsrpc_CommPktCommand_vals[i].strptr != NULL; i++) {
81 if (frsrpc_frsrpc_CommPktCommand_vals[i].value == parameter) {
82 s = frsrpc_frsrpc_CommPktCommand_vals[i].strptr;
86 col_append_fstr(pinfo->cinfo, COL_INFO, ",command = %s",
90 *param=(uint32_t)parameter;
97 frsrpc_dissect_struct_frsrpc_CommPktChunkCtr(tvbuff_t *tvb, int offset, packet_info *pinfo, proto_tree *tree, dcerpc_info* di, uint8_t *drep _U_, int hf_index, uint32_t param _U_)
99 uint32_t remaining = tvb_reported_length_remaining(tvb, offset);
100 int align_status = di->no_align;
103 proto_item *item = proto_tree_add_item(tree, hf_index, tvb, offset, -1, ENC_NA);
104 proto_tree *subtree = proto_item_add_subtree(item, ett_ChunkCtr);
106 while (remaining > 0) {
107 offset = frsrpc_dissect_struct_CommPktChunk(tvb, offset, pinfo, subtree, di, drep, hf_CommPktChunk, param);
108 remaining = tvb_reported_length_remaining(tvb, offset);
110 di->no_align = align_status;