2 * Copyright (C) 2018-2019 Lima Project
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20 * OTHER DEALINGS IN THE SOFTWARE.
28 #include <pipe/p_defines.h>
30 #include "util/u_debug.h"
32 #include "lima_util.h"
33 #include "lima_parser.h"
35 FILE *lima_dump_command_stream
= NULL
;
36 int lima_dump_frame_count
= 0;
38 bool lima_get_absolute_timeout(uint64_t *timeout
)
40 struct timespec current
;
43 if (*timeout
== PIPE_TIMEOUT_INFINITE
)
46 if (clock_gettime(CLOCK_MONOTONIC
, ¤t
))
49 current_ns
= ((uint64_t)current
.tv_sec
) * 1000000000ull;
50 current_ns
+= current
.tv_nsec
;
51 *timeout
+= current_ns
;
56 void lima_dump_blob(FILE *fp
, void *data
, int size
, bool is_float
)
59 for (int i
= 0; i
* 4 < size
; i
++) {
64 fprintf(fp
, "%f, ", ((float *)data
)[i
]);
66 fprintf(fp
, "0x%08x, ", ((uint32_t *)data
)[i
]);
68 if ((i
% 4 == 3) || (i
== size
/ 4 - 1)) {
69 fprintf(fp
, "/* 0x%08x */", MAX2((i
- 3) * 4, 0));
70 if (i
) fprintf(fp
, "\n");
77 lima_dump_vs_command_stream_print(void *data
, int size
, uint32_t start
)
79 if (lima_dump_command_stream
)
80 lima_parse_vs(lima_dump_command_stream
, (uint32_t *)data
, size
, start
);
84 lima_dump_plbu_command_stream_print(void *data
, int size
, uint32_t start
)
86 if (lima_dump_command_stream
)
87 lima_parse_plbu(lima_dump_command_stream
, (uint32_t *)data
, size
, start
);
91 lima_dump_rsw_command_stream_print(void *data
, int size
, uint32_t start
)
93 if (lima_dump_command_stream
)
94 lima_parse_render_state(lima_dump_command_stream
, (uint32_t *)data
, size
, start
);
98 lima_dump_texture_descriptor(void *data
, int size
, uint32_t start
, uint32_t offset
)
100 if (lima_dump_command_stream
)
101 lima_parse_texture_descriptor(lima_dump_command_stream
, (uint32_t *)data
, size
, start
, offset
);
105 lima_dump_file_open(void)
107 if (lima_dump_command_stream
)
111 const char *dump_command
= debug_get_option("LIMA_DUMP_FILE", "lima.dump");
112 snprintf(buffer
, sizeof(buffer
), "%s.%04d", dump_command
, lima_dump_frame_count
);
114 printf("lima: dump command stream to file %s\n", buffer
);
115 lima_dump_command_stream
= fopen(buffer
, "w");
116 if (!lima_dump_command_stream
)
117 fprintf(stderr
, "lima: failed to open command stream log file %s\n",
122 lima_dump_file_close(void)
124 if (lima_dump_command_stream
) {
125 fclose(lima_dump_command_stream
);
126 lima_dump_command_stream
= NULL
;
131 lima_dump_file_next(void)
133 if (lima_dump_command_stream
) {
134 lima_dump_file_close();
135 lima_dump_frame_count
++;
136 lima_dump_file_open();
141 lima_dump_command_stream_print(void *data
, int size
, bool is_float
,
142 const char *fmt
, ...)
144 if (lima_dump_command_stream
) {
147 vfprintf(lima_dump_command_stream
, fmt
, ap
);
150 lima_dump_blob(lima_dump_command_stream
, data
, size
, is_float
);