Coverage Report

Created: 2026-01-09 07:21

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/work/fu-synaptics-mst-struct.c
Line
Count
Source
1
/*
2
 * This file is auto-generated, do not modify!
3
 *
4
 * SPDX-License-Identifier: LGPL-2.1-or-later
5
 */
6
7
#include "config.h"
8
9
#include <glib.h>
10
11
#include "fu-synaptics-mst-struct.h"
12
#include "fu-byte-array.h"
13
#include "fu-mem-private.h"
14
#include "fu-string.h"
15
16
#ifdef G_LOG_DOMAIN
17
  #undef G_LOG_DOMAIN
18
#endif
19
0
#define G_LOG_DOMAIN "FuStruct"
20
21
/**
22
 * fu_synaptics_mst_family_to_string:
23
 * @val: value, e.g. %FU_SYNAPTICS_MST_FAMILY_TESLA
24
 *
25
 * Converts an enumerated value to a string.
26
 *
27
 * Returns: identifier string
28
 **/
29
const gchar *
30
fu_synaptics_mst_family_to_string(FuSynapticsMstFamily val)
31
20
{
32
20
    if (val == FU_SYNAPTICS_MST_FAMILY_TESLA)
33
0
        return "tesla";
34
20
    if (val == FU_SYNAPTICS_MST_FAMILY_LEAF)
35
0
        return "leaf";
36
20
    if (val == FU_SYNAPTICS_MST_FAMILY_PANAMERA)
37
0
        return "panamera";
38
20
    if (val == FU_SYNAPTICS_MST_FAMILY_CAYENNE)
39
0
        return "cayenne";
40
20
    if (val == FU_SYNAPTICS_MST_FAMILY_SPYDER)
41
0
        return "spyder";
42
20
    if (val == FU_SYNAPTICS_MST_FAMILY_CARRERA)
43
0
        return "carrera";
44
20
    return NULL;
45
20
}
46
47
/**
48
 * fu_synaptics_mst_updc_rc_to_string:
49
 * @val: value, e.g. %FU_SYNAPTICS_MST_UPDC_RC_INVALID
50
 *
51
 * Converts an enumerated value to a string.
52
 *
53
 * Returns: identifier string
54
 **/
55
const gchar *
56
fu_synaptics_mst_updc_rc_to_string(FuSynapticsMstUpdcRc val)
57
0
{
58
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_SUCCESS)
59
0
        return "success";
60
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_INVALID)
61
0
        return "invalid";
62
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_UNSUPPORTED)
63
0
        return "unsupported";
64
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_FAILED)
65
0
        return "failed";
66
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_DISABLED)
67
0
        return "disabled";
68
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_CONFIGURE_SIGN_FAILED)
69
0
        return "configure-sign-failed";
70
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_FIRMWARE_SIGN_FAILED)
71
0
        return "firmware-sign-failed";
72
0
    if (val == FU_SYNAPTICS_MST_UPDC_RC_ROLLBACK_FAILED)
73
0
        return "rollback-failed";
74
0
    return NULL;
75
0
}
76
77
/**
78
 * fu_synaptics_mst_updc_cmd_to_string:
79
 * @val: value, e.g. %FU_SYNAPTICS_MST_UPDC_CMD_DISABLE_RC
80
 *
81
 * Converts an enumerated value to a string.
82
 *
83
 * Returns: identifier string
84
 **/
85
const gchar *
86
fu_synaptics_mst_updc_cmd_to_string(FuSynapticsMstUpdcCmd val)
87
0
{
88
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_ENABLE_RC)
89
0
        return "enable-rc";
90
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_DISABLE_RC)
91
0
        return "disable-rc";
92
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_GET_ID)
93
0
        return "get-id";
94
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_GET_VERSION)
95
0
        return "get-version";
96
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_FLASH_MAPPING)
97
0
        return "flash-mapping";
98
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_ENABLE_FLASH_CHIP_ERASE)
99
0
        return "enable-flash-chip-erase";
