hw/mem/cxl_type3: Fix problem with g_steal_pointer()

When setting GLIB_VERSION_MAX_ALLOWED to GLIB_VERSION_2_58 or higher,
glib adds type safety checks to the g_steal_pointer() macro. This
triggers errors in the ct3_build_cdat_entries_for_mr() function which
uses the g_steal_pointer() for type-casting from one pointer type to
the other (which also looks quite weird since the local pointers have
all been declared with g_autofree though they are never freed here).
Fix it by using a proper typecast instead. For making this possible, we
have to remove the QEMU_PACKED attribute from some structs since GCC
otherwise complains that the source and destination pointer might
have different alignment restrictions. Removing the QEMU_PACKED should
be fine here since the structs are already naturally aligned. Anyway,
add some QEMU_BUILD_BUG_ON() statements to make sure that we've got
the right sizes (without padding in the structs).

Signed-off-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Reviewed-by: Michael Tokarev <mjt@tls.msk.ru>
Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
This commit is contained in:
Thomas Huth 2024-03-04 11:44:06 +01:00 committed by Michael Tokarev
parent c68f81fec8
commit 00691b1f6a
2 changed files with 18 additions and 15 deletions

View File

@ -46,12 +46,12 @@ static void ct3_build_cdat_entries_for_mr(CDATSubHeader **cdat_table,
int dsmad_handle, MemoryRegion *mr, int dsmad_handle, MemoryRegion *mr,
bool is_pmem, uint64_t dpa_base) bool is_pmem, uint64_t dpa_base)
{ {
g_autofree CDATDsmas *dsmas = NULL; CDATDsmas *dsmas;
g_autofree CDATDslbis *dslbis0 = NULL; CDATDslbis *dslbis0;
g_autofree CDATDslbis *dslbis1 = NULL; CDATDslbis *dslbis1;
g_autofree CDATDslbis *dslbis2 = NULL; CDATDslbis *dslbis2;
g_autofree CDATDslbis *dslbis3 = NULL; CDATDslbis *dslbis3;
g_autofree CDATDsemts *dsemts = NULL; CDATDsemts *dsemts;
dsmas = g_malloc(sizeof(*dsmas)); dsmas = g_malloc(sizeof(*dsmas));
*dsmas = (CDATDsmas) { *dsmas = (CDATDsmas) {
@ -135,12 +135,12 @@ static void ct3_build_cdat_entries_for_mr(CDATSubHeader **cdat_table,
}; };
/* Header always at start of structure */ /* Header always at start of structure */
cdat_table[CT3_CDAT_DSMAS] = g_steal_pointer(&dsmas); cdat_table[CT3_CDAT_DSMAS] = (CDATSubHeader *)dsmas;
cdat_table[CT3_CDAT_DSLBIS0] = g_steal_pointer(&dslbis0); cdat_table[CT3_CDAT_DSLBIS0] = (CDATSubHeader *)dslbis0;
cdat_table[CT3_CDAT_DSLBIS1] = g_steal_pointer(&dslbis1); cdat_table[CT3_CDAT_DSLBIS1] = (CDATSubHeader *)dslbis1;
cdat_table[CT3_CDAT_DSLBIS2] = g_steal_pointer(&dslbis2); cdat_table[CT3_CDAT_DSLBIS2] = (CDATSubHeader *)dslbis2;
cdat_table[CT3_CDAT_DSLBIS3] = g_steal_pointer(&dslbis3); cdat_table[CT3_CDAT_DSLBIS3] = (CDATSubHeader *)dslbis3;
cdat_table[CT3_CDAT_DSEMTS] = g_steal_pointer(&dsemts); cdat_table[CT3_CDAT_DSEMTS] = (CDATSubHeader *)dsemts;
} }
static int ct3_build_cdat_table(CDATSubHeader ***cdat_table, void *priv) static int ct3_build_cdat_table(CDATSubHeader ***cdat_table, void *priv)

View File

@ -82,7 +82,8 @@ typedef struct CDATDsmas {
uint16_t reserved; uint16_t reserved;
uint64_t DPA_base; uint64_t DPA_base;
uint64_t DPA_length; uint64_t DPA_length;
} QEMU_PACKED CDATDsmas; } CDATDsmas;
QEMU_BUILD_BUG_ON(sizeof(CDATDsmas) != 24);
/* Device Scoped Latency and Bandwidth Information Structure - CDAT Table 5 */ /* Device Scoped Latency and Bandwidth Information Structure - CDAT Table 5 */
typedef struct CDATDslbis { typedef struct CDATDslbis {
@ -95,7 +96,8 @@ typedef struct CDATDslbis {
uint64_t entry_base_unit; uint64_t entry_base_unit;
uint16_t entry[3]; uint16_t entry[3];
uint16_t reserved2; uint16_t reserved2;
} QEMU_PACKED CDATDslbis; } CDATDslbis;
QEMU_BUILD_BUG_ON(sizeof(CDATDslbis) != 24);
/* Device Scoped Memory Side Cache Information Structure - CDAT Table 6 */ /* Device Scoped Memory Side Cache Information Structure - CDAT Table 6 */
typedef struct CDATDsmscis { typedef struct CDATDsmscis {
@ -122,7 +124,8 @@ typedef struct CDATDsemts {
uint16_t reserved; uint16_t reserved;
uint64_t DPA_offset; uint64_t DPA_offset;
uint64_t DPA_length; uint64_t DPA_length;
} QEMU_PACKED CDATDsemts; } CDATDsemts;
QEMU_BUILD_BUG_ON(sizeof(CDATDsemts) != 24);
/* Switch Scoped Latency and Bandwidth Information Structure - CDAT Table 9 */ /* Switch Scoped Latency and Bandwidth Information Structure - CDAT Table 9 */
typedef struct CDATSslbisHeader { typedef struct CDATSslbisHeader {