318 lines
8.3 KiB
C
318 lines
8.3 KiB
C
|
/****************************************************************************
|
||
|
*
|
||
|
* The MIT License (MIT)
|
||
|
*
|
||
|
* Copyright 2020 NXP
|
||
|
* All Rights Reserved.
|
||
|
*
|
||
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||
|
* a copy of this software and associated documentation files (the
|
||
|
* 'Software'), to deal in the Software without restriction, including
|
||
|
* without limitation the rights to use, copy, modify, merge, publish,
|
||
|
* distribute, sub license, and/or sell copies of the Software, and to
|
||
|
* permit persons to whom the Software is furnished to do so, subject
|
||
|
* to the following conditions:
|
||
|
*
|
||
|
* The above copyright notice and this permission notice (including the
|
||
|
* next paragraph) shall be included in all copies or substantial
|
||
|
* portions of the Software.
|
||
|
*
|
||
|
* THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
||
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
|
||
|
* IN NO EVENT SHALL VIVANTE AND/OR ITS SUPPLIERS BE LIABLE FOR ANY
|
||
|
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||
|
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||
|
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
*
|
||
|
*****************************************************************************/
|
||
|
|
||
|
/** Include Files */
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
#include "vg_lite_text.h"
|
||
|
#include "vft_draw.h"
|
||
|
#include "vft_debug.h"
|
||
|
|
||
|
#ifdef ENABLE_DEBUG_TRACE
|
||
|
|
||
|
/** Macros */
|
||
|
|
||
|
/** Data structures */
|
||
|
typedef enum path_type {
|
||
|
PATH_DONE,
|
||
|
PATH_CLOSE,
|
||
|
MOVE_TO,
|
||
|
MOVE_TO_REL,
|
||
|
LINE_TO,
|
||
|
LINE_TO_REL,
|
||
|
QUAD_TO,
|
||
|
QUAD_TO_REL,
|
||
|
CUBI_TO,
|
||
|
CUBI_TO_REL,
|
||
|
NUM_PATH_CMD
|
||
|
} path_type_t;
|
||
|
|
||
|
/** Internal or external API prototypes */
|
||
|
|
||
|
/** Globals */
|
||
|
static const int data_count[] =
|
||
|
{
|
||
|
0,
|
||
|
0,
|
||
|
2,
|
||
|
2,
|
||
|
2,
|
||
|
2,
|
||
|
4,
|
||
|
4,
|
||
|
6,
|
||
|
6
|
||
|
};
|
||
|
|
||
|
static char s_cmd_name[][16] =
|
||
|
{
|
||
|
{"PATH_DONE" },
|
||
|
{"PATH_CLOSE" },
|
||
|
{"MOVE_TO" },
|
||
|
{"MOVE_TO_REL" },
|
||
|
{"LINE_TO" },
|
||
|
{"LINE_TO_REL" },
|
||
|
{"QUAD_TO" },
|
||
|
{"QUAD_TO_REL" },
|
||
|
{"CUBI_TO" },
|
||
|
{"CUBI_TO_REL" },
|
||
|
{"NUM_PATH_CMD"},
|
||
|
};
|
||
|
|
||
|
|
||
|
/** Externs if any */
|
||
|
|
||
|
/** Code section */
|
||
|
void vfg_dbg_path_data(path_desc_t* path_data_desc, int offset)
|
||
|
{
|
||
|
float* draw_cmds;
|
||
|
|
||
|
draw_cmds = &path_data_desc->draw_cmds[0];
|
||
|
|
||
|
for (int i = 0; i < path_data_desc->num_draw_cmds; i++) {
|
||
|
uint32_t cmd, j;
|
||
|
|
||
|
cmd = *((uint32_t*)(&draw_cmds[i]));
|
||
|
if (cmd < NUM_PATH_CMD) {
|
||
|
TRACE_BIN(("BIN: %08x: %s(%d) [",
|
||
|
offset + i * 4,
|
||
|
s_cmd_name[cmd], cmd));
|
||
|
for (j = 0; j < data_count[cmd]; j++) {
|
||
|
TRACE_BIN((" %.2f", draw_cmds[i + j + 1]));
|
||
|
}
|
||
|
i += j;
|
||
|
TRACE_BIN(("]\n"));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void vft_dbg_path(char *prefix, void *draw_cmds_args, int num_draw_cmds)
|
||
|
{
|
||
|
float* draw_cmds;
|
||
|
|
||
|
draw_cmds = draw_cmds_args;
|
||
|
int offset = 0;
|
||
|
for (int i = 0; i < num_draw_cmds; i++) {
|
||
|
uint32_t cmd, j;
|
||
|
|
||
|
cmd = *((uint32_t*)(&draw_cmds[i]));
|
||
|
if (cmd < NUM_PATH_CMD) {
|
||
|
printf("BIN: %08x: %s(%d) [",
|
||
|
offset + i * 4,
|
||
|
s_cmd_name[cmd], cmd);
|
||
|
for (j = 0; j < data_count[cmd]; j++) {
|
||
|
printf(" %.2f", draw_cmds[i + j + 1]);
|
||
|
}
|
||
|
i += j;
|
||
|
printf("]\n");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void vft_dbg_path_bounds(char *name, float *ary, int num_elements)
|
||
|
{
|
||
|
float* array_data;
|
||
|
|
||
|
array_data = ary;
|
||
|
printf("%s [",name);
|
||
|
for (int i = 0; i < num_elements; i++) {
|
||
|
printf(" %.2f", array_data[i]);
|
||
|
}
|
||
|
printf("]\n");
|
||
|
}
|
||
|
|
||
|
void vft_dbg_kern_desc(kern_desc_t* kern_desc, int num_kern_entries, int offset)
|
||
|
{
|
||
|
for (int i = 0; i < num_kern_entries; i++) {
|
||
|
TRACE_BIN(("BIN: %08x: [%d] (u,k)=(%hu, %hu)\n",
|
||
|
(int)(offset + i * sizeof(kern_desc_t)),
|
||
|
i,
|
||
|
kern_desc[i].unicode,
|
||
|
kern_desc[i].kern));
|
||
|
}
|
||
|
}
|
||
|
void vft_dbg_glyph_desc(glyph_desc_t* g, int offset)
|
||
|
{
|
||
|
glyph_desc_t _desc = *g; /* Temporary copy descriptor*/
|
||
|
|
||
|
TRACE_BIN_FIELD_UINT16(unicode);
|
||
|
TRACE_BIN_FIELD_UINT16(horiz_adv_x);
|
||
|
TRACE_BIN_FIELD_UINT32(kern_num_entries);
|
||
|
TRACE_BIN_FIELD_UINT32(kern_table_offset);
|
||
|
TRACE_BIN_FIELD_FLOAT(path.bounds[0]);
|
||
|
TRACE_BIN_FIELD_FLOAT(path.bounds[1]);
|
||
|
TRACE_BIN_FIELD_FLOAT(path.bounds[2]);
|
||
|
TRACE_BIN_FIELD_FLOAT(path.bounds[3]);
|
||
|
TRACE_BIN_FIELD_UINT32(path.num_draw_cmds);
|
||
|
TRACE_BIN_FIELD_UINT32(path.draw_cmds_offset);
|
||
|
|
||
|
}
|
||
|
|
||
|
/* TRACE values for debugging purpose */
|
||
|
void vft_dbg_font_face_desc(font_face_desc_t* font_face, int offset)
|
||
|
{
|
||
|
font_face_desc_t _desc = *font_face; /* Temporary copy descriptor*/
|
||
|
|
||
|
TRACE_INFO(("font-face-block\n"));
|
||
|
|
||
|
TRACE_BIN_FIELD_STR(font_family_name); offset += sizeof(_desc.font_family_name);
|
||
|
TRACE_BIN_FIELD_UINT16(units_per_em);
|
||
|
TRACE_BIN_FIELD_UINT16(ascent);
|
||
|
TRACE_BIN_FIELD_UINT16(descent);
|
||
|
TRACE_BIN_FIELD_UINT16(vg_font);
|
||
|
TRACE_BIN_FIELD_UINT32(num_glyphs);
|
||
|
}
|
||
|
|
||
|
void vft_dbg_matrix(char *name, vg_lite_matrix_t *mat)
|
||
|
{
|
||
|
printf("%s\n",name);
|
||
|
printf(" %0.3f %0.3f %0.3f\n",
|
||
|
mat->m[0][0],mat->m[0][1],mat->m[0][2]);
|
||
|
printf(" %0.3f %0.3f %0.3f\n",
|
||
|
mat->m[1][0],mat->m[1][1],mat->m[1][2]);
|
||
|
printf(" %0.3f %0.3f %0.3f\n",
|
||
|
mat->m[2][0],mat->m[1][1],mat->m[2][2]);
|
||
|
}
|
||
|
|
||
|
void vft_dbg_path_table(font_face_desc_t* font_face, int offset)
|
||
|
{
|
||
|
TRACE_INFO(("path-block\n"));
|
||
|
for (uint32_t i = 0; i < font_face->num_glyphs; i++) {
|
||
|
glyph_desc_t* g = &font_face->glyphs[i];
|
||
|
TRACE_BIN(("Glyph - path: '%c' unicode = %d\n", g->unicode, g->unicode));
|
||
|
offset = g->path.draw_cmds_offset;
|
||
|
vfg_dbg_path_data(&g->path, offset);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void vft_dbg_kern_table(font_face_desc_t* font_face, int offset)
|
||
|
{
|
||
|
TRACE_INFO(("kern-block\n"));
|
||
|
for (uint32_t i = 0; i < font_face->num_glyphs; i++) {
|
||
|
glyph_desc_t* g = &font_face->glyphs[i];
|
||
|
|
||
|
TRACE_INFO(("Kern: '%c' unicode=%hu\n", g->unicode, g->unicode));
|
||
|
|
||
|
vft_dbg_kern_desc(&g->kern_table[0],
|
||
|
g->kern_num_entries,
|
||
|
offset);
|
||
|
offset += (g->kern_num_entries * sizeof(kern_desc_t));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void vft_dbg_glyph_table(font_face_desc_t* font_face, int offset)
|
||
|
{
|
||
|
TRACE_INFO(("glyph-block\n"));
|
||
|
for (uint32_t i = 0; i < font_face->num_glyphs; i++) {
|
||
|
glyph_desc_t* g = &font_face->glyphs[i];
|
||
|
TRACE_INFO(("Glyph: '%c'\n", g->unicode));
|
||
|
vft_dbg_glyph_desc(g, offset);
|
||
|
offset += sizeof(glyph_desc_t);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
int g_offset = 0;
|
||
|
|
||
|
void dbg_float_ary(char *name, float *ary, int count, int *disk_offset)
|
||
|
{
|
||
|
int i;
|
||
|
int offset = *disk_offset;
|
||
|
for (i=0; i<count; i++) {
|
||
|
DBG_TRACE(("DBG: %s[%d]=%f offset=%d\n", \
|
||
|
name, \
|
||
|
i, \
|
||
|
ary[i], offset));
|
||
|
offset+= 4;
|
||
|
}
|
||
|
*disk_offset = offset;
|
||
|
}
|
||
|
|
||
|
void dbg_int_ary(char *name, uint32_t *ary, int count, int *disk_offset)
|
||
|
{
|
||
|
int i;
|
||
|
int offset = *disk_offset;
|
||
|
for (i=0; i<count; i++) {
|
||
|
DBG_TRACE(("DBG: %s[%d]=%d offset=%d\n", \
|
||
|
name, \
|
||
|
i, \
|
||
|
ary[i], offset));
|
||
|
offset+= 4;
|
||
|
}
|
||
|
*disk_offset = offset;
|
||
|
}
|
||
|
|
||
|
void dbg_int_param(char *name, uint32_t value, int *disk_offset)
|
||
|
{
|
||
|
int offset = *disk_offset;
|
||
|
DBG_TRACE(("DBG: %s=%d offset=%d\n", \
|
||
|
name, \
|
||
|
value, offset));
|
||
|
offset+= 4;
|
||
|
*disk_offset = offset;
|
||
|
}
|
||
|
|
||
|
void dbg_float_ary_no_offset_update(char *name, float *ary,
|
||
|
int count, int disk_offset)
|
||
|
{
|
||
|
int i;
|
||
|
int offset = disk_offset;
|
||
|
for (i=0; i<count; i++) {
|
||
|
DBG_TRACE(("DBG: %s[%d]=%f offset=%d\n", \
|
||
|
name, \
|
||
|
i, \
|
||
|
ary[i], offset));
|
||
|
offset+= 4;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void dbg_int_ary_no_offset_update(char *name, uint32_t *ary,
|
||
|
int count, int disk_offset)
|
||
|
{
|
||
|
int i;
|
||
|
int offset = disk_offset;
|
||
|
for (i=0; i<count; i++) {
|
||
|
DBG_TRACE(("DBG: %s[%d]=%d offset=%d\n", \
|
||
|
name, \
|
||
|
i, \
|
||
|
ary[i], offset));
|
||
|
offset+= 4;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void dbg_int_param_no_offset_update(char *name, uint32_t value, int disk_offset)
|
||
|
{
|
||
|
int offset = disk_offset;
|
||
|
DBG_TRACE(("DBG: %s=%d offset=%d\n", \
|
||
|
name, \
|
||
|
value, offset));
|
||
|
offset+= 4;
|
||
|
}
|
||
|
|
||
|
#endif
|