| ## @file | |
| # Network DSC include file for [Defines] section of all Architectures. | |
| # | |
| # This file can be included to the [Defines] section of a platform DSC file by | |
| # using "!include NetworkPkg/NetworkDefines.dsc.inc" to set default value of | |
| # flags if they are not defined somewhere else, and also check the value to see | |
| # if there is any conflict. | |
| # | |
| # These flags can be defined before the !include line, or changed on the command | |
| # line to enable or disable related feature support. | |
| # -D FLAG=VALUE | |
| # The default value of these flags are: | |
| # DEFINE NETWORK_ENABLE = TRUE | |
| # DEFINE NETWORK_SNP_ENABLE = TRUE | |
| # DEFINE NETWORK_IP4_ENABLE = TRUE | |
| # DEFINE NETWORK_IP6_ENABLE = TRUE | |
| # DEFINE NETWORK_TLS_ENABLE = TRUE | |
| # DEFINE NETWORK_HTTP_ENABLE = FALSE | |
| # DEFINE NETWORK_HTTP_BOOT_ENABLE = TRUE | |
| # DEFINE NETWORK_ALLOW_HTTP_CONNECTIONS = FALSE | |
| # DEFINE NETWORK_ISCSI_ENABLE = FALSE | |
| # DEFINE NETWORK_ISCSI_MD5_ENABLE = TRUE | |
| # DEFINE NETWORK_VLAN_ENABLE = TRUE | |
| # | |
| # Copyright (c) 2019, Intel Corporation. All rights reserved.<BR> | |
| # (C) Copyright 2020 Hewlett Packard Enterprise Development LP<BR> | |
| # | |
| # SPDX-License-Identifier: BSD-2-Clause-Patent | |
| # | |
| ## | |
| !ifndef NETWORK_ENABLE | |
| # | |
| # This flag is to enable or disable the whole network stack. | |
| # | |
| DEFINE NETWORK_ENABLE = TRUE | |
| !endif | |
| !ifndef NETWORK_SNP_ENABLE | |
| # | |
| # This flag is to include the common SNP driver or not. | |
| # | |
| DEFINE NETWORK_SNP_ENABLE = TRUE | |
| !endif | |
| !ifndef NETWORK_VLAN_ENABLE | |
| # | |
| # This flag is to enable or disable VLAN feature. | |
| # | |
| DEFINE NETWORK_VLAN_ENABLE = TRUE | |
| !endif | |
| !ifndef NETWORK_IP4_ENABLE | |
| # | |
| # This flag is to enable or disable IPv4 network stack. | |
| # | |
| DEFINE NETWORK_IP4_ENABLE = TRUE | |
| !endif | |
| !ifndef NETWORK_IP6_ENABLE | |
| # | |
| # This flag is to enable or disable IPv6 network stack. | |
| # | |
| DEFINE NETWORK_IP6_ENABLE = TRUE | |
| !endif | |
| !ifndef NETWORK_TLS_ENABLE | |
| # | |
| # This flag is to enable or disable TLS feature. | |
| # | |
| # Note: This feature depends on the OpenSSL building. To enable this feature, please | |
| # follow the instructions found in the file "OpenSSL-HOWTO.txt" located in | |
| # CryptoPkg\Library\OpensslLib to enable the OpenSSL building first. | |
| # The OpensslLib.inf library instance should be used since libssl is required. | |
| # | |
| DEFINE NETWORK_TLS_ENABLE = TRUE | |
| !endif | |
| !ifndef NETWORK_HTTP_ENABLE | |
| # | |
| # This flag is to enable or disable HTTP(S) feature. | |
| # The default is set to FALSE to not affecting the existing | |
| # platforms. | |
| # NETWORK_HTTP_ENABLE set to FALSE is not affecting NETWORK_HTTP_BOOT_ENABLE | |
| # when NETWORK_HTTP_BOOT_ENABLE is TRUE. | |
| DEFINE NETWORK_HTTP_ENABLE = FALSE | |
| !endif | |
| !ifndef NETWORK_HTTP_BOOT_ENABLE | |
| # | |
| # This flag is to enable or disable HTTP(S) boot feature. | |
| # | |
| # | |
| DEFINE NETWORK_HTTP_BOOT_ENABLE = TRUE | |
| !endif | |
| !ifndef NETWORK_ALLOW_HTTP_CONNECTIONS | |
| # | |
| # Indicates whether HTTP connections (i.e., unsecured) are permitted or not. | |
| # | |
| # Note: If NETWORK_ALLOW_HTTP_CONNECTIONS is TRUE, HTTP connections are allowed. | |
| # Both the "https://" and "http://" URI schemes are permitted. Otherwise, HTTP | |
| # connections are denied. Only the "https://" URI scheme is permitted. | |
| # | |
| DEFINE NETWORK_ALLOW_HTTP_CONNECTIONS = FALSE | |
| !endif | |
| !ifndef NETWORK_ISCSI_ENABLE | |
| # | |
| # This flag is to enable or disable iSCSI feature. | |
| # | |
| # Note: This feature depends on the OpenSSL building. To enable this feature, please | |
| # follow the instructions found in the file "OpenSSL-HOWTO.txt" located in | |
| # CryptoPkg\Library\OpensslLib to enable the OpenSSL building first. | |
| # Both OpensslLib.inf and OpensslLibCrypto.inf library instance can be used | |
| # since libssl is not required for iSCSI. | |
| # | |
| DEFINE NETWORK_ISCSI_ENABLE = FALSE | |
| !endif | |
| !ifndef NETWORK_ISCSI_MD5_ENABLE | |
| # | |
| # This flag enables the deprecated MD5 hash algorithm in iSCSI CHAP | |
| # authentication. | |
| # | |
| # Note: The NETWORK_ISCSI_MD5_ENABLE flag only makes a difference if | |
| # NETWORK_ISCSI_ENABLE is TRUE; otherwise, NETWORK_ISCSI_MD5_ENABLE is | |
| # ignored. | |
| # | |
| # With NETWORK_ISCSI_MD5_ENABLE set to TRUE, MD5 is enabled as the | |
| # least preferred CHAP hash algorithm. With NETWORK_ISCSI_MD5_ENABLE | |
| # set to FALSE, MD5 is disabled statically, at build time. | |
| # | |
| # The default value is TRUE, because RFC 7143 mandates MD5, and because | |
| # several vendors' iSCSI targets only support MD5, for CHAP. | |
| # | |
| DEFINE NETWORK_ISCSI_MD5_ENABLE = TRUE | |
| !endif | |
| !if $(NETWORK_ENABLE) == TRUE | |
| # | |
| # Check the flags to see if there is any conflict. | |
| # | |
| !if ($(NETWORK_IP4_ENABLE) == FALSE) AND ($(NETWORK_IP6_ENABLE) == FALSE) | |
| !error "Must enable at least IP4 or IP6 stack if NETWORK_ENABLE is set to TRUE!" | |
| !endif | |
| !if ($(NETWORK_HTTP_BOOT_ENABLE) == TRUE) OR ($(NETWORK_HTTP_ENABLE) == TRUE) | |
| !if ($(NETWORK_TLS_ENABLE) == FALSE) AND ($(NETWORK_ALLOW_HTTP_CONNECTIONS) == FALSE) | |
| !error "Must enable TLS to support HTTPS, or allow unsecured HTTP connection, if NETWORK_HTTP_BOOT_ENABLE or NETWORK_HTTP_ENABLE is set to TRUE!" | |
| !endif | |
| !endif | |
| !endif |