diff options
author | qhuang8 <qhuang8@6f19259b-4bc3-4df7-8a09-765794883524> | 2006-09-13 10:00:18 +0000 |
---|---|---|
committer | qhuang8 <qhuang8@6f19259b-4bc3-4df7-8a09-765794883524> | 2006-09-13 10:00:18 +0000 |
commit | 10e4f9901cf50906166832d0195ef84be8f56c9b (patch) | |
tree | cbbda9f77bbe9f82a18c22f783386904fb0ebc17 | |
parent | 5c4eec41d79fad6c629416226c49ebdcd3b7d468 (diff) | |
download | edk2-platforms-10e4f9901cf50906166832d0195ef84be8f56c9b.tar.xz |
1.Support to drop Pei Services Table Pointer at best.
2.Change the comments style of Migration tool.
3.Fix a bug in identify function header.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1530 6f19259b-4bc3-4df7-8a09-765794883524
3 files changed, 93 insertions, 53 deletions
diff --git a/Tools/Source/MigrationTools/org/tianocore/migration/Critic.java b/Tools/Source/MigrationTools/org/tianocore/migration/Critic.java index 45670d94c2..4641e37c73 100644 --- a/Tools/Source/MigrationTools/org/tianocore/migration/Critic.java +++ b/Tools/Source/MigrationTools/org/tianocore/migration/Critic.java @@ -45,7 +45,7 @@ public final class Critic { wholeline = wholeline.replaceAll("\t", " ");
wholeline = Common.replaceAll(wholeline, ptnheadcomment, "/** @file$1**/");
- wholeline = Common.replaceAll(wholeline, ptnfunccomment, "$1/**$3**/$4$2");
+ wholeline = Common.replaceAll(wholeline, ptnfunccomment, "$1\n/**$3\n**/$4$2");
//wholeline = Common.replaceAll(wholeline, ptncommentstructure, "/**\n#%\n$1\n%#\n#%%\n$2\n%%#\n#%%%\n$3\n%%%#\n**/");
// first scan
diff --git a/Tools/Source/MigrationTools/org/tianocore/migration/MigrationTool.java b/Tools/Source/MigrationTools/org/tianocore/migration/MigrationTool.java index e159c5e4ea..edb6a95a34 100644 --- a/Tools/Source/MigrationTools/org/tianocore/migration/MigrationTool.java +++ b/Tools/Source/MigrationTools/org/tianocore/migration/MigrationTool.java @@ -21,7 +21,7 @@ public class MigrationTool { public static UI ui = null;
public static Database db = null;
- public static String MIGRATIONCOMMENT = "//%@//";
+ public static String MIGRATIONCOMMENT = "//@MT:";
public static boolean printModuleInfo = false;
public static boolean doCritic = false;
diff --git a/Tools/Source/MigrationTools/org/tianocore/migration/SourceFileReplacer.java b/Tools/Source/MigrationTools/org/tianocore/migration/SourceFileReplacer.java index 3325f15044..4ff8ebe524 100644 --- a/Tools/Source/MigrationTools/org/tianocore/migration/SourceFileReplacer.java +++ b/Tools/Source/MigrationTools/org/tianocore/migration/SourceFileReplacer.java @@ -40,7 +40,23 @@ public final class SourceFileReplacer implements Common.ForDoAll { "BuildBspStoreHob",
"BuildMemoryAllocationHob"
};
-
+ private static final String[] peiserviceslibfunc = {
+ "InstallPpi",
+ "ReInstallPpi",
+ "LocatePpi",
+ "NotifyPpi",
+ "GetBootMode",
+ "SetBootMode",
+ "GetHobList",
+ "CreateHob",
+ "FfsFindNextVolume",
+ "FfsFindNextFile",
+ "FfsFindSectionData",
+ "InstallPeiMemory",
+ "AllocatePages",
+ "AllocatePool",
+ "PeiResetSystem"
+ };
//---------------------------------------inner classes---------------------------------------//
private static class r8tor9 {
r8tor9(String r8, String r9) {
@@ -117,55 +133,20 @@ public final class SourceFileReplacer implements Common.ForDoAll { replaceGuid(wholeline, mi.protocol, "protocol", fileprotocol);
// Converting Pei
- // First , find all (**PeiServices)-> or (*PeiServices). with arg "PeiServices" , change name and add #%
- Pattern ptnpei = Pattern.compile("\\(\\*\\*?PeiServices\\)[.-][>]?\\s*(\\w*)(\\s*\\(\\s*PeiServices\\s*,\\s*)", Pattern.MULTILINE);
if (mi.getModuleType().matches("PEIM")) {
- //if (mi.moduletype.contains("PEIM")) {
- Matcher mtrpei = ptnpei.matcher(wholeline);
- while (mtrpei.find()) { // ! add a library here !
- wholeline = mtrpei.replaceAll("PeiServices$1#%$2");
- mi.hashrequiredr9libs.add("PeiServicesLib");
- }
- mtrpei.reset();
- if (wholeline.contains("PeiServicesCopyMem")) {
- wholeline = wholeline.replaceAll("PeiServicesCopyMem#%", "CopyMem");
- mi.hashrequiredr9libs.add("BaseMemoryLib");
- }
- if (wholeline.contains("PeiServicesSetMem")) {
- wholeline = wholeline.replaceAll("PeiServicesSetMem#%", "SetMem");
- mi.hashrequiredr9libs.add("BaseMemoryLib");
- }
-
- // Second , find all #% to drop the arg "PeiServices"
- Pattern ptnpeiarg = Pattern.compile("#%+(\\s*\\(+\\s*)PeiServices\\s*,\\s*", Pattern.MULTILINE);
- Matcher mtrpeiarg = ptnpeiarg.matcher(wholeline);
- while (mtrpeiarg.find()) {
- wholeline = mtrpeiarg.replaceAll("$1");
- }
- }
-
- wholeline = hobLibFuncDropStatus(wholeline);
-
- Matcher mtrmac;
- mtrmac = Pattern.compile("EFI_IDIV_ROUND\\((.*), (.*)\\)").matcher(wholeline);
- if (mtrmac.find()) {
- wholeline = mtrmac.replaceAll("\\($1 \\/ $2 \\+ \\(\\(\\(2 \\* \\($1 \\% $2\\)\\) \\< $2\\) \\? 0 \\: 1\\)\\)");
- }
- mtrmac = Pattern.compile("EFI_MIN\\((.*), (.*)\\)").matcher(wholeline);
- if (mtrmac.find()) {
- wholeline = mtrmac.replaceAll("\\(\\($1 \\< $2\\) \\? $1 \\: $2\\)");
- }
- mtrmac = Pattern.compile("EFI_MAX\\((.*), (.*)\\)").matcher(wholeline);
- if (mtrmac.find()) {
- wholeline = mtrmac.replaceAll("\\(\\($1 \\> $2\\) \\? $1 \\: $2\\)");
- }
- mtrmac = Pattern.compile("EFI_UINTN_ALIGNED\\((.*)\\)").matcher(wholeline);
- if (mtrmac.find()) {
- wholeline = mtrmac.replaceAll("\\(\\(\\(UINTN\\) $1\\) \\& \\(sizeof \\(UINTN\\) \\- 1\\)\\)");
- }
- if (wholeline.contains("EFI_UINTN_ALIGN_MASK")) {
- wholeline = wholeline.replaceAll("EFI_UINTN_ALIGN_MASK", "(sizeof (UINTN) - 1)");
+ //
+ // Try to remove PeiServicesTablePointer;
+ //
+ wholeline = dropPeiServicesPointer (wholeline);
+ //
+ // Drop the possible return Status of Hob building function.
+ //
+ wholeline = drophobLibReturnStatus (wholeline);
}
+ //
+ // Expand obsolete R8 macro.
+ //
+ wholeline = replaceObsoleteMacro (wholeline);
show(filefunc, "function");
show(filemacro, "macro");
@@ -236,7 +217,42 @@ public final class SourceFileReplacer implements Common.ForDoAll { }
}
- private final String hobLibFuncDropStatus(String wholeline) { // or use regex to find pattern "Status = ..."
+ private final String dropPeiServicesPointer (String wholeline) {
+ String peiServicesTablePointer;
+ String peiServicesTableCaller;
+ String regPeiServices;
+ Pattern ptnPei;
+ Matcher mtrPei;
+
+ peiServicesTablePointer = "\\w(?:\\w|[0-9]|->)*";
+ peiServicesTableCaller = "\\(\\*\\*?\\s*(" + peiServicesTablePointer + ")\\s*\\)[.-]>?\\s*";
+ for (int i = 0; i < peiserviceslibfunc.length; i++) {
+ regPeiServices = peiServicesTableCaller + peiserviceslibfunc[i] + "\\s*\\(\\s*\\1\\s*,(\\t| )*";
+ ptnPei = Pattern.compile (regPeiServices);
+ mtrPei = ptnPei.matcher (wholeline);
+ if (mtrPei.find()) {
+ wholeline = mtrPei.replaceAll("PeiServices" + peiserviceslibfunc[i] + " (");
+ mi.hashrequiredr9libs.add("PeiServicesLib");
+ }
+ }
+ regPeiServices = peiServicesTableCaller + "(CopyMem|SetMem)" + "\\s*\\((\\t| )*";
+ ptnPei = Pattern.compile (regPeiServices);
+ mtrPei = ptnPei.matcher (wholeline);
+ if (mtrPei.find()) {
+ wholeline = mtrPei.replaceAll("$2 (");
+ mi.hashrequiredr9libs.add("BaseMemoryLib");
+ }
+
+ ptnPei = Pattern.compile("#%+(\\s*\\(+\\s*)" + peiServicesTablePointer + "\\s*,\\s*", Pattern.MULTILINE);
+ mtrPei = ptnPei.matcher(wholeline);
+ while (mtrPei.find()) {
+ wholeline = mtrPei.replaceAll("$1");
+ }
+
+ return wholeline;
+ }
+
+ private final String drophobLibReturnStatus (String wholeline) { // or use regex to find pattern "Status = ..."
Pattern ptnhobstatus;
Matcher mtrhobstatus;
String templine = wholeline;
@@ -244,7 +260,8 @@ public final class SourceFileReplacer implements Common.ForDoAll { ptnhobstatus = Pattern.compile("(Status\\s*=\\s*)?" + specialhoblibfunc[i] + "(.*?\\)\\s*;)", Pattern.DOTALL);
mtrhobstatus = ptnhobstatus.matcher(templine);
if (mtrhobstatus.find()) {
- templine = mtrhobstatus.replaceAll(specialhoblibfunc[i] + mtrhobstatus.group(2) + "\n //Migration comments: R9 Hob-building library functions will assert if build failure.\n Status = EFI_SUCCESS;");
+ templine = mtrhobstatus.replaceAll(specialhoblibfunc[i] + mtrhobstatus.group(2) + "\n " +
+ MigrationTool.MIGRATIONCOMMENT + "R9 Hob-building library functions will assert if build failure.\n Status = EFI_SUCCESS;");
}
}
return templine;
@@ -258,7 +275,6 @@ public final class SourceFileReplacer implements Common.ForDoAll { it = symbolSet.iterator();
while (it.hasNext()) { //macros are all assumed MdePkg currently
r8thing = it.next();
- System.out.println (r8thing);
//mi.hashrequiredr9libs.add(MigrationTool.db.getR9Lib(r8thing));
if ((r9thing = MigrationTool.db.getR9Macro(r8thing)) != null) {
if (wholeline.contains(r8thing)) {
@@ -307,6 +323,30 @@ public final class SourceFileReplacer implements Common.ForDoAll { return wholeline;
}
+ private final String replaceObsoleteMacro (String wholeline) {
+ Matcher mtrmac;
+ mtrmac = Pattern.compile("EFI_IDIV_ROUND\\((.*), (.*)\\)").matcher(wholeline);
+ if (mtrmac.find()) {
+ wholeline = mtrmac.replaceAll("\\($1 \\/ $2 \\+ \\(\\(\\(2 \\* \\($1 \\% $2\\)\\) \\< $2\\) \\? 0 \\: 1\\)\\)");
+ }
+ mtrmac = Pattern.compile("EFI_MIN\\((.*), (.*)\\)").matcher(wholeline);
+ if (mtrmac.find()) {
+ wholeline = mtrmac.replaceAll("\\(\\($1 \\< $2\\) \\? $1 \\: $2\\)");
+ }
+ mtrmac = Pattern.compile("EFI_MAX\\((.*), (.*)\\)").matcher(wholeline);
+ if (mtrmac.find()) {
+ wholeline = mtrmac.replaceAll("\\(\\($1 \\> $2\\) \\? $1 \\: $2\\)");
+ }
+ mtrmac = Pattern.compile("EFI_UINTN_ALIGNED\\((.*)\\)").matcher(wholeline);
+ if (mtrmac.find()) {
+ wholeline = mtrmac.replaceAll("\\(\\(\\(UINTN\\) $1\\) \\& \\(sizeof \\(UINTN\\) \\- 1\\)\\)");
+ }
+ if (wholeline.contains("EFI_UINTN_ALIGN_MASK")) {
+ wholeline = wholeline.replaceAll("EFI_UINTN_ALIGN_MASK", "(sizeof (UINTN) - 1)");
+ }
+ return wholeline;
+ }
+
private final void addr8only() throws Exception {
String paragraph = null;
String line = Common.file2string(MigrationTool.db.DatabasePath + File.separator + "R8Lib.c");
|