Coverage Report

Created: 2026-01-25 06:22

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/work/fu-elanfp-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-elanfp-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
 * fu_struct_elanfp_firmware_hdr_ref: (skip):
22
 **/
23
FuStructElanfpFirmwareHdr *
24
fu_struct_elanfp_firmware_hdr_ref(FuStructElanfpFirmwareHdr *st)
25
0
{
26
0
    g_return_val_if_fail(st != NULL, NULL);
27
0
    st->refcount++;
28
0
    return st;
29
0
}
30
/**
31
 * fu_struct_elanfp_firmware_hdr_unref: (skip):
32
 **/
33
void
34
fu_struct_elanfp_firmware_hdr_unref(FuStructElanfpFirmwareHdr *st)
35
437
{
36
437
    g_return_if_fail(st != NULL);
37
437
    if (st->refcount == 0) {
38
0
        g_critical("FuStructElanfpFirmwareHdr refcount already zero");
39
0
        return;
40
0
    }
41
437
    if (--st->refcount > 0)
42
0
        return;
43
437
    if (st->buf != NULL)
44
437
        g_byte_array_unref(st->buf);
45
437
    g_free(st);
46
437
}
47
/**
48
 * fu_struct_elanfp_firmware_hdr_new_internal: (skip):
49
 **/
50
static FuStructElanfpFirmwareHdr *
51
fu_struct_elanfp_firmware_hdr_new_internal(void)
52
437
{
53
437
    FuStructElanfpFirmwareHdr *st = g_new0(FuStructElanfpFirmwareHdr, 1);
54
437
    st->refcount = 1;
55
437
    return st;
56
437
}
57
58
/* getters */
59
/**
60
 * fu_struct_elanfp_firmware_hdr_get_magic: (skip):
61
 **/
62
static guint32
63
fu_struct_elanfp_firmware_hdr_get_magic(const FuStructElanfpFirmwareHdr *st)
64
491
{
65
491
    g_return_val_if_fail(st != NULL, 0x0);
66
491
    return fu_memread_uint32(st->buf->data + 0, G_LITTLE_ENDIAN);
67
491
}
68
69
/* setters */
70
static gboolean
71
fu_struct_elanfp_firmware_hdr_validate_internal(FuStructElanfpFirmwareHdr *st, GError **error)
72
431
{
73
431
    g_return_val_if_fail(st != NULL, FALSE);
74
431
    if (fu_struct_elanfp_firmware_hdr_get_magic(st) != 0x46325354) {
75
60
        g_set_error(error,
76
60
                    FWUPD_ERROR,
77
60
                    FWUPD_ERROR_INVALID_DATA,
78
60
                    "constant FuStructElanfpFirmwareHdr.magic was not valid, "
79
60
                    "expected 0x%x and got 0x%x",
80
60
                    (guint) 0x46325354,
81
60
                    (guint) fu_struct_elanfp_firmware_hdr_get_magic(st));
82
60
        return FALSE;
83
60
    }
84
371
    return TRUE;
85
431
}
86
/**
87
 * fu_struct_elanfp_firmware_hdr_validate_stream: (skip):
88
 **/
89
gboolean
90
fu_struct_elanfp_firmware_hdr_validate_stream(GInputStream *stream, gsize offset, GError **error)
91
437
{
92
437
    g_autoptr(FuStructElanfpFirmwareHdr) st = fu_struct_elanfp_firmware_hdr_new_internal();
93
437
    g_return_val_if_fail(G_IS_INPUT_STREAM(stream), FALSE);
94
437
    g_return_val_if_fail(error == NULL || *error == NULL, FALSE);
95
437
    st->buf = fu_input_stream_read_byte_array(stream, offset, 4, NULL, error);
96
437
    if (st->buf == NULL) {
97
0
        g_prefix_error(error, "FuStructElanfpFirmwareHdr failed read of 0x%x: ", (guint) 4);
98
0
        return FALSE;
99
0
    }
100
437
    if (st->buf->len != 4) {
101
6
        g_set_error(error,
102
6
                    FWUPD_ERROR,
103
6
                    FWUPD_ERROR_INVALID_DATA,
104
6
                    "FuStructElanfpFirmwareHdr requested 0x%x and got 0x%x",
105
6
                    (guint) 4,
106
6
                    (guint) st->buf->len);
107
6
        return FALSE;
108
6
    }
109
431
    return fu_struct_elanfp_firmware_hdr_validate_internal(st, error);
110
437
}