Revision: 14768
          http://sourceforge.net/p/edk2/code/14768
Author:   ydong10
Date:     2013-10-14 02:42:47 +0000 (Mon, 14 Oct 2013)
Log Message:
-----------
Move update legacy order logic from CHANGING to CHANGED.

Signed-off-by: Eric Dong <[email protected]>
Reviewed-by: Liming Gao <[email protected]>

Modified Paths:
--------------
    trunk/edk2/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.c

Modified: 
trunk/edk2/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.c
===================================================================
--- trunk/edk2/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.c   
2013-10-14 02:02:02 UTC (rev 14767)
+++ trunk/edk2/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.c   
2013-10-14 02:42:47 UTC (rev 14768)
@@ -316,6 +316,106 @@
     
     UpdatePageId (Private, QuestionId);
 
+    if (QuestionId < FILE_OPTION_OFFSET) {
+      if (QuestionId < CONFIG_OPTION_OFFSET) {
+        switch (QuestionId) {
+        case KEY_VALUE_BOOT_FROM_FILE:
+          Private->FeCurrentState = FileExplorerStateBootFromFile;
+          break;
+
+        case FORM_BOOT_ADD_ID:
+          Private->FeCurrentState = FileExplorerStateAddBootOption;
+          break;
+
+        case FORM_DRV_ADD_FILE_ID:
+          Private->FeCurrentState = FileExplorerStateAddDriverOptionState;
+          break;
+
+        case FORM_DRV_ADD_HANDLE_ID:
+          CleanUpPage (FORM_DRV_ADD_HANDLE_ID, Private);
+          UpdateDrvAddHandlePage (Private);
+          break;
+
+        case FORM_BOOT_DEL_ID:
+          CleanUpPage (FORM_BOOT_DEL_ID, Private);
+          UpdateBootDelPage (Private);
+          break;
+
+        case FORM_BOOT_CHG_ID:
+        case FORM_DRV_CHG_ID:
+          UpdatePageBody (QuestionId, Private);
+          break;
+
+        case FORM_DRV_DEL_ID:
+          CleanUpPage (FORM_DRV_DEL_ID, Private);
+          UpdateDrvDelPage (Private);
+          break;
+
+        case FORM_BOOT_NEXT_ID:
+          CleanUpPage (FORM_BOOT_NEXT_ID, Private);
+          UpdateBootNextPage (Private);
+          break;
+
+        case FORM_TIME_OUT_ID:
+          CleanUpPage (FORM_TIME_OUT_ID, Private);
+          UpdateTimeOutPage (Private);
+          break;
+
+        case FORM_CON_IN_ID:
+        case FORM_CON_OUT_ID:
+        case FORM_CON_ERR_ID:
+          UpdatePageBody (QuestionId, Private);
+          break;
+
+        case FORM_CON_MODE_ID:
+          CleanUpPage (FORM_CON_MODE_ID, Private);
+          UpdateConModePage (Private);
+          break;
+
+        case FORM_CON_COM_ID:
+          CleanUpPage (FORM_CON_COM_ID, Private);
+          UpdateConCOMPage (Private);
+          break;
+
+        case FORM_SET_FD_ORDER_ID:
+        case FORM_SET_HD_ORDER_ID:
+        case FORM_SET_CD_ORDER_ID:
+        case FORM_SET_NET_ORDER_ID:
+        case FORM_SET_BEV_ORDER_ID:
+          CleanUpPage (QuestionId, Private);
+          UpdateSetLegacyDeviceOrderPage (QuestionId, Private);
+          break;
+
+        default:
+          break;
+        }
+      } else if ((QuestionId >= TERMINAL_OPTION_OFFSET) && (QuestionId < 
CONSOLE_OPTION_OFFSET)) {
+        Index2                    = (UINT16) (QuestionId - 
TERMINAL_OPTION_OFFSET);
+        Private->CurrentTerminal  = Index2;
+
+        CleanUpPage (FORM_CON_COM_SETUP_ID, Private);
+        UpdateTerminalPage (Private);
+
+      } else if (QuestionId >= HANDLE_OPTION_OFFSET) {
+        Index2                  = (UINT16) (QuestionId - HANDLE_OPTION_OFFSET);
+
+        NewMenuEntry            = BOpt_GetMenuEntry (&DriverMenu, Index2);
+        ASSERT (NewMenuEntry != NULL);
+        Private->HandleContext  = (BM_HANDLE_CONTEXT *) 
NewMenuEntry->VariableContext;
+
+        CleanUpPage (FORM_DRV_ADD_HANDLE_DESC_ID, Private);
+
+        Private->MenuEntry                  = NewMenuEntry;
+        Private->LoadContext->FilePathList  = 
Private->HandleContext->DevicePath;
+
+        UpdateDriverAddHandleDescPage (Private);
+      }
+    }
+  } else if (Action == EFI_BROWSER_ACTION_CHANGED) {
+    if ((Value == NULL) || (ActionRequest == NULL)) {
+      return EFI_INVALID_PARAMETER;
+    }
+    
     //
     // need to be subtituded.
     //
@@ -466,134 +566,34 @@
         //
         Value->u8 = NewLegacyDev[Index3];
       }
