hw/mem/cxl_type3: Fix More flag setting for dynamic capacity event records
Per cxl spec r3.1, for multiple dynamic capacity event records grouped via the More flag, the last record in the sequence should clear the More flag. Before the change, the More flag of the event record is cleared before the loop of inserting records into the event log, which will leave the flag always set once it is set in the loop. Fixes: d0b9b28a5b9f ("hw/cxl/events: Add qmp interfaces to add/release dynamic capacity extents") Signed-off-by: Fan Ni <fan.ni@samsung.com> Link: https://lore.kernel.org/r/20240827164304.88876-2-nifan.cxl@gmail.com Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> Message-Id: <20241014121902.2146424-5-Jonathan.Cameron@huawei.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
5eabca7ec0
commit
80ee960f8d
@ -2064,11 +2064,11 @@ static void qmp_cxl_process_dynamic_capacity_prescriptive(const char *path,
|
|||||||
stw_le_p(&dCap.host_id, hid);
|
stw_le_p(&dCap.host_id, hid);
|
||||||
/* only valid for DC_REGION_CONFIG_UPDATED event */
|
/* only valid for DC_REGION_CONFIG_UPDATED event */
|
||||||
dCap.updated_region_id = 0;
|
dCap.updated_region_id = 0;
|
||||||
dCap.flags = 0;
|
|
||||||
for (i = 0; i < num_extents; i++) {
|
for (i = 0; i < num_extents; i++) {
|
||||||
memcpy(&dCap.dynamic_capacity_extent, &extents[i],
|
memcpy(&dCap.dynamic_capacity_extent, &extents[i],
|
||||||
sizeof(CXLDCExtentRaw));
|
sizeof(CXLDCExtentRaw));
|
||||||
|
|
||||||
|
dCap.flags = 0;
|
||||||
if (i < num_extents - 1) {
|
if (i < num_extents - 1) {
|
||||||
/* Set "More" flag */
|
/* Set "More" flag */
|
||||||
dCap.flags |= BIT(0);
|
dCap.flags |= BIT(0);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user