NetworkPkg: Use Http11 definitions in HttpDxe and HttpBootDxe

Change HttpDxe and HttpBootDxe to use the standard definitions from
Http11.h instead of private duplicate definitions.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Samer El-Haj-Mahmoud <elhaj@hpe.com>
Reviewed-by: Fu Siyuan <siyuan.fu@intel.com>
This commit is contained in:
Samer El-Haj-Mahmoud 2016-02-19 06:47:36 +08:00 committed by Fu Siyuan
parent 003f3c00d8
commit 90f658c460
6 changed files with 22 additions and 20 deletions

View File

@ -2,6 +2,7 @@
Implementation of the boot file download function. Implementation of the boot file download function.
Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR> Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR>
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
This program and the accompanying materials are licensed and made available under This program and the accompanying materials are licensed and made available under
the terms and conditions of the BSD License that accompanies this distribution. the terms and conditions of the BSD License that accompanies this distribution.
The full text of the license may be found at The full text of the license may be found at
@ -807,7 +808,7 @@ HttpBootGetBootFile (
} }
Status = HttpBootSetHeader ( Status = HttpBootSetHeader (
HttpIoHeader, HttpIoHeader,
HTTP_FIELD_NAME_HOST, HTTP_HEADER_HOST,
HostName HostName
); );
FreePool (HostName); FreePool (HostName);
@ -820,7 +821,7 @@ HttpBootGetBootFile (
// //
Status = HttpBootSetHeader ( Status = HttpBootSetHeader (
HttpIoHeader, HttpIoHeader,
HTTP_FIELD_NAME_ACCEPT, HTTP_HEADER_ACCEPT,
"*/*" "*/*"
); );
if (EFI_ERROR (Status)) { if (EFI_ERROR (Status)) {
@ -832,7 +833,7 @@ HttpBootGetBootFile (
// //
Status = HttpBootSetHeader ( Status = HttpBootSetHeader (
HttpIoHeader, HttpIoHeader,
HTTP_FIELD_NAME_USER_AGENT, HTTP_HEADER_USER_AGENT,
HTTP_USER_AGENT_EFI_HTTP_BOOT HTTP_USER_AGENT_EFI_HTTP_BOOT
); );
if (EFI_ERROR (Status)) { if (EFI_ERROR (Status)) {

View File

@ -2,6 +2,7 @@
Declaration of the boot file download function. Declaration of the boot file download function.
Copyright (c) 2015, Intel Corporation. All rights reserved.<BR> Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
This program and the accompanying materials are licensed and made available under This program and the accompanying materials are licensed and made available under
the terms and conditions of the BSD License that accompanies this distribution. the terms and conditions of the BSD License that accompanies this distribution.
The full text of the license may be found at The full text of the license may be found at
@ -18,9 +19,6 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
#define HTTP_BOOT_REQUEST_TIMEOUT 5000 // 5 seconds in uints of millisecond. #define HTTP_BOOT_REQUEST_TIMEOUT 5000 // 5 seconds in uints of millisecond.
#define HTTP_BOOT_BLOCK_SIZE 1500 #define HTTP_BOOT_BLOCK_SIZE 1500
#define HTTP_FIELD_NAME_USER_AGENT "User-Agent"
#define HTTP_FIELD_NAME_HOST "Host"
#define HTTP_FIELD_NAME_ACCEPT "Accept"
#define HTTP_USER_AGENT_EFI_HTTP_BOOT "UefiHttpBoot/1.0" #define HTTP_USER_AGENT_EFI_HTTP_BOOT "UefiHttpBoot/1.0"

View File

@ -2,6 +2,7 @@
UEFI HTTP boot driver's private data structure and interfaces declaration. UEFI HTTP boot driver's private data structure and interfaces declaration.
Copyright (c) 2015, Intel Corporation. All rights reserved.<BR> Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
This program and the accompanying materials are licensed and made available under This program and the accompanying materials are licensed and made available under
the terms and conditions of the BSD License that accompanies this distribution. the terms and conditions of the BSD License that accompanies this distribution.
The full text of the license may be found at The full text of the license may be found at
@ -17,6 +18,8 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
#include <Uefi.h> #include <Uefi.h>
#include <IndustryStandard/Http11.h>
// //
// Libraries // Libraries
// //

View File

@ -2,6 +2,7 @@
The header files of the driver binding and service binding protocol for HttpDxe driver. The header files of the driver binding and service binding protocol for HttpDxe driver.
Copyright (c) 2015, Intel Corporation. All rights reserved.<BR> Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
This program and the accompanying materials This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License are licensed and made available under the terms and conditions of the BSD License
@ -17,6 +18,7 @@
#define __EFI_HTTP_DRIVER_H__ #define __EFI_HTTP_DRIVER_H__
#include <Uefi.h> #include <Uefi.h>
#include <IndustryStandard/Http11.h>
// //
// Libraries // Libraries

View File

@ -2,6 +2,7 @@
The header files of implementation of EFI_HTTP_PROTOCOL protocol interfaces. The header files of implementation of EFI_HTTP_PROTOCOL protocol interfaces.
Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR> Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR>
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
This program and the accompanying materials This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License are licensed and made available under the terms and conditions of the BSD License
@ -19,17 +20,10 @@
#define HTTP_DEFAULT_PORT 80 #define HTTP_DEFAULT_PORT 80
#define HTTP_END_OF_HDR_STR "\r\n\r\n" #define HTTP_END_OF_HDR_STR "\r\n\r\n"
#define HTTP_CRLF_STR "\r\n" #define HTTP_CRLF_STR "\r\n"
#define HTTP_VERSION_STR "HTTP/1.1" #define HTTP_VERSION_STR HTTP_VERSION
#define HTTP_VERSION_CRLF_STR " HTTP/1.1\r\n" #define HTTP_VERSION_CRLF_STR " HTTP/1.1\r\n"
#define HTTP_GET_STR "GET "
#define HTTP_HEAD_STR "HEAD "
#define HTTP_ERROR_OR_NOT_SUPPORT_STATUS_CODE 300 #define HTTP_ERROR_OR_NOT_SUPPORT_STATUS_CODE 300
//
// Connect method has maximum length according to EFI_HTTP_METHOD defined in
// UEFI2.5 spec so use this.
//
#define HTTP_MAXIMUM_METHOD_LEN sizeof ("CONNECT")
/** /**
Returns the operational parameters for the current HTTP child instance. Returns the operational parameters for the current HTTP child instance.

View File

@ -2,7 +2,7 @@
Miscellaneous routines for HttpDxe driver. Miscellaneous routines for HttpDxe driver.
Copyright (c) 2015, Intel Corporation. All rights reserved.<BR> Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>
(C) Copyright 2015 Hewlett Packard Enterprise Development LP<BR> (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
This program and the accompanying materials This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License 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 which accompanies this distribution. The full text of the license may be found at
@ -2023,7 +2023,7 @@ HttpGenRequestString (
// //
// Calculate HTTP message length. // Calculate HTTP message length.
// //
MsgSize = Message->BodyLength + HTTP_MAXIMUM_METHOD_LEN + AsciiStrLen (Url) + MsgSize = Message->BodyLength + HTTP_METHOD_MAXIMUM_LEN + AsciiStrLen (Url) +
AsciiStrLen (HTTP_VERSION_CRLF_STR) + HttpHdrSize; AsciiStrLen (HTTP_VERSION_CRLF_STR) + HttpHdrSize;
Request = AllocateZeroPool (MsgSize); Request = AllocateZeroPool (MsgSize);
if (Request == NULL) { if (Request == NULL) {
@ -2036,13 +2036,13 @@ HttpGenRequestString (
// //
switch (Message->Data.Request->Method) { switch (Message->Data.Request->Method) {
case HttpMethodGet: case HttpMethodGet:
StrLength = sizeof (HTTP_GET_STR) - 1; StrLength = sizeof (HTTP_METHOD_GET) - 1;
CopyMem (RequestPtr, HTTP_GET_STR, StrLength); CopyMem (RequestPtr, HTTP_METHOD_GET, StrLength);
RequestPtr += StrLength; RequestPtr += StrLength;
break; break;
case HttpMethodHead: case HttpMethodHead:
StrLength = sizeof (HTTP_HEAD_STR) - 1; StrLength = sizeof (HTTP_METHOD_HEAD) - 1;
CopyMem (RequestPtr, HTTP_HEAD_STR, StrLength); CopyMem (RequestPtr, HTTP_METHOD_HEAD, StrLength);
RequestPtr += StrLength; RequestPtr += StrLength;
break; break;
default: default:
@ -2050,6 +2050,10 @@ HttpGenRequestString (
goto Exit; goto Exit;
} }
StrLength = AsciiStrLen(" ");
CopyMem (RequestPtr, " ", StrLength);
RequestPtr += StrLength;
StrLength = AsciiStrLen (Url); StrLength = AsciiStrLen (Url);
CopyMem (RequestPtr, Url, StrLength); CopyMem (RequestPtr, Url, StrLength);
RequestPtr += StrLength; RequestPtr += StrLength;