blob: 2c5963f18b75e0e6a51a3f94be8404eef1c7e534 [file] [log] [blame]
José Fonseca7e329022010-11-19 17:05:18 +00001/**************************************************************************
2 *
3 * Copyright 2010 VMware, Inc.
4 * All Rights Reserved.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 * copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22 * THE SOFTWARE.
23 *
24 **************************************************************************/
25
Jose Fonseca9653f952015-05-19 16:32:43 +010026#pragma once
José Fonseca7e329022010-11-19 17:05:18 +000027
28
José Fonseca7e329022010-11-19 17:05:18 +000029#include <iostream>
José Fonseca89851d02010-11-28 12:16:52 +000030#include <list>
José Fonseca7e329022010-11-19 17:05:18 +000031
Zack Rusin712429a2011-08-25 23:22:30 -040032#include "trace_file.hpp"
José Fonseca7e329022010-11-19 17:05:18 +000033#include "trace_format.hpp"
34#include "trace_model.hpp"
José Fonseca67964382012-03-27 23:54:30 +010035#include "trace_api.hpp"
José Fonseca7e329022010-11-19 17:05:18 +000036
37
José Fonsecab4a3d142011-10-27 07:43:19 +010038namespace trace {
José Fonseca7e329022010-11-19 17:05:18 +000039
José Fonseca61e61f72011-09-11 16:53:34 +010040
41struct ParseBookmark
42{
43 File::Offset offset;
44 unsigned next_call_no;
45};
46
47
Jose Fonsecac110dbc2017-06-23 13:04:17 +010048typedef std::map<std::string, std::string> Properties;
49
50
Jon Ashburn9459abf2014-09-04 23:03:37 +010051// Parser interface
52class AbstractParser
53{
54public:
55 virtual ~AbstractParser() {}
56 virtual Call *parse_call(void) = 0;
57 virtual void getBookmark(ParseBookmark &bookmark) = 0;
58 virtual void setBookmark(const ParseBookmark &bookmark) = 0;
59 virtual bool open(const char *filename) = 0;
60 virtual void close(void) = 0;
61 virtual unsigned long long getVersion(void) const = 0;
Jose Fonsecac110dbc2017-06-23 13:04:17 +010062 virtual const Properties & getProperties(void) const = 0;
63
64 const std::string & getProperty(const char *name) const;
Jon Ashburn9459abf2014-09-04 23:03:37 +010065};
66
67
68class Parser: public AbstractParser
José Fonseca7e329022010-11-19 17:05:18 +000069{
70protected:
Jose Fonsecae8a5de72017-06-22 15:18:52 +010071 File *file = nullptr;
José Fonsecafa922142010-11-25 09:36:04 +000072
José Fonsecae2d65222011-09-11 22:04:07 +010073 enum Mode {
74 FULL = 0,
75 SCAN,
76 SKIP
77 };
78
Jose Fonsecac110dbc2017-06-23 13:04:17 +010079 Properties properties;
80
José Fonseca19828972010-11-29 20:34:32 +000081 typedef std::list<Call *> CallList;
82 CallList calls;
José Fonseca34957132010-11-25 16:14:45 +000083
José Fonseca340f5692011-11-30 07:04:44 +000084 struct FunctionSigFlags : public FunctionSig {
85 CallFlags flags;
86 };
87
José Fonseca6a6d3e42011-09-11 14:14:21 +010088 // Helper template that extends a base signature structure, with additional
89 // parsing information.
90 template< class T >
91 struct SigState : public T {
92 // Offset in the file of where signature was defined. It is used when
93 // reparsing to determine whether the signature definition is to be
94 // expected next or not.
José Fonseca9c25e062013-05-06 07:25:40 +010095 File::Offset fileOffset;
José Fonseca6a6d3e42011-09-11 14:14:21 +010096 };
97
José Fonseca340f5692011-11-30 07:04:44 +000098 typedef SigState<FunctionSigFlags> FunctionSigState;
José Fonseca6a6d3e42011-09-11 14:14:21 +010099 typedef SigState<StructSig> StructSigState;
100 typedef SigState<EnumSig> EnumSigState;
101 typedef SigState<BitmaskSig> BitmaskSigState;
José Fonseca9c25e062013-05-06 07:25:40 +0100102 typedef SigState<StackFrame> StackFrameState;
José Fonseca6a6d3e42011-09-11 14:14:21 +0100103
104 typedef std::vector<FunctionSigState *> FunctionMap;
105 typedef std::vector<StructSigState *> StructMap;
106 typedef std::vector<EnumSigState *> EnumMap;
107 typedef std::vector<BitmaskSigState *> BitmaskMap;
José Fonseca9c25e062013-05-06 07:25:40 +0100108 typedef std::vector<StackFrameState *> StackFrameMap;
José Fonseca6a6d3e42011-09-11 14:14:21 +0100109
José Fonseca19828972010-11-29 20:34:32 +0000110 FunctionMap functions;
José Fonseca19828972010-11-29 20:34:32 +0000111 StructMap structs;
José Fonseca19828972010-11-29 20:34:32 +0000112 EnumMap enums;
José Fonseca19828972010-11-29 20:34:32 +0000113 BitmaskMap bitmasks;
José Fonseca9c25e062013-05-06 07:25:40 +0100114 StackFrameMap frames;
José Fonsecad35973c2010-11-26 14:14:45 +0000115
José Fonseca340f5692011-11-30 07:04:44 +0000116
Jose Fonsecae8a5de72017-06-22 15:18:52 +0100117 FunctionSig *glGetErrorSig = nullptr;
José Fonseca34957132010-11-25 16:14:45 +0000118
Jose Fonsecae8a5de72017-06-22 15:18:52 +0100119 int next_event_type = -1;
120 unsigned next_call_no = 0;
121
122 unsigned long long version = 0;
123 unsigned long long semanticVersion = 0;
124
Jon Ashburn9459abf2014-09-04 23:03:37 +0100125public:
Jose Fonsecae8a5de72017-06-22 15:18:52 +0100126 API api = API_UNKNOWN;
José Fonseca99221832011-03-22 22:15:46 +0000127
José Fonseca57dbaf52011-04-10 14:45:43 +0100128 Parser();
José Fonseca7e329022010-11-19 17:05:18 +0000129
José Fonseca57dbaf52011-04-10 14:45:43 +0100130 ~Parser();
José Fonseca6f51d3b2010-11-22 19:56:19 +0000131
Jose Fonseca697391f2016-03-05 14:44:37 +0000132 bool open(const char *filename) override;
José Fonseca7e329022010-11-19 17:05:18 +0000133
Jose Fonseca697391f2016-03-05 14:44:37 +0000134 void close(void) override;
José Fonseca7e329022010-11-19 17:05:18 +0000135
Jose Fonseca697391f2016-03-05 14:44:37 +0000136 Call *parse_call(void) override {
José Fonsecae2d65222011-09-11 22:04:07 +0100137 return parse_call(FULL);
138 }
José Fonseca7e329022010-11-19 17:05:18 +0000139
Zack Rusin712429a2011-08-25 23:22:30 -0400140 bool supportsOffsets() const
141 {
Zack Rusin7c767752011-09-01 11:33:51 -0400142 return file->supportsOffsets();
Zack Rusin712429a2011-08-25 23:22:30 -0400143 }
144
Jose Fonseca697391f2016-03-05 14:44:37 +0000145 void getBookmark(ParseBookmark &bookmark) override;
Zack Rusin712429a2011-08-25 23:22:30 -0400146
Jose Fonseca697391f2016-03-05 14:44:37 +0000147 void setBookmark(const ParseBookmark &bookmark) override;
Zack Rusine0df9522011-09-01 01:50:56 -0400148
Jose Fonseca697391f2016-03-05 14:44:37 +0000149 unsigned long long getVersion(void) const override {
Jose Fonsecae8a5de72017-06-22 15:18:52 +0100150 return semanticVersion;
Jon Ashburn9459abf2014-09-04 23:03:37 +0100151 }
152
Jose Fonsecac110dbc2017-06-23 13:04:17 +0100153 const Properties & getProperties(void) const override {
154 return properties;
155 }
156
Zack Rusin2b1bd4f2011-09-04 16:14:22 -0400157 int percentRead()
158 {
159 return file->percentRead();
160 }
161
José Fonsecae2d65222011-09-11 22:04:07 +0100162 Call *scan_call() {
163 return parse_call(SCAN);
164 }
Zack Rusin46c4a322011-09-02 01:08:49 -0400165
José Fonseca57dbaf52011-04-10 14:45:43 +0100166protected:
José Fonsecae2d65222011-09-11 22:04:07 +0100167 Call *parse_call(Mode mode);
168
José Fonseca340f5692011-11-30 07:04:44 +0000169 FunctionSigFlags *parse_function_sig(void);
José Fonseca6a6d3e42011-09-11 14:14:21 +0100170 StructSig *parse_struct_sig();
José Fonsecaeb644512011-12-11 10:33:55 +0000171 EnumSig *parse_old_enum_sig();
José Fonseca6a6d3e42011-09-11 14:14:21 +0100172 EnumSig *parse_enum_sig();
173 BitmaskSig *parse_bitmask_sig();
José Fonsecae2d65222011-09-11 22:04:07 +0100174
Jose Fonsecade9621f2015-08-14 00:10:21 +0100175public:
José Fonseca340f5692011-11-30 07:04:44 +0000176 static CallFlags
177 lookupCallFlags(const char *name);
178
Jose Fonsecade9621f2015-08-14 00:10:21 +0100179protected:
Jose Fonsecac110dbc2017-06-23 13:04:17 +0100180 void parseProperties(void);
181
José Fonsecae2d65222011-09-11 22:04:07 +0100182 Call *parse_Call(Mode mode);
José Fonseca6a6d3e42011-09-11 14:14:21 +0100183
José Fonsecae2d65222011-09-11 22:04:07 +0100184 void parse_enter(Mode mode);
Zack Rusin46c4a322011-09-02 01:08:49 -0400185
José Fonsecae2d65222011-09-11 22:04:07 +0100186 Call *parse_leave(Mode mode);
Zack Rusin46c4a322011-09-02 01:08:49 -0400187
José Fonsecae2d65222011-09-11 22:04:07 +0100188 bool parse_call_details(Call *call, Mode mode);
Zack Rusin46c4a322011-09-02 01:08:49 -0400189
Eugene Velesevichaa1b2132013-04-23 17:56:14 +0400190 bool parse_call_backtrace(Call *call, Mode mode);
José Fonseca9c25e062013-05-06 07:25:40 +0100191 StackFrame * parse_backtrace_frame(Mode mode);
Eugene Velesevichaa1b2132013-04-23 17:56:14 +0400192
José Fonseca340f5692011-11-30 07:04:44 +0000193 void adjust_call_flags(Call *call);
194
José Fonsecae2d65222011-09-11 22:04:07 +0100195 void parse_arg(Call *call, Mode mode);
Zack Rusin46c4a322011-09-02 01:08:49 -0400196
José Fonseca838decf2011-09-11 14:44:41 +0100197 Value *parse_value(void);
Zack Rusin46c4a322011-09-02 01:08:49 -0400198 void scan_value(void);
José Fonsecae2d65222011-09-11 22:04:07 +0100199 inline Value *parse_value(Mode mode) {
200 if (mode == FULL) {
201 return parse_value();
202 } else {
203 scan_value();
204 return NULL;
205 }
206 }
Zack Rusin46c4a322011-09-02 01:08:49 -0400207
José Fonseca838decf2011-09-11 14:44:41 +0100208 Value *parse_sint();
Zack Rusin46c4a322011-09-02 01:08:49 -0400209 void scan_sint();
210
José Fonseca838decf2011-09-11 14:44:41 +0100211 Value *parse_uint();
Zack Rusin46c4a322011-09-02 01:08:49 -0400212 void scan_uint();
213
José Fonseca838decf2011-09-11 14:44:41 +0100214 Value *parse_float();
Zack Rusin46c4a322011-09-02 01:08:49 -0400215 void scan_float();
216
José Fonseca838decf2011-09-11 14:44:41 +0100217 Value *parse_double();
Zack Rusin46c4a322011-09-02 01:08:49 -0400218 void scan_double();
219
José Fonseca838decf2011-09-11 14:44:41 +0100220 Value *parse_string();
Zack Rusin46c4a322011-09-02 01:08:49 -0400221 void scan_string();
222
José Fonseca838decf2011-09-11 14:44:41 +0100223 Value *parse_enum();
Zack Rusin46c4a322011-09-02 01:08:49 -0400224 void scan_enum();
225
José Fonseca838decf2011-09-11 14:44:41 +0100226 Value *parse_bitmask();
Zack Rusin46c4a322011-09-02 01:08:49 -0400227 void scan_bitmask();
228
José Fonseca838decf2011-09-11 14:44:41 +0100229 Value *parse_array(void);
Zack Rusin46c4a322011-09-02 01:08:49 -0400230 void scan_array(void);
231
José Fonseca838decf2011-09-11 14:44:41 +0100232 Value *parse_blob(void);
Zack Rusin46c4a322011-09-02 01:08:49 -0400233 void scan_blob(void);
234
José Fonseca838decf2011-09-11 14:44:41 +0100235 Value *parse_struct();
Zack Rusin46c4a322011-09-02 01:08:49 -0400236 void scan_struct();
237
José Fonseca838decf2011-09-11 14:44:41 +0100238 Value *parse_opaque();
Zack Rusin46c4a322011-09-02 01:08:49 -0400239 void scan_opaque();
240
José Fonseca112a1322012-04-27 17:15:32 +0100241 Value *parse_repr();
242 void scan_repr();
243
José Fonsecad5cda7c2014-09-25 15:19:09 +0100244 Value *parse_wstring();
245 void scan_wstring();
246
Jose Fonsecac110dbc2017-06-23 13:04:17 +0100247 char * read_string(void);
Zack Rusin46c4a322011-09-02 01:08:49 -0400248 void skip_string(void);
249
José Fonsecaeb644512011-12-11 10:33:55 +0000250 signed long long read_sint(void);
251 void skip_sint(void);
252
José Fonseca838decf2011-09-11 14:44:41 +0100253 unsigned long long read_uint(void);
Zack Rusin46c4a322011-09-02 01:08:49 -0400254 void skip_uint(void);
255
José Fonseca838decf2011-09-11 14:44:41 +0100256 inline int read_byte(void);
Zack Rusin46c4a322011-09-02 01:08:49 -0400257 inline void skip_byte(void);
José Fonseca7e329022010-11-19 17:05:18 +0000258};
259
260
Jose Fonseca0c287892015-10-14 14:19:01 +0100261AbstractParser *
262lastFrameLoopParser(AbstractParser *parser, int loopCount);
Jon Ashburn9459abf2014-09-04 23:03:37 +0100263
264
José Fonsecab4a3d142011-10-27 07:43:19 +0100265} /* namespace trace */
José Fonseca7e329022010-11-19 17:05:18 +0000266