100
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_CAL_EEPROM_CHECKSUM)
101
0
        return "cal-eeprom-checksum";
102
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_FLASH_ERASE)
103
0
        return "flash-erase";
104
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_CAL_EEPROM_CHECK_CRC8)
105
0
        return "cal-eeprom-check-crc8";
106
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_CAL_EEPROM_CHECK_CRC16)
107
0
        return "cal-eeprom-check-crc16";
108
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_ACTIVATE_FIRMWARE)
109
0
        return "activate-firmware";
110
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_WRITE_TO_EEPROM)
111
0
        return "write-to-eeprom";
112
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_WRITE_TO_MEMORY)
113
0
        return "write-to-memory";
114
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_WRITE_TO_TX_DPCD)
115
0
        return "write-to-tx-dpcd";
116
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_WRITE_TO_TX_DPCD_TX1)
117
0
        return "write-to-tx-dpcd-tx1";
118
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_WRITE_TO_TX_DPCD_TX2)
119
0
        return "write-to-tx-dpcd-tx2";
120
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_WRITE_TO_TX_DPCD_TX3)
121
0
        return "write-to-tx-dpcd-tx3";
122
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_READ_FROM_EEPROM)
123
0
        return "read-from-eeprom";
124
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_READ_FROM_MEMORY)
125
0
        return "read-from-memory";
126
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_READ_FROM_TX_DPCD)
127
0
        return "read-from-tx-dpcd";
128
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_READ_FROM_TX_DPCD_TX1)
129
0
        return "read-from-tx-dpcd-tx1";
130
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_READ_FROM_TX_DPCD_TX2)
131
0
        return "read-from-tx-dpcd-tx2";
132
0
    if (val == FU_SYNAPTICS_MST_UPDC_CMD_READ_FROM_TX_DPCD_TX3)
133
0
        return "read-from-tx-dpcd-tx3";
134
0
    return NULL;
135
0
}
136
137
/**
138
 * fu_struct_synaptics_firmware_config_ref: (skip):
139
 **/
140
FuStructSynapticsFirmwareConfig *
141
fu_struct_synaptics_firmware_config_ref(FuStructSynapticsFirmwareConfig *st)
142
0
{
143
0
    g_return_val_if_fail(st != NULL, NULL);
144
0
    st->refcount++;
145
0
    return st;
146
0
}
147
/**
148
 * fu_struct_synaptics_firmware_config_unref: (skip):
149
 **/
150
void
151
fu_struct_synaptics_firmware_config_unref(FuStructSynapticsFirmwareConfig *st)
152
299
{
153
299
    g_return_if_fail(st != NULL);
154
299
    if (st->refcount == 0) {
155
0
        g_critical("FuStructSynapticsFirmwareConfig refcount already zero");
156
0
        return;
157
0
    }
158
299
    if (--st->refcount > 0)
159
0
        return;
160
299
    if (st->buf != NULL)
161
224
        g_byte_array_unref(st->buf);
162
299
    g_free(st);
163
299
}
164
/**
165
 * fu_struct_synaptics_firmware_config_new_internal: (skip):
166
 **/
167
static FuStructSynapticsFirmwareConfig *
168
fu_struct_synaptics_firmware_config_new_internal(void)
169
299
{
170
299
    FuStructSynapticsFirmwareConfig *st = g_new0(FuStructSynapticsFirmwareConfig, 1);
171
299
    st->refcount = 1;
172
299
    return st;
173
299
}
174
175
/* getters */
176
/**
177
 * fu_struct_synaptics_firmware_config_get_version: (skip):
178
 **/
179
guint8
180
fu_struct_synaptics_firmware_config_get_version(const FuStructSynapticsFirmwareConfig *st)
181
67
{
182
67
    g_return_val_if_fail(st != NULL, 0x0);
183
67
    return st->buf->data[0];
184
67
}
185
/**
186
 * fu_struct_synaptics_firmware_config_get_magic1: (skip):
187
 **/
