mirror of https://github.com/acidanthera/audk.git
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:
parent
003f3c00d8
commit
90f658c460
|
@ -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)) {
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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
|
||||||
//
|
//
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue