1 #include "common/transport.hpp" 2 3 #include <libpldm/platform.h> 4 5 #include <CLI/CLI.hpp> 6 #include <phosphor-logging/lg2.hpp> 7 8 #include <array> 9 10 PHOSPHOR_LOG2_USING; 11 12 int main(int argc, char** argv) 13 { 14 CLI::App app{"Send PLDM command SetStateEffecterStates"}; 15 uint8_t mctpEid{}; 16 app.add_option("-m,--mctp_eid", mctpEid, "MCTP EID")->required(); 17 uint16_t effecterId{}; 18 app.add_option("-e,--effecter", effecterId, "Effecter Id")->required(); 19 uint8_t state{}; 20 app.add_option("-s,--state", state, "New state value")->required(); 21 CLI11_PARSE(app, argc, argv); 22 23 // Encode PLDM Request message 24 uint8_t effecterCount = 1; 25 std::array<uint8_t, 26 sizeof(pldm_msg_hdr) + sizeof(effecterId) + 27 sizeof(effecterCount) + sizeof(set_effecter_state_field)> 28 requestMsg{}; 29 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data()); 30 set_effecter_state_field stateField{PLDM_REQUEST_SET, state}; 31 auto rc = encode_set_state_effecter_states_req(0, effecterId, effecterCount, 32 &stateField, request); 33 if (rc != PLDM_SUCCESS) 34 { 35 error( 36 "Failed to encode set state effecter states request message, response code '{RC}'", 37 "RC", lg2::hex, rc); 38 return -1; 39 } 40 41 PldmTransport pldmTransport{}; 42 43 void* responseMsg = nullptr; 44 size_t responseMsgSize{}; 45 // Send PLDM request msg and wait for response 46 rc = pldmTransport.sendRecvMsg(static_cast<pldm_tid_t>(mctpEid), 47 requestMsg.data(), requestMsg.size(), 48 responseMsg, responseMsgSize); 49 if (0 > rc) 50 { 51 error( 52 "Failed to send message/receive response, response code '{RC}' and error - {ERROR}", 53 "RC", rc, "ERROR", errno); 54 return -1; 55 } 56 pldm_msg* response = reinterpret_cast<pldm_msg*>(responseMsg); 57 info( 58 "Done! Got the response for PLDM send receive message request, response code '{RC}'", 59 "RC", lg2::hex, response->payload[0]); 60 free(responseMsg); 61 62 return 0; 63 } 64