mirror of https://github.com/acidanthera/audk.git
BaseTools/EfiRom: Add/refine boundary checks for strcpy/strcat calls
Add checks to ensure when the destination string buffer is of fixed size, the strcpy/strcat functions calls will not access beyond the boundary. Cc: Yonghong Zhu <yonghong.zhu@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Hao Wu <hao.a.wu@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
parent
3e1497334e
commit
52e8c56838
|
@ -96,7 +96,13 @@ Returns:
|
|||
//
|
||||
if (!mOptions.OutFileName[0]) {
|
||||
if (mOptions.FileList != NULL) {
|
||||
strcpy (mOptions.OutFileName, mOptions.FileList->FileName);
|
||||
if (strlen (mOptions.FileList->FileName) >= MAX_PATH) {
|
||||
Status = STATUS_ERROR;
|
||||
Error (NULL, 0, 2000, "Invalid parameter", "Input file name is too long - %s.", mOptions.FileList->FileName);
|
||||
goto BailOut;
|
||||
}
|
||||
strncpy (mOptions.OutFileName, mOptions.FileList->FileName, MAX_PATH - 1);
|
||||
mOptions.OutFileName[MAX_PATH - 1] = 0;
|
||||
//
|
||||
// Find the last . on the line and replace the filename extension with
|
||||
// the default
|
||||
|
|
Loading…
Reference in New Issue