From 885b812fd68ae554a9b603a585cbe60fa67a0df9 Mon Sep 17 00:00:00 2001 From: Srikar Josyula Date: Thu, 17 Oct 2024 13:36:30 +0530 Subject: [PATCH] Relaxing MBWU monitor count check - Giving 30% room for MBWU monitor count when it encounters buffer memcpy Signed-off-by: Srikar Josyula Change-Id: I33113bb6eb06f231a02592ccd9dc779ccff1a300 --- test_pool/mpam/operating_system/test_mpam003.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/test_pool/mpam/operating_system/test_mpam003.c b/test_pool/mpam/operating_system/test_mpam003.c index f8ee632e..86ccec4f 100644 --- a/test_pool/mpam/operating_system/test_mpam003.c +++ b/test_pool/mpam/operating_system/test_mpam003.c @@ -37,6 +37,7 @@ static void payload(void) uint32_t rsrc_node_cnt, rsrc_index; uint64_t mpam2_el2, mpam2_el2_temp; uint64_t byte_count; + uint64_t byte_count_min; uint64_t addr_base, addr_len; uint64_t nrdy_timeout; uint32_t test_fails = 0; @@ -169,8 +170,12 @@ static void payload(void) val_print(ACS_PRINT_DEBUG, "\n byte_count = 0x%llx bytes", byte_count); /* the monitor must count both read and write bandwidth, - hence count must be twice of the buffer size */ - if ((byte_count != 2 * BUFFER_SIZE)) { + hence count must be twice of the buffer size + with 30% room for implementation differences */ + byte_count_min = 2 * BUFFER_SIZE - ((2 * BUFFER_SIZE * 3) / 10); + + /* Report fail if the monitor count does not belong within permitted range */ + if (!((byte_count > byte_count_min) && (byte_count <= 2 * BUFFER_SIZE))) { val_print(ACS_PRINT_ERR, "\n Monitor count incorrect for MSC %d", msc_index); val_print(ACS_PRINT_ERR, " rsrc node %d", rsrc_index);