mirror of https://github.com/acidanthera/audk.git
MdeModulePkg/Bus/Ufs: Ensure device not return more data than expected
This commit adds checks to make sure the UFS devices do not return more data than the driver expected. Cc: Ruiyu Ni <ruiyu.ni@intel.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Star Zeng <star.zeng@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Hao Wu <hao.a.wu@intel.com> Reviewed-by: Star Zeng <star.zeng@intel.com>
This commit is contained in:
parent
b2252bab12
commit
8894c90d74
|
@ -857,6 +857,14 @@ UfsRwDeviceDesc (
|
||||||
SwapLittleEndianToBigEndian ((UINT8*)&ReturnDataSize, sizeof (UINT16));
|
SwapLittleEndianToBigEndian ((UINT8*)&ReturnDataSize, sizeof (UINT16));
|
||||||
|
|
||||||
if (Read) {
|
if (Read) {
|
||||||
|
//
|
||||||
|
// Make sure the hardware device does not return more data than expected.
|
||||||
|
//
|
||||||
|
if (ReturnDataSize > Packet.InTransferLength) {
|
||||||
|
Status = EFI_DEVICE_ERROR;
|
||||||
|
goto Exit;
|
||||||
|
}
|
||||||
|
|
||||||
CopyMem (Packet.InDataBuffer, (QueryResp + 1), ReturnDataSize);
|
CopyMem (Packet.InDataBuffer, (QueryResp + 1), ReturnDataSize);
|
||||||
Packet.InTransferLength = ReturnDataSize;
|
Packet.InTransferLength = ReturnDataSize;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1170,8 +1178,15 @@ UfsExecScsiCmds (
|
||||||
SwapLittleEndianToBigEndian ((UINT8*)&SenseDataLen, sizeof (UINT16));
|
SwapLittleEndianToBigEndian ((UINT8*)&SenseDataLen, sizeof (UINT16));
|
||||||
|
|
||||||
if ((Packet->SenseDataLength != 0) && (Packet->SenseData != NULL)) {
|
if ((Packet->SenseDataLength != 0) && (Packet->SenseData != NULL)) {
|
||||||
|
//
|
||||||
|
// Make sure the hardware device does not return more data than expected.
|
||||||
|
//
|
||||||
|
if (SenseDataLen <= Packet->SenseDataLength) {
|
||||||
CopyMem (Packet->SenseData, Response->SenseData, SenseDataLen);
|
CopyMem (Packet->SenseData, Response->SenseData, SenseDataLen);
|
||||||
Packet->SenseDataLength = (UINT8)SenseDataLen;
|
Packet->SenseDataLength = (UINT8)SenseDataLen;
|
||||||
|
} else {
|
||||||
|
Packet->SenseDataLength = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
|
@ -833,6 +833,7 @@ UfsStopExecCmd (
|
||||||
@param[in] QueryResp Pointer to the query response.
|
@param[in] QueryResp Pointer to the query response.
|
||||||
|
|
||||||
@retval EFI_INVALID_PARAMETER Packet or QueryResp are empty or opcode is invalid.
|
@retval EFI_INVALID_PARAMETER Packet or QueryResp are empty or opcode is invalid.
|
||||||
|
@retval EFI_DEVICE_ERROR Data returned from device is invalid.
|
||||||
@retval EFI_SUCCESS Data extracted.
|
@retval EFI_SUCCESS Data extracted.
|
||||||
|
|
||||||
**/
|
**/
|
||||||
|
@ -853,6 +854,13 @@ UfsGetReturnDataFromQueryResponse (
|
||||||
case UtpQueryFuncOpcodeRdDesc:
|
case UtpQueryFuncOpcodeRdDesc:
|
||||||
ReturnDataSize = QueryResp->Tsf.Length;
|
ReturnDataSize = QueryResp->Tsf.Length;
|
||||||
SwapLittleEndianToBigEndian ((UINT8*)&ReturnDataSize, sizeof (UINT16));
|
SwapLittleEndianToBigEndian ((UINT8*)&ReturnDataSize, sizeof (UINT16));
|
||||||
|
//
|
||||||
|
// Make sure the hardware device does not return more data than expected.
|
||||||
|
//
|
||||||
|
if (ReturnDataSize > Packet->TransferLength) {
|
||||||
|
return EFI_DEVICE_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
CopyMem (Packet->DataBuffer, (QueryResp + 1), ReturnDataSize);
|
CopyMem (Packet->DataBuffer, (QueryResp + 1), ReturnDataSize);
|
||||||
Packet->TransferLength = ReturnDataSize;
|
Packet->TransferLength = ReturnDataSize;
|
||||||
break;
|
break;
|
||||||
|
@ -1469,8 +1477,15 @@ UfsExecScsiCmds (
|
||||||
SwapLittleEndianToBigEndian ((UINT8*)&SenseDataLen, sizeof (UINT16));
|
SwapLittleEndianToBigEndian ((UINT8*)&SenseDataLen, sizeof (UINT16));
|
||||||
|
|
||||||
if ((Packet->SenseDataLength != 0) && (Packet->SenseData != NULL)) {
|
if ((Packet->SenseDataLength != 0) && (Packet->SenseData != NULL)) {
|
||||||
|
//
|
||||||
|
// Make sure the hardware device does not return more data than expected.
|
||||||
|
//
|
||||||
|
if (SenseDataLen <= Packet->SenseDataLength) {
|
||||||
CopyMem (Packet->SenseData, Response->SenseData, SenseDataLen);
|
CopyMem (Packet->SenseData, Response->SenseData, SenseDataLen);
|
||||||
Packet->SenseDataLength = (UINT8)SenseDataLen;
|
Packet->SenseDataLength = (UINT8)SenseDataLen;
|
||||||
|
} else {
|
||||||
|
Packet->SenseDataLength = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -2226,8 +2241,15 @@ ProcessAsyncTaskList (
|
||||||
SwapLittleEndianToBigEndian ((UINT8*)&SenseDataLen, sizeof (UINT16));
|
SwapLittleEndianToBigEndian ((UINT8*)&SenseDataLen, sizeof (UINT16));
|
||||||
|
|
||||||
if ((Packet->SenseDataLength != 0) && (Packet->SenseData != NULL)) {
|
if ((Packet->SenseDataLength != 0) && (Packet->SenseData != NULL)) {
|
||||||
|
//
|
||||||
|
// Make sure the hardware device does not return more data than expected.
|
||||||
|
//
|
||||||
|
if (SenseDataLen <= Packet->SenseDataLength) {
|
||||||
CopyMem (Packet->SenseData, Response->SenseData, SenseDataLen);
|
CopyMem (Packet->SenseData, Response->SenseData, SenseDataLen);
|
||||||
Packet->SenseDataLength = (UINT8)SenseDataLen;
|
Packet->SenseDataLength = (UINT8)SenseDataLen;
|
||||||
|
} else {
|
||||||
|
Packet->SenseDataLength = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in New Issue