188
guint8
189
fu_struct_synaptics_firmware_config_get_magic1(const FuStructSynapticsFirmwareConfig *st)
190
219
{
191
219
    g_return_val_if_fail(st != NULL, 0x0);
192
219
    return st->buf->data[2];
193
219
}
194
/**
195
 * fu_struct_synaptics_firmware_config_get_magic2: (skip):
196
 **/
197
guint8
198
fu_struct_synaptics_firmware_config_get_magic2(const FuStructSynapticsFirmwareConfig *st)
199
105
{
200
105
    g_return_val_if_fail(st != NULL, 0x0);
201
105
    return st->buf->data[3];
202
105
}
203
204
/* setters */
205
/**
206
 * fu_struct_synaptics_firmware_config_to_string: (skip):
207
 **/
208
static gchar *
209
fu_struct_synaptics_firmware_config_to_string(const FuStructSynapticsFirmwareConfig *st)
210
0
{
211
0
    g_autoptr(GString) str = g_string_new("FuStructSynapticsFirmwareConfig:\n");
212
0
    g_return_val_if_fail(st != NULL, NULL);
213
0
    g_string_append_printf(str, "  version: 0x%x\n",
214
0
                           (guint) fu_struct_synaptics_firmware_config_get_version(st));
215
0
    g_string_append_printf(str, "  magic1: 0x%x\n",
216
0
                           (guint) fu_struct_synaptics_firmware_config_get_magic1(st));
217
0
    g_string_append_printf(str, "  magic2: 0x%x\n",
218
0
                           (guint) fu_struct_synaptics_firmware_config_get_magic2(st));
219
0
    if (str->len > 0)
220
0
        g_string_set_size(str, str->len - 1);
221
0
    return g_string_free(g_steal_pointer(&str), FALSE);
222
0
}
223
static gboolean
224
fu_struct_synaptics_firmware_config_validate_internal(FuStructSynapticsFirmwareConfig *st, GError **error)
225
219
{
226
219
    g_return_val_if_fail(st != NULL, FALSE);
227
219
    return TRUE;
228
219
}
229
static gboolean
230
fu_struct_synaptics_firmware_config_parse_internal(FuStructSynapticsFirmwareConfig *st, GError **error)
231
219
{
232
219
    if (g_getenv("FWUPD_VERBOSE") != NULL) {
233
0
        g_autofree gchar *str = fu_struct_synaptics_firmware_config_to_string(st);
234
0
        g_debug("%s", str);
235
0
    }
236
219
    if (!fu_struct_synaptics_firmware_config_validate_internal(st, error))
237
0
        return FALSE;
238
219
    return TRUE;
239
219
}
240
/**
241
 * fu_struct_synaptics_firmware_config_parse_stream: (skip):
242
 **/
243
FuStructSynapticsFirmwareConfig *
244
fu_struct_synaptics_firmware_config_parse_stream(GInputStream *stream, gsize offset, GError **error)
245
299
{
246
299
    g_autoptr(FuStructSynapticsFirmwareConfig) st = fu_struct_synaptics_firmware_config_new_internal();
247
299
    st->buf = fu_input_stream_read_byte_array(stream, offset, 4, NULL, error);
248
299
    if (st->buf == NULL) {
249
75
        g_prefix_error(error, "FuStructSynapticsFirmwareConfig failed read of 0x%x: ", (guint) 4);
250
75
        return NULL;
251
75
    }
252
224
    if (st->buf->len != 4) {
253
5
        g_set_error(error,
254
5
                    FWUPD_ERROR,
255
5
                    FWUPD_ERROR_INVALID_DATA,
256
5
                    "FuStructSynapticsFirmwareConfig requested 0x%x and got 0x%x",
257
5
                    (guint) 4,
258
5
                    (guint) st->buf->len);
259
5
        return NULL;
260
5
    }
261
219
    if (!fu_struct_synaptics_firmware_config_parse_internal(st, error))
262
0
        return NULL;
263
219
    return g_steal_pointer(&st);
264
219
}