-    }
-
-    if (QuestionId < FILE_OPTION_OFFSET) {
-      if (QuestionId < CONFIG_OPTION_OFFSET) {
-        switch (QuestionId) {
-        case KEY_VALUE_BOOT_FROM_FILE:
-          Private->FeCurrentState = FileExplorerStateBootFromFile;
-          break;
-
-        case FORM_BOOT_ADD_ID:
-          Private->FeCurrentState = FileExplorerStateAddBootOption;
-          break;
-
-        case FORM_DRV_ADD_FILE_ID:
-          Private->FeCurrentState = FileExplorerStateAddDriverOptionState;
-          break;
-
-        case FORM_DRV_ADD_HANDLE_ID:
-          CleanUpPage (FORM_DRV_ADD_HANDLE_ID, Private);
-          UpdateDrvAddHandlePage (Private);
-          break;
-
-        case FORM_BOOT_DEL_ID:
-          CleanUpPage (FORM_BOOT_DEL_ID, Private);
-          UpdateBootDelPage (Private);
-          break;
-
-        case FORM_BOOT_CHG_ID:
-        case FORM_DRV_CHG_ID:
-          UpdatePageBody (QuestionId, Private);
-          break;
-
-        case FORM_DRV_DEL_ID:
-          CleanUpPage (FORM_DRV_DEL_ID, Private);
-          UpdateDrvDelPage (Private);
-          break;
-
-        case FORM_BOOT_NEXT_ID:
-          CleanUpPage (FORM_BOOT_NEXT_ID, Private);
-          UpdateBootNextPage (Private);
-          break;
-
-        case FORM_TIME_OUT_ID:
-          CleanUpPage (FORM_TIME_OUT_ID, Private);
-          UpdateTimeOutPage (Private);
-          break;
-
-        case FORM_CON_IN_ID:
-        case FORM_CON_OUT_ID:
-        case FORM_CON_ERR_ID:
-          UpdatePageBody (QuestionId, Private);
-          break;
-
-        case FORM_CON_MODE_ID:
-          CleanUpPage (FORM_CON_MODE_ID, Private);
-          UpdateConModePage (Private);
-          break;
-
-        case FORM_CON_COM_ID:
-          CleanUpPage (FORM_CON_COM_ID, Private);
-          UpdateConCOMPage (Private);
-          break;
-
-        case FORM_SET_FD_ORDER_ID:
-        case FORM_SET_HD_ORDER_ID:
-        case FORM_SET_CD_ORDER_ID:
-        case FORM_SET_NET_ORDER_ID:
-        case FORM_SET_BEV_ORDER_ID:
-          CleanUpPage (QuestionId, Private);
-          UpdateSetLegacyDeviceOrderPage (QuestionId, Private);
-          break;
-
-        default:
-          break;
+    } else {
+      switch (QuestionId) {
+      case KEY_VALUE_SAVE_AND_EXIT:
+      case KEY_VALUE_NO_SAVE_AND_EXIT:
+        if (QuestionId == KEY_VALUE_SAVE_AND_EXIT) {
+          Status = ApplyChangeHandler (Private, CurrentFakeNVMap, 
Private->BmmPreviousPageId);
+          if (EFI_ERROR (Status)) {
+            return Status;
+          }
+        } else if (QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT) {
+          DiscardChangeHandler (Private, CurrentFakeNVMap);
         }
-      } else if ((QuestionId >= TERMINAL_OPTION_OFFSET) && (QuestionId < 
CONSOLE_OPTION_OFFSET)) {
-        Index2                    = (UINT16) (QuestionId - 
TERMINAL_OPTION_OFFSET);
-        Private->CurrentTerminal  = Index2;
 
-        CleanUpPage (FORM_CON_COM_SETUP_ID, Private);
-        UpdateTerminalPage (Private);
+        //
+        // Tell browser not to ask for confirmation of changes,
+        // since we have already applied or discarded.
+        //
+        *ActionRequest = EFI_BROWSER_ACTION_REQUEST_FORM_SUBMIT_EXIT;
+        break;  
 
-      } else if (QuestionId >= HANDLE_OPTION_OFFSET) {
-        Index2                  = (UINT16) (QuestionId - HANDLE_OPTION_OFFSET);
+      case FORM_RESET:
+        gRT->ResetSystem (EfiResetCold, EFI_SUCCESS, 0, NULL);
+        return EFI_UNSUPPORTED;
 
-        NewMenuEntry            = BOpt_GetMenuEntry (&DriverMenu, Index2);
-        ASSERT (NewMenuEntry != NULL);
-        Private->HandleContext  = (BM_HANDLE_CONTEXT *) 
NewMenuEntry->VariableContext;
-
-        CleanUpPage (FORM_DRV_ADD_HANDLE_DESC_ID, Private);
-
-        Private->MenuEntry                  = NewMenuEntry;
-        Private->LoadContext->FilePathList  = 
Private->HandleContext->DevicePath;
-
-        UpdateDriverAddHandleDescPage (Private);
+      default:
+        break;
       }
     }
-  } else if (Action == EFI_BROWSER_ACTION_CHANGED) {
-    if ((Value == NULL) || (ActionRequest == NULL)) {
-      return EFI_INVALID_PARAMETER;
-    }
-    
-    switch (QuestionId) {
-    case KEY_VALUE_SAVE_AND_EXIT:
-    case KEY_VALUE_NO_SAVE_AND_EXIT:
-      if (QuestionId == KEY_VALUE_SAVE_AND_EXIT) {
-        Status = ApplyChangeHandler (Private, CurrentFakeNVMap, 
Private->BmmPreviousPageId);
-        if (EFI_ERROR (Status)) {
-          return Status;
-        }
-      } else if (QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT) {
-        DiscardChangeHandler (Private, CurrentFakeNVMap);
-      }
-
-      //
-      // Tell browser not to ask for confirmation of changes,
-      // since we have already applied or discarded.
-      //
-      *ActionRequest = EFI_BROWSER_ACTION_REQUEST_FORM_SUBMIT_EXIT;
-      break;  
-
-    case FORM_RESET:
-      gRT->ResetSystem (EfiResetCold, EFI_SUCCESS, 0, NULL);
-      return EFI_UNSUPPORTED;
-
-    default:
-      break;
-    }
   }
 
   //

This was sent by the SourceForge.net collaborative development platform, the 
world's largest Open Source development site.


------------------------------------------------------------------------------
October Webinars: Code for Performance
Free Intel webinars can help you accelerate application performance.
Explore tips for MPI, OpenMP, advanced profiling, and more. Get the most from 
the latest Intel processors and coprocessors. See abstracts and register >
http://pubads.g.doubleclick.net/gampad/clk?id=60134071&iu=/4140/ostg.clktrk
_______________________________________________
edk2-commits mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/edk2-commits

Reply via email to