diff --git a/programs/bpf/c/src/error_handling/error_handling.c b/programs/bpf/c/src/error_handling/error_handling.c index cd611bed6ad953..36e0740c20921b 100644 --- a/programs/bpf/c/src/error_handling/error_handling.c +++ b/programs/bpf/c/src/error_handling/error_handling.c @@ -9,7 +9,7 @@ */ extern uint64_t entrypoint(const uint8_t *input) { - SolKeyedAccount ka[4]; + SolKeyedAccount ka[1]; SolParameters params = (SolParameters) { .ka = ka }; if (!sol_deserialize(input, ¶ms, SOL_ARRAY_SIZE(ka))) { diff --git a/sdk/bpf/c/inc/solana_sdk.h b/sdk/bpf/c/inc/solana_sdk.h index 340d58fbc5305f..b188e14daad881 100644 --- a/sdk/bpf/c/inc/solana_sdk.h +++ b/sdk/bpf/c/inc/solana_sdk.h @@ -284,13 +284,29 @@ SOL_FN_PREFIX bool sol_deserialize( } params->ka_num = *(uint64_t *) input; input += sizeof(uint64_t); - if (ka_num < params->ka_num) { + + if (ka_num > params->ka_num) { return false; } for (int i = 0; i < params->ka_num; i++) { uint8_t dup_info = input[0]; input += sizeof(uint8_t); + + if (i >= ka_num) { + if (dup_info == UINT8_MAX) { + input += sizeof(uint8_t); + input += sizeof(uint8_t); + input += sizeof(SolPubkey); + input += sizeof(uint64_t); + input += *(uint64_t *) input; + input += sizeof(uint64_t); + input += sizeof(SolPubkey); + input += sizeof(uint8_t); + input += sizeof(uint64_t); + } + continue; + } if (dup_info == UINT8_MAX) { // is signer? params->ka[i].is_signer = *(uint8_t *) input != 0; @@ -418,7 +434,6 @@ SOL_FN_PREFIX void sol_log_params(const SolParameters *params) { */ uint64_t entrypoint(const uint8_t *input); - #ifdef SOL_TEST /** * Stub log functions when building tests