Signed-off-by: Eric Dong <eric.dong@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@14034
6f19259b-4bc3-4df7-8a09-
765794883524
/** @file\r
HII Library implementation that uses DXE protocols and services.\r
\r
/** @file\r
HII Library implementation that uses DXE protocols and services.\r
\r
- Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR>\r
+ Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.<BR>\r
This program and the accompanying materials\r
are licensed and made available under the terms and conditions of the BSD License\r
which accompanies this distribution. The full text of the license may be found at\r
This program and the accompanying materials\r
are licensed and made available under the terms and conditions of the BSD License\r
which accompanies this distribution. The full text of the license may be found at\r
{\r
EFI_IFR_NUMERIC OpCode;\r
UINTN Position;\r
{\r
EFI_IFR_NUMERIC OpCode;\r
UINTN Position;\r
\r
ASSERT ((QuestionFlags & (~(EFI_IFR_FLAG_READ_ONLY | EFI_IFR_FLAG_CALLBACK | EFI_IFR_FLAG_RESET_REQUIRED))) == 0);\r
\r
\r
ASSERT ((QuestionFlags & (~(EFI_IFR_FLAG_READ_ONLY | EFI_IFR_FLAG_CALLBACK | EFI_IFR_FLAG_RESET_REQUIRED))) == 0);\r
\r
ZeroMem (&OpCode, sizeof (OpCode));\r
OpCode.Question.QuestionId = QuestionId;\r
OpCode.Question.VarStoreId = VarStoreId;\r
ZeroMem (&OpCode, sizeof (OpCode));\r
OpCode.Question.QuestionId = QuestionId;\r
OpCode.Question.VarStoreId = VarStoreId;\r
OpCode.data.u8.MinValue = (UINT8)Minimum;\r
OpCode.data.u8.MaxValue = (UINT8)Maximum;\r
OpCode.data.u8.Step = (UINT8)Step;\r
OpCode.data.u8.MinValue = (UINT8)Minimum;\r
OpCode.data.u8.MaxValue = (UINT8)Maximum;\r
OpCode.data.u8.Step = (UINT8)Step;\r
break;\r
\r
case EFI_IFR_NUMERIC_SIZE_2:\r
OpCode.data.u16.MinValue = (UINT16)Minimum;\r
OpCode.data.u16.MaxValue = (UINT16)Maximum;\r
OpCode.data.u16.Step = (UINT16)Step;\r
break;\r
\r
case EFI_IFR_NUMERIC_SIZE_2:\r
OpCode.data.u16.MinValue = (UINT16)Minimum;\r
OpCode.data.u16.MaxValue = (UINT16)Maximum;\r
OpCode.data.u16.Step = (UINT16)Step;\r
break;\r
\r
case EFI_IFR_NUMERIC_SIZE_4:\r
OpCode.data.u32.MinValue = (UINT32)Minimum;\r
OpCode.data.u32.MaxValue = (UINT32)Maximum;\r
OpCode.data.u32.Step = (UINT32)Step;\r
break;\r
\r
case EFI_IFR_NUMERIC_SIZE_4:\r
OpCode.data.u32.MinValue = (UINT32)Minimum;\r
OpCode.data.u32.MaxValue = (UINT32)Maximum;\r
OpCode.data.u32.Step = (UINT32)Step;\r
break;\r
\r
case EFI_IFR_NUMERIC_SIZE_8:\r
OpCode.data.u64.MinValue = Minimum;\r
OpCode.data.u64.MaxValue = Maximum;\r
OpCode.data.u64.Step = Step;\r
break;\r
\r
case EFI_IFR_NUMERIC_SIZE_8:\r
OpCode.data.u64.MinValue = Minimum;\r
OpCode.data.u64.MaxValue = Maximum;\r
OpCode.data.u64.Step = Step;\r
+ Length += OFFSET_OF (EFI_IFR_NUMERIC, data);\r
+\r
if (DefaultsOpCodeHandle == NULL) {\r
if (DefaultsOpCodeHandle == NULL) {\r
- return InternalHiiCreateOpCode (OpCodeHandle, &OpCode, EFI_IFR_NUMERIC_OP, sizeof (OpCode));\r
+ return InternalHiiCreateOpCode (OpCodeHandle, &OpCode, EFI_IFR_NUMERIC_OP, Length);\r
}\r
\r
Position = InternalHiiOpCodeHandlePosition (OpCodeHandle);\r
}\r
\r
Position = InternalHiiOpCodeHandlePosition (OpCodeHandle);\r
- InternalHiiCreateOpCodeExtended (OpCodeHandle, &OpCode, EFI_IFR_NUMERIC_OP, sizeof (OpCode), 0, 1);\r
+ InternalHiiCreateOpCodeExtended (OpCodeHandle, &OpCode, EFI_IFR_NUMERIC_OP, Length, 0, 1);\r
InternalHiiAppendOpCodes (OpCodeHandle, DefaultsOpCodeHandle);\r
HiiCreateEndOpCode (OpCodeHandle);\r
return InternalHiiOpCodeHandleBuffer (OpCodeHandle) + Position;\r
InternalHiiAppendOpCodes (OpCodeHandle, DefaultsOpCodeHandle);\r
HiiCreateEndOpCode (OpCodeHandle);\r
return InternalHiiOpCodeHandleBuffer (OpCodeHandle) + Position;\r