sq epan/dissectors/pidl/rcg/rcg.cnf
[wireshark-sm.git] / epan / dissectors / pidl / frsrpc / frsrpc.cnf
blobcbd32d4d9a56cf54b925572d100a771699f34e69
1 NOEMIT CommPktChunkCtr
2 NOEMIT CommPktChangeOrderCommand.file_name
4 ETT_FIELD ett_ChunkCtr
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
13 CODE START
14 static int
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;
19         if (!conformant) {
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);
23                 offset += 261;
24         }
26         return offset;
29 int
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_)
32         uint32_t type = 0;
33         int i = 0;
34         const char *s = NULL;
35         proto_item *item = NULL;
36         proto_tree *tree = NULL;
37         int old_offset;
40         old_offset = offset;
42         if (parent_tree) {
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);
45         }
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;
54                 }
55         }
56         if (s != NULL) {
57                 proto_item_append_text(item, ", type = %s", s);
58         }
59         proto_item_set_len(item, offset-old_offset);
62         if (di->call_data->flags & DCERPC_IS_NDR64) {
63                 ALIGN_TO_3_BYTES;
64         }
66         return offset;
69 int
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_)
72         uint32_t parameter=0;
73         int i = 0;
74         const char *s = NULL;
75         if(param){
76                 parameter=(uint32_t)*param;
77         }
78         offset = dissect_ndr_uint32(tvb, offset, pinfo, tree, di, drep, hf_index, &parameter);
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;
83                 }
84         }
85         if (s!= NULL)
86                 col_append_fstr(pinfo->cinfo, COL_INFO, ",command = %s",
87                                 s);
89         if(param){
90                 *param=(uint32_t)parameter;
91         }
92         return offset;
96 static int
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;
102         if (remaining > 0) {
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);
105                 di->no_align = 1;
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);
109                 }
110                 di->no_align = align_status;
111         }
112         return offset;
115 CODE END