Revert BaseTools: PYTHON3 migration
This reverts commit 6693f359b3c213513c5096a06c6f67244a44dc52..
678f851312
.
Python3 migration is the fundamental change. It requires every developer
to install Python3. Before this migration, the well communication and wide
verification must be done. But now, most people is not aware of this change,
and not try it. So, Python3 migration is reverted and be moved to edk2-staging
Python3 branch for the edk2 user evaluation.
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
@@ -43,7 +43,7 @@ libs: $(LIBRARIES)
|
||||
@echo # Build libraries
|
||||
@echo ######################
|
||||
@if not exist $(LIB_PATH) mkdir $(LIB_PATH)
|
||||
@$(PYTHON3) Makefiles\NmakeSubdirs.py all $**
|
||||
@$(PYTHON_HOME)\python.exe Makefiles\NmakeSubdirs.py all $**
|
||||
|
||||
apps: $(APPLICATIONS)
|
||||
@echo.
|
||||
@@ -51,7 +51,7 @@ apps: $(APPLICATIONS)
|
||||
@echo # Build executables
|
||||
@echo ######################
|
||||
@if not exist $(BIN_PATH) mkdir $(BIN_PATH)
|
||||
@$(PYTHON3) Makefiles\NmakeSubdirs.py all $**
|
||||
@$(PYTHON_HOME)\python.exe Makefiles\NmakeSubdirs.py all $**
|
||||
|
||||
install: $(LIB_PATH) $(BIN_PATH)
|
||||
@echo.
|
||||
@@ -65,11 +65,11 @@ install: $(LIB_PATH) $(BIN_PATH)
|
||||
|
||||
.PHONY: clean
|
||||
clean:
|
||||
@$(PYTHON3) Makefiles\NmakeSubdirs.py clean $(LIBRARIES) $(APPLICATIONS)
|
||||
@$(PYTHON_HOME)\python.exe Makefiles\NmakeSubdirs.py clean $(LIBRARIES) $(APPLICATIONS)
|
||||
|
||||
.PHONY: cleanall
|
||||
cleanall:
|
||||
@$(PYTHON3) Makefiles\NmakeSubdirs.py cleanall $(LIBRARIES) $(APPLICATIONS)
|
||||
@$(PYTHON_HOME)\python.exe Makefiles\NmakeSubdirs.py cleanall $(LIBRARIES) $(APPLICATIONS)
|
||||
|
||||
!INCLUDE Makefiles\ms.rule
|
||||
|
||||
|
25
BaseTools/Source/C/PyUtility/Makefile
Normal file
25
BaseTools/Source/C/PyUtility/Makefile
Normal file
@@ -0,0 +1,25 @@
|
||||
## @file
|
||||
# Makefile
|
||||
#
|
||||
# Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR>
|
||||
# This program and the accompanying materials
|
||||
# are licensed and made available under the terms and conditions of the BSD License
|
||||
# which accompanies this distribution. The full text of the license may be found at
|
||||
# http://opensource.org/licenses/bsd-license.php
|
||||
#
|
||||
# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||
#
|
||||
|
||||
!INCLUDE ..\Makefiles\ms.common
|
||||
|
||||
APPNAME = GenSec
|
||||
|
||||
LIBS = $(LIB_PATH)\Common.lib
|
||||
|
||||
OBJECTS = PyUtility.obj
|
||||
|
||||
#CFLAGS = $(CFLAGS) /nodefaultlib:libc.lib
|
||||
|
||||
!INCLUDE ..\Makefiles\ms.app
|
||||
|
106
BaseTools/Source/C/PyUtility/PyUtility.c
Normal file
106
BaseTools/Source/C/PyUtility/PyUtility.c
Normal file
@@ -0,0 +1,106 @@
|
||||
/** @file
|
||||
Python Utility
|
||||
|
||||
Copyright (c) 2009 - 2018, Intel Corporation. All rights reserved.<BR>
|
||||
This program and the accompanying materials are licensed and made available
|
||||
under the terms and conditions of the BSD License which accompanies this
|
||||
distribution. The full text of the license may be found at
|
||||
http://opensource.org/licenses/bsd-license.php
|
||||
|
||||
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||
|
||||
**/
|
||||
|
||||
#include <Python.h>
|
||||
#include <Windows.h>
|
||||
#include <Common/UefiBaseTypes.h>
|
||||
|
||||
/*
|
||||
SaveFileToDisk(FilePath, Content)
|
||||
*/
|
||||
STATIC
|
||||
PyObject*
|
||||
SaveFileToDisk (
|
||||
PyObject *Self,
|
||||
PyObject *Args
|
||||
)
|
||||
{
|
||||
CHAR8 *File;
|
||||
UINT8 *Data;
|
||||
UINTN DataLength;
|
||||
UINTN WriteBytes;
|
||||
UINTN Status;
|
||||
HANDLE FileHandle;
|
||||
PyObject *ReturnValue = Py_False;
|
||||
|
||||
Status = PyArg_ParseTuple(
|
||||
Args,
|
||||
"ss#",
|
||||
&File,
|
||||
&Data,
|
||||
&DataLength
|
||||
);
|
||||
if (Status == 0) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
FileHandle = CreateFile(
|
||||
File,
|
||||
GENERIC_WRITE,
|
||||
FILE_SHARE_WRITE|FILE_SHARE_READ|FILE_SHARE_DELETE,
|
||||
NULL,
|
||||
CREATE_ALWAYS,
|
||||
FILE_ATTRIBUTE_NORMAL,
|
||||
NULL
|
||||
);
|
||||
if (FileHandle == INVALID_HANDLE_VALUE) {
|
||||
PyErr_SetString(PyExc_Exception, "File creation failure");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
while (WriteFile(FileHandle, Data, DataLength, &WriteBytes, NULL)) {
|
||||
if (DataLength <= WriteBytes) {
|
||||
DataLength = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
Data += WriteBytes;
|
||||
DataLength -= WriteBytes;
|
||||
}
|
||||
|
||||
if (DataLength != 0) {
|
||||
// file saved unsuccessfully
|
||||
PyErr_SetString(PyExc_Exception, "File write failure");
|
||||
goto Done;
|
||||
}
|
||||
|
||||
//
|
||||
// Flush buffer may slow down the whole build performance (average 10s slower)
|
||||
//
|
||||
//if (!FlushFileBuffers(FileHandle)) {
|
||||
// PyErr_SetString(PyExc_Exception, "File flush failure");
|
||||
// goto Done;
|
||||
//}
|
||||
|
||||
// success!
|
||||
ReturnValue = Py_True;
|
||||
|
||||
Done:
|
||||
CloseHandle(FileHandle);
|
||||
return ReturnValue;
|
||||
}
|
||||
|
||||
STATIC INT8 SaveFileToDiskDocs[] = "SaveFileToDisk(): Make sure the file is saved to disk\n";
|
||||
|
||||
STATIC PyMethodDef PyUtility_Funcs[] = {
|
||||
{"SaveFileToDisk", (PyCFunction)SaveFileToDisk, METH_VARARGS, SaveFileToDiskDocs},
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
PyMODINIT_FUNC
|
||||
initPyUtility(VOID) {
|
||||
Py_InitModule3("PyUtility", PyUtility_Funcs, "Utilties Module Implemented C Language");
|
||||
}
|
||||
|
||||
|
42
BaseTools/Source/C/PyUtility/setup.py
Normal file
42
BaseTools/Source/C/PyUtility/setup.py
Normal file
@@ -0,0 +1,42 @@
|
||||
## @file
|
||||
# package and install PyEfiCompressor extension
|
||||
#
|
||||
# Copyright (c) 2008, Intel Corporation. All rights reserved.<BR>
|
||||
#
|
||||
# This program and the accompanying materials
|
||||
# are licensed and made available under the terms and conditions of the BSD License
|
||||
# which accompanies this distribution. The full text of the license may be found at
|
||||
# http://opensource.org/licenses/bsd-license.php
|
||||
#
|
||||
# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||
#
|
||||
|
||||
##
|
||||
# Import Modules
|
||||
#
|
||||
from distutils.core import setup, Extension
|
||||
import os
|
||||
|
||||
if 'BASE_TOOLS_PATH' not in os.environ:
|
||||
raise "Please define BASE_TOOLS_PATH to the root of base tools tree"
|
||||
|
||||
BaseToolsDir = os.environ['BASE_TOOLS_PATH']
|
||||
setup(
|
||||
name="PyUtility",
|
||||
version="0.01",
|
||||
ext_modules=[
|
||||
Extension(
|
||||
'PyUtility',
|
||||
sources=[
|
||||
'PyUtility.c'
|
||||
],
|
||||
include_dirs=[
|
||||
os.path.join(BaseToolsDir, 'Source', 'C', 'Include'),
|
||||
os.path.join(BaseToolsDir, 'Source', 'C', 'Include', 'Ia32'),
|
||||
os.path.join(BaseToolsDir, 'Source', 'C', 'Common')
|
||||
],
|
||||
)
|
||||
],
|
||||
)
|
||||
|
@@ -17,7 +17,6 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||
**/
|
||||
|
||||
#include "Compress.h"
|
||||
#include "Decompress.h"
|
||||
#include "TianoCompress.h"
|
||||
#include "EfiUtilityMsgs.h"
|
||||
#include "ParseInf.h"
|
||||
@@ -66,7 +65,6 @@ static BOOLEAN QuietMode = FALSE;
|
||||
//
|
||||
STATIC BOOLEAN ENCODE = FALSE;
|
||||
STATIC BOOLEAN DECODE = FALSE;
|
||||
STATIC BOOLEAN UEFIMODE = FALSE;
|
||||
STATIC UINT8 *mSrc, *mDst, *mSrcUpperLimit, *mDstUpperLimit;
|
||||
STATIC UINT8 *mLevel, *mText, *mChildCount, *mBuf, mCLen[NC], mPTLen[NPT], *mLen;
|
||||
STATIC INT16 mHeap[NC + 1];
|
||||
@@ -1705,8 +1703,6 @@ Returns:
|
||||
// Details Option
|
||||
//
|
||||
fprintf (stdout, "Options:\n");
|
||||
fprintf (stdout, " --uefi\n\
|
||||
Enable UefiCompress, use TianoCompress when without this option\n");
|
||||
fprintf (stdout, " -o FileName, --output FileName\n\
|
||||
File will be created to store the ouput content.\n");
|
||||
fprintf (stdout, " -v, --verbose\n\
|
||||
@@ -1826,13 +1822,6 @@ Returns:
|
||||
continue;
|
||||
}
|
||||
|
||||
if (stricmp(argv[0], "--uefi") == 0) {
|
||||
UEFIMODE = TRUE;
|
||||
argc--;
|
||||
argv++;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (stricmp (argv[0], "--debug") == 0) {
|
||||
argc-=2;
|
||||
argv++;
|
||||
@@ -1950,11 +1939,7 @@ Returns:
|
||||
if (DebugMode) {
|
||||
DebugMsg(UTILITY_NAME, 0, DebugLevel, "Encoding", NULL);
|
||||
}
|
||||
if (UEFIMODE) {
|
||||
Status = EfiCompress ((UINT8 *)FileBuffer, InputLength, OutBuffer, &DstSize);
|
||||
} else {
|
||||
Status = TianoCompress ((UINT8 *)FileBuffer, InputLength, OutBuffer, &DstSize);
|
||||
}
|
||||
Status = TianoCompress ((UINT8 *)FileBuffer, InputLength, OutBuffer, &DstSize);
|
||||
|
||||
if (Status == EFI_BUFFER_TOO_SMALL) {
|
||||
OutBuffer = (UINT8 *) malloc (DstSize);
|
||||
@@ -1964,11 +1949,7 @@ Returns:
|
||||
}
|
||||
}
|
||||
|
||||
if (UEFIMODE) {
|
||||
Status = EfiCompress ((UINT8 *)FileBuffer, InputLength, OutBuffer, &DstSize);
|
||||
} else {
|
||||
Status = TianoCompress ((UINT8 *)FileBuffer, InputLength, OutBuffer, &DstSize);
|
||||
}
|
||||
Status = TianoCompress ((UINT8 *)FileBuffer, InputLength, OutBuffer, &DstSize);
|
||||
if (Status != EFI_SUCCESS) {
|
||||
Error (NULL, 0, 0007, "Error compressing file", NULL);
|
||||
goto ERROR;
|
||||
@@ -1998,46 +1979,32 @@ Returns:
|
||||
if (DebugMode) {
|
||||
DebugMsg(UTILITY_NAME, 0, DebugLevel, "Decoding\n", NULL);
|
||||
}
|
||||
//
|
||||
// Get Compressed file original size
|
||||
//
|
||||
Src = (UINT8 *)FileBuffer;
|
||||
OrigSize = Src[4] + (Src[5] << 8) + (Src[6] << 16) + (Src[7] << 24);
|
||||
|
||||
if (UEFIMODE) {
|
||||
Status = Extract((VOID *)FileBuffer, InputLength, (VOID *)&OutBuffer, &DstSize, 1);
|
||||
if (Status != EFI_SUCCESS) {
|
||||
goto ERROR;
|
||||
}
|
||||
fwrite(OutBuffer, (size_t)(DstSize), 1, OutputFile);
|
||||
} else {
|
||||
//
|
||||
// Get Compressed file original size
|
||||
//
|
||||
Src = (UINT8 *)FileBuffer;
|
||||
OrigSize = Src[4] + (Src[5] << 8) + (Src[6] << 16) + (Src[7] << 24);
|
||||
//
|
||||
// Allocate OutputBuffer
|
||||
//
|
||||
OutBuffer = (UINT8 *)malloc(OrigSize);
|
||||
if (OutBuffer == NULL) {
|
||||
Error (NULL, 0, 4001, "Resource:", "Memory cannot be allocated!");
|
||||
goto ERROR;
|
||||
}
|
||||
|
||||
//
|
||||
// Allocate OutputBuffer
|
||||
//
|
||||
OutBuffer = (UINT8 *)malloc(OrigSize);
|
||||
if (OutBuffer == NULL) {
|
||||
Error (NULL, 0, 4001, "Resource:", "Memory cannot be allocated!");
|
||||
goto ERROR;
|
||||
}
|
||||
|
||||
Status = TDecompress((VOID *)FileBuffer, (VOID *)OutBuffer, (VOID *)Scratch, 2);
|
||||
if (Status != EFI_SUCCESS) {
|
||||
goto ERROR;
|
||||
}
|
||||
fwrite(OutBuffer, (size_t)(Scratch->mOrigSize), 1, OutputFile);
|
||||
Status = Decompress((VOID *)FileBuffer, (VOID *)OutBuffer, (VOID *)Scratch, 2);
|
||||
if (Status != EFI_SUCCESS) {
|
||||
goto ERROR;
|
||||
}
|
||||
|
||||
fwrite(OutBuffer, (size_t)(Scratch->mOrigSize), 1, OutputFile);
|
||||
fclose(OutputFile);
|
||||
fclose(InputFile);
|
||||
if (Scratch != NULL) {
|
||||
free(Scratch);
|
||||
}
|
||||
if (FileBuffer != NULL) {
|
||||
free(FileBuffer);
|
||||
}
|
||||
if (OutBuffer != NULL) {
|
||||
free(OutBuffer);
|
||||
}
|
||||
free(Scratch);
|
||||
free(FileBuffer);
|
||||
free(OutBuffer);
|
||||
|
||||
if (DebugMode) {
|
||||
DebugMsg(UTILITY_NAME, 0, DebugLevel, "Encoding successful!\n", NULL);
|
||||
@@ -2667,7 +2634,7 @@ Done:
|
||||
|
||||
RETURN_STATUS
|
||||
EFIAPI
|
||||
TDecompress (
|
||||
Decompress (
|
||||
IN VOID *Source,
|
||||
IN OUT VOID *Destination,
|
||||
IN OUT VOID *Scratch,
|
||||
|
@@ -427,7 +427,7 @@ Decode (
|
||||
|
||||
RETURN_STATUS
|
||||
EFIAPI
|
||||
TDecompress (
|
||||
Decompress (
|
||||
IN VOID *Source,
|
||||
IN OUT VOID *Destination,
|
||||
IN OUT VOID *Scratch,
|
||||
|
Reference in New Issue
Block a user