Skip to content

Commit

Permalink
Switch from VS2019 to VS2022 and add ClangPDB to PR and CI gates
Browse files Browse the repository at this point in the history
This change added the support for locating CLANGPDB for Windows host
systems.

Co-authored-by: Sean Brogan <[email protected]>
Signed-off-by: Kun Qin <[email protected]>

(cherry picked from commit 803897e)
  • Loading branch information
spbrogan authored and kuqin12 committed Jul 30, 2024
1 parent e5a993a commit 433da20
Show file tree
Hide file tree
Showing 2 changed files with 105 additions and 0 deletions.
94 changes: 94 additions & 0 deletions BaseTools/Plugin/ClangPdbToolChain/ClangPdbToolChain.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
# @file ClangPdbToolChain.py
# Plugin to configures paths for the ClangPdb tool chain
##
# This plugin works in conjuncture with the tools_def
#
# Copyright (c) Microsoft Corporation
# SPDX-License-Identifier: BSD-2-Clause-Patent
##
import os
import logging
from io import StringIO
from edk2toolext.environment.plugintypes.uefi_build_plugin import IUefiBuildPlugin
from edk2toolext.environment import shell_environment
from edk2toolext.environment import version_aggregator
from edk2toollib.utility_functions import GetHostInfo
from edk2toollib.utility_functions import RunCmd


class ClangPdbToolChain(IUefiBuildPlugin):

def do_post_build(self, thebuilder):
return 0

def do_pre_build(self, thebuilder):
self.Logger = logging.getLogger("ClangPdbToolChain")

##
# CLANGPBD
# - Need to find the clang path.
# - Report path and version for logging
#
# if CLANG_BIN already set the plugin will confirm it exists and get the version of clang
# If not set it will look for clang on the path. If found it will configure for that.
# if still not found it will try the default install directory.
# finally an error will be reported if not found
##
if thebuilder.env.GetValue("TOOL_CHAIN_TAG") == "CLANGPDB":

HostInfo = GetHostInfo()
ClangBin_Default = "UNDEFINED"
clang_exe = "clang"

if HostInfo.os == "Windows":
ClangBin_Default = "C:\\Program Files\\LLVM\\bin\\\\" #need to escape the last slash as it seems to be removed
clang_exe += ".exe"
elif HostInfo.os == "Linux":
ClangBin_Default = "/LLVM/bin/" #this isn't right
else:
pass
# no defaults set

ClangBin = shell_environment.GetEnvironment().get_shell_var("CLANG_BIN")
if ClangBin is not None:
self.Logger.info("CLANG_BIN is already set.")
else:
# see if clang is on path.
for path_entry in os.getenv("PATH").split(os.pathsep):
path_entry = os.path.normpath(path_entry)
if os.path.isfile(os.path.join(path_entry, clang_exe)):
ClangBin = os.path.abspath(path_entry) + os.sep
break
if ClangBin is None:
# Didn't find it on path - try the install default.
ClangBin = ClangBin_Default

shell_environment.GetEnvironment().set_shell_var("CLANG_BIN", ClangBin)

version_aggregator.GetVersionAggregator().ReportVersion(
"CLANG BIN", ClangBin, version_aggregator.VersionTypes.INFO)

# now confirm it exists
if not os.path.exists(shell_environment.GetEnvironment().get_shell_var("CLANG_BIN")):
self.Logger.error(f"Path for CLANGPDB toolchain is invalid. {ClangBin}")
return -2

version_aggregator.GetVersionAggregator().ReportVersion(
"CLANG Version", self._get_clang_version(ClangBin), version_aggregator.VersionTypes.TOOL)

return 0

##
## Get the clang version to report
##
## clang --version
## clang version 12.0.0
##
def _get_clang_version(self, clang_bin_path):
return_buffer = StringIO()
ret = RunCmd(os.path.join(clang_bin_path, "clang"), "--version", outstream=return_buffer)
if (ret != 0):
logging.warning("Failed to find version of clang")
return -1
line = return_buffer.getvalue().splitlines()[0].strip()
return line[14:].strip()
11 changes: 11 additions & 0 deletions BaseTools/Plugin/ClangPdbToolChain/ClangPdbToolChain_plug_in.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
## @file
# Build Plugin used to set the path to the Clang/LLVM PDB tools chain
#
# Copyright (c) Microsoft Corporation.
# SPDX-License-Identifier: BSD-2-Clause-Patent
##
{
"scope": "global",
"name": "Clang Pdb Tool Chain Support",
"module": "ClangPdbToolChain"
}

0 comments on commit 433da20

Please sign in to comment.