bluetooth: host: Fix alignment of gatt_chrc

The following warning is issued by clang:

warning: field  within 'struct gatt_chrc' is less aligned than 'union
gatt_chrc::(anonymous at subsys/bluetooth/host/gatt.c:1859:2)' and
is usually due to 'struct gatt_chrc' being packed, which can lead
to unaligned accesses [-Wunaligned-access]

This is due to the fact that the uint16_t uuid field requires 2-byte
alignment but it is not marked as packed. Since the enclosing struct is
indeed packed, the required alignment is not guaranteed and so clang
complains. Fix it by ensuring that the union is marked as packed too.

Signed-off-by: Carles Cufi <carles.cufi@nordicsemi.no>
This commit is contained in:
Carles Cufi 2024-04-22 19:05:53 +02:00 committed by Johan Hedberg
parent f18ea95758
commit a1dd9a5f6e

View file

@ -1859,7 +1859,7 @@ struct gatt_chrc {
union {
uint16_t uuid16;
uint8_t uuid[16];
};
} __packed;
} __packed;
uint16_t bt_gatt_attr_value_handle(const struct bt_gatt_attr *attr)