Skip to content

Commit

Permalink
test-ipmi-hiomap: Add protocol-recovery-get-flash-info-failure test
Browse files Browse the repository at this point in the history
[ Upstream commit 9398b84 ]

Cc: stable
Signed-off-by: Andrew Jeffery <andrew@aj.id.au>
Signed-off-by: Stewart Smith <stewart@linux.ibm.com>
Signed-off-by: Vasant Hegde <hegdevasant@linux.vnet.ibm.com>
  • Loading branch information
amboar authored and Vasant Hegde committed Mar 4, 2019
1 parent ffe0980 commit 0e8e03e
Showing 1 changed file with 195 additions and 0 deletions.
195 changes: 195 additions & 0 deletions libflash/test/test-ipmi-hiomap.c
Original file line number Diff line number Diff line change
Expand Up @@ -2368,6 +2368,29 @@ static const struct scenario_event hiomap_recovery_ack_call = {
},
};

static const struct scenario_event hiomap_recovery_get_info_call = {
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_GET_INFO,
.seq = 8,
.args = {
[0] = HIOMAP_V2,
},
},
.cc = IPMI_CC_NO_ERROR,
.resp = {
.cmd = HIOMAP_C_GET_INFO,
.seq = 8,
.args = {
[0] = HIOMAP_V2,
[1] = 12,
[2] = 8, [3] = 0,
},
},
},
};

static const struct scenario_event
scenario_hiomap_protocol_recovery_failure_ack[] = {
{ .type = scenario_event_p, .p = &hiomap_ack_call, },
Expand Down Expand Up @@ -2707,6 +2730,177 @@ static void test_hiomap_protocol_recovery_failure_get_info(void)
scenario_exit();
}

static const struct scenario_event
scenario_hiomap_protocol_recovery_failure_get_flash_info[] = {
{ .type = scenario_event_p, .p = &hiomap_ack_call, },
{ .type = scenario_event_p, .p = &hiomap_get_info_call, },
{ .type = scenario_event_p, .p = &hiomap_get_flash_info_call, },
{
.type = scenario_event_p,
.p = &hiomap_create_write_window_qs0l1_rs0l1_call,
},
{ .type = scenario_event_p, .p = &hiomap_erase_qs0l1_call, },
{ .type = scenario_event_p, .p = &hiomap_flush_call, },
{ .type = scenario_delay },
{
.type = scenario_sel,
.s = {
.bmc_state = HIOMAP_E_DAEMON_READY |
HIOMAP_E_PROTOCOL_RESET
}
},
{ .type = scenario_event_p, .p = &hiomap_recovery_ack_call, },
{ .type = scenario_event_p, .p = &hiomap_recovery_get_info_call},
{
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_GET_FLASH_INFO,
.seq = 9,
},
.cc = IPMI_ERR_UNSPECIFIED,
},

},
{
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_ACK,
.seq = 10,
.args = {
[0] = HIOMAP_E_PROTOCOL_RESET,
},
},
.cc = IPMI_CC_NO_ERROR,
.resp = {
.cmd = HIOMAP_C_ACK,
.seq = 10,
},
},
},
{
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_GET_INFO,
.seq = 11,
.args = {
[0] = HIOMAP_V2,
},
},
.cc = IPMI_CC_NO_ERROR,
.resp = {
.cmd = HIOMAP_C_GET_INFO,
.seq = 11,
.args = {
[0] = HIOMAP_V2,
[1] = 12,
[2] = 8, [3] = 0,
},
},
},
},
{
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_GET_FLASH_INFO,
.seq = 12,
.args = {
},
},
.cc = IPMI_CC_NO_ERROR,
.resp = {
.cmd = HIOMAP_C_GET_FLASH_INFO,
.seq = 12,
.args = {
[0] = 0x00, [1] = 0x20,
[2] = 0x01, [3] = 0x00,
},
},
},
},
{
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_CREATE_WRITE_WINDOW,
.seq = 13,
.args = {
[0] = 0x00, [1] = 0x00,
[2] = 0x01, [3] = 0x00,
},
},
.cc = IPMI_CC_NO_ERROR,
.resp = {
.cmd = HIOMAP_C_CREATE_WRITE_WINDOW,
.seq = 13,
.args = {
[0] = 0xff, [1] = 0x0f,
[2] = 0x01, [3] = 0x00,
[4] = 0x00, [5] = 0x00,
},
},
},
},
{
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_ERASE,
.seq = 14,
.args = {
[0] = 0x00, [1] = 0x00,
[2] = 0x01, [3] = 0x00,
},
},
.resp = {
.cmd = HIOMAP_C_ERASE,
.seq = 14,
},
},
},
{
.type = scenario_cmd,
.c = {
.req = {
.cmd = HIOMAP_C_FLUSH,
.seq = 15,
},
.resp = {
.cmd = HIOMAP_C_FLUSH,
.seq = 15,
},
},
},
SCENARIO_SENTINEL,
};

static void test_hiomap_protocol_recovery_failure_get_flash_info(void)
{
struct blocklevel_device *bl;
struct ipmi_hiomap *ctx;
size_t len;

scenario_enter(scenario_hiomap_protocol_recovery_failure_get_flash_info);
assert(!ipmi_hiomap_init(&bl));
ctx = container_of(bl, struct ipmi_hiomap, bl);
len = 1 << ctx->block_size_shift;
/*
* We're erasing the same block 3 times - it's irrelevant, we're just
* trying to manipulate window state
*/
assert(!bl->erase(bl, 0, len));
scenario_advance();
ctx = container_of(bl, struct ipmi_hiomap, bl);
len = 1 << ctx->block_size_shift;
assert(bl->erase(bl, 0, len) > 0);
assert(!bl->erase(bl, 0, len));
ipmi_hiomap_exit(bl);
scenario_exit();
}

struct test_case {
const char *name;
void (*fn)(void);
Expand Down Expand Up @@ -2764,6 +2958,7 @@ struct test_case test_cases[] = {
TEST_CASE(test_hiomap_erase_malformed_large),
TEST_CASE(test_hiomap_protocol_recovery_failure_ack),
TEST_CASE(test_hiomap_protocol_recovery_failure_get_info),
TEST_CASE(test_hiomap_protocol_recovery_failure_get_flash_info),
{ NULL, NULL },
};

Expand Down

0 comments on commit 0e8e03e

Please sign in to comment.