On Thu, 2025-09-04 at 11:10 +0100, Jonathan Cameron wrote: > > [...] > > diff --git a/backends/spdm-socket.c b/backends/spdm-socket.c > > index 2c709c68c8..3d264814df 100644 > > --- a/backends/spdm-socket.c > > +++ b/backends/spdm-socket.c > > @@ -184,28 +184,62 @@ int spdm_socket_connect(uint16_t port, Error > > **errp) > > return client_socket; > > } > > > > -uint32_t spdm_socket_rsp(const int socket, uint32_t > > transport_type, > > - void *req, uint32_t req_len, > > - void *rsp, uint32_t rsp_len) > > +static bool spdm_socket_command_valid(uint32_t command) > As below - perhaps this sanity check belongs in a precursor patch? > > +{ > > + switch (command) { > > + case SPDM_SOCKET_COMMAND_NORMAL: > > + case SPDM_SOCKET_STORAGE_CMD_IF_SEND: > > + case SPDM_SOCKET_STORAGE_CMD_IF_RECV: > > + case SOCKET_SPDM_STORAGE_ACK_STATUS: > > + case SPDM_SOCKET_COMMAND_OOB_ENCAP_KEY_UPDATE: > > + case SPDM_SOCKET_COMMAND_CONTINUE: > > + case SPDM_SOCKET_COMMAND_SHUTDOWN: > > + case SPDM_SOCKET_COMMAND_UNKOWN: > > + case SPDM_SOCKET_COMMAND_TEST: > > + return true; > > + default: > > + return false; > > + } > > +} > > + > > +uint32_t spdm_socket_receive(const int socket, uint32_t > > transport_type, > > + void *rsp, uint32_t rsp_len) > > { > > uint32_t command; > > bool result; > > > > - result = send_platform_data(socket, transport_type, > > - SPDM_SOCKET_COMMAND_NORMAL, > > - req, req_len); > > - if (!result) { > > + result = receive_platform_data(socket, transport_type, > > &command, > > + (uint8_t *)rsp, &rsp_len); > > + > > + /* we may have received some data, but check if the command is > > valid */ > > + if (!result || !spdm_socket_command_valid(command)) { > > Is this change related to the separate send/recv part? Perhaps it > is a useful bit of hardening to do as a precursor patch? Hey Jonathan,
I think it makes sense to integrate this directly into spdm_socket_receive() in this patch. As in a precursor patch, it would need to be changed here again. > > > return 0; > > } > > > > - result = receive_platform_data(socket, transport_type, > > &command, > > - (uint8_t *)rsp, &rsp_len); > > + return rsp_len; > > +} > > + > > +bool spdm_socket_send(const int socket, uint32_t socket_cmd, > > + uint32_t transport_type, void *req, uint32_t > > req_len) > > +{ > > + return send_platform_data(socket, transport_type, > > + socket_cmd, req, req_len); > > I'd wrap that closer to 80 chars. Ah yep! > > > +} > > + > > +uint32_t spdm_socket_rsp(const int socket, uint32_t > > transport_type, > > + void *req, uint32_t req_len, > > + void *rsp, uint32_t rsp_len) > > +{ > > + bool result; > > + > > + result = spdm_socket_send(socket, SPDM_SOCKET_COMMAND_NORMAL, > > + transport_type, req, req_len); > > if (!result) { > > return 0; > > } > > > > - assert(command != 0); > > - > > + rsp_len = spdm_socket_receive(socket, transport_type, (uint8_t > > *)rsp, > > Why casting to a uint8_t * ? It is a void * and this function takes > a void *. Okay yeah, will fixup. > > > + rsp_len); > > return rsp_len; > > } > > > > diff --git a/include/system/spdm-socket.h b/include/system/spdm- > > socket.h > > index 5d8bd9aa4e..2b7d03f82d 100644 > > --- a/include/system/spdm-socket.h > > +++ b/include/system/spdm-socket.h > > > /** > > * spdm_socket_close: send a shutdown command to the server > > * @socket: socket returned from spdm_socket_connect() > > @@ -60,6 +89,9 @@ uint32_t spdm_socket_rsp(const int socket, > > uint32_t transport_type, > > void spdm_socket_close(const int socket, uint32_t transport_type); > > > > #define SPDM_SOCKET_COMMAND_NORMAL 0x0001 > > +#define SPDM_SOCKET_STORAGE_CMD_IF_SEND 0x0002 > > +#define SPDM_SOCKET_STORAGE_CMD_IF_RECV 0x0003 > > +#define SOCKET_SPDM_STORAGE_ACK_STATUS 0x0004 > > #define SPDM_SOCKET_COMMAND_OOB_ENCAP_KEY_UPDATE 0x8001 > > #define SPDM_SOCKET_COMMAND_CONTINUE 0xFFFD > > #define SPDM_SOCKET_COMMAND_SHUTDOWN 0xFFFE > > @@ -68,7 +100,10 @@ void spdm_socket_close(const int socket, > > uint32_t transport_type); > > > > #define SPDM_SOCKET_TRANSPORT_TYPE_MCTP 0x01 > > #define SPDM_SOCKET_TRANSPORT_TYPE_PCI_DOE 0x02 > > +#define SPDM_SOCKET_TRANSPORT_TYPE_SCSI 0x03 > > +#define SPDM_SOCKET_TRANSPORT_TYPE_NVME 0x04 > > Not used in this patch. Move it to where it is first used. > > > > > #define SPDM_SOCKET_MAX_MESSAGE_BUFFER_SIZE 0x1200 > > +#define SPDM_SOCKET_MAX_MSG_STATUS_LEN 0x02 > > Not used in this patch. Sounds good, I will move them up. Thanks! Wilfred