| 1 | # $Id: WINSDK10.kmk 3320 2020-04-16 22:19:22Z bird $
|
|---|
| 2 | ## @file
|
|---|
| 3 | # kBuild SDK - The Microsoft Windows SDK v10.
|
|---|
| 4 | #
|
|---|
| 5 |
|
|---|
| 6 | #
|
|---|
| 7 | # Copyright (c) 2006-2020 knut st. osmundsen <bird-kBuild-spam-xx@anduin.net>
|
|---|
| 8 | #
|
|---|
| 9 | # This file is part of kBuild.
|
|---|
| 10 | #
|
|---|
| 11 | # kBuild is free software; you can redistribute it and/or modify
|
|---|
| 12 | # it under the terms of the GNU General Public License as published by
|
|---|
| 13 | # the Free Software Foundation; either version 2 of the License, or
|
|---|
| 14 | # (at your option) any later version.
|
|---|
| 15 | #
|
|---|
| 16 | # kBuild is distributed in the hope that it will be useful,
|
|---|
| 17 | # but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|---|
| 18 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|---|
| 19 | # GNU General Public License for more details.
|
|---|
| 20 | #
|
|---|
| 21 | # You should have received a copy of the GNU General Public License
|
|---|
| 22 | # along with kBuild; if not, write to the Free Software
|
|---|
| 23 | # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|---|
| 24 | #
|
|---|
| 25 | #
|
|---|
| 26 | # As a special exception you are granted permission to include this file, via
|
|---|
| 27 | # the kmk include directive, as you wish without this in itself causing the
|
|---|
| 28 | # resulting makefile, program or whatever to be covered by the GPL license.
|
|---|
| 29 | # This exception does not however invalidate any other reasons why the makefile,
|
|---|
| 30 | # program, whatever should not be covered the GPL.
|
|---|
| 31 | #
|
|---|
| 32 | #
|
|---|
| 33 |
|
|---|
| 34 | SDK_WINSDK10 := The Windows Platform SDK v7.1, targeting (KBUILD_TARGET).
|
|---|
| 35 |
|
|---|
| 36 | ifndef INCLUDED_WIN_COMMON_KMK
|
|---|
| 37 | include $(KBUILD_PATH)/win-common.kmk
|
|---|
| 38 | endif
|
|---|
| 39 |
|
|---|
| 40 | #
|
|---|
| 41 | # SDK Specific Properties
|
|---|
| 42 | #
|
|---|
| 43 |
|
|---|
| 44 | ## @def PATH_SDK_WINSDK10
|
|---|
| 45 | ## The base path of the Windows 10 SDK.
|
|---|
| 46 | ## @def SDK_WINSDK10_VERSION
|
|---|
| 47 | ## The SDK version for subdirectories.
|
|---|
| 48 | ifndef PATH_SDK_WINSDK10
|
|---|
| 49 | ifndef SDK_WINSDK10_VERSION
|
|---|
| 50 | PATH_SDK_WINSDK10 := $(firstfile $(foreachfile toolsdir, \
|
|---|
| 51 | $(PATH_DEVTOOLS_BLD) $(PATH_DEVTOOLS_TRG) $(PATH_DEVTOOLS)/win.x86 $(PATH_DEVTOOLS)/win.amd64 \
|
|---|
| 52 | , $(rsortfiles $(qwildcard ,$(toolsdir)/sdk/v10*/[Ii][Nn][Cc][Ll][Uu][Dd][Ee]/10.0.*))))
|
|---|
| 53 | ifeq ($(PATH_SDK_WINSDK10),)
|
|---|
| 54 | PATH_SDK_WINSDK10 := $(firstfile $(foreachfile progfilesdir,$(WINCMN_PROGRAM_FILES_LIST)\
|
|---|
| 55 | ,$(rsortfiles $(qwildcard ,$(progfilesdir)/Windows\ Kits/10/[Ii][Nn][Cc][Ll][Uu][Dd][Ee]/10.0.*)) ))
|
|---|
| 56 | ifeq ($(PATH_SDK_WINSDK10),)
|
|---|
| 57 | $(warning kBuild: PATH_SDK_WINSDK10 couldn't be determined!)
|
|---|
| 58 | PATH_SDK_WINSDK10 := $(PATH_DEVTOOLS_BLD)/sdk/v10-not-found/Include/10.0.10240.0
|
|---|
| 59 | endif
|
|---|
| 60 | endif
|
|---|
| 61 | SDK_WINSDK10_VERSION := $(qnotdir ,$(PATH_SDK_WINSDK10))
|
|---|
| 62 | else
|
|---|
| 63 | PATH_SDK_WINSDK10 := $(firstfile $(foreachfile toolsdir, \
|
|---|
| 64 | $(PATH_DEVTOOLS_BLD) $(PATH_DEVTOOLS_TRG) $(PATH_DEVTOOLS)/win.x86 $(PATH_DEVTOOLS)/win.amd64 \
|
|---|
| 65 | , $(rsortfiles $(qwildcard ,$(toolsdir)/sdk/v10*/[Ii][Nn][Cc][Ll][Uu][Dd][Ee]/$(SDK_WINSDK10_VERSION)))))
|
|---|
| 66 | ifeq ($(PATH_SDK_WINSDK10),)
|
|---|
| 67 | PATH_SDK_WINSDK10 := $(firstfile $(foreachfile progfilesdir,$(WINCMN_PROGRAM_FILES_LIST)\
|
|---|
| 68 | ,$(rsortfiles $(qwildcard ,$(progfilesdir)/Windows\ Kits/10/[Ii][Nn][Cc][Ll][Uu][Dd][Ee]/$(SDK_WINSDK10_VERSION))) ))
|
|---|
| 69 | ifeq ($(PATH_SDK_WINSDK10),)
|
|---|
| 70 | $(warning kBuild: PATH_SDK_WINSDK10 couldn't be determined!)
|
|---|
| 71 | PATH_SDK_WINSDK10 := $(PATH_DEVTOOLS_BLD)/sdk/v10-not-found/Include/$(SDK_WINSDK10_VERSION)
|
|---|
| 72 | endif
|
|---|
| 73 | endif
|
|---|
| 74 | SDK_WINSDK10_VERSION := $(qnotdir ,$(PATH_SDK_WINSDK10))
|
|---|
| 75 | endif
|
|---|
| 76 | PATH_SDK_WINSDK10 := $(substr $(qdir ,$(PATH_SDK_WINSDK10)),1,-9)
|
|---|
| 77 | else
|
|---|
| 78 | PATH_SDK_WINSDK10 := $(PATH_SDK_WINSDK10)
|
|---|
| 79 | ifndef SDK_WINSDK10_VERSION
|
|---|
| 80 | SDK_WINSDK10_VERSION := $(qnotdir ,$(firstfile $(rsortfiles $(qwildcard ,$(PATH_SDK_WINSDK10)/[Ii][Nn][Cc][Ll][Uu][Dd][Ee]/10.0.*))))
|
|---|
| 81 | ifeq ($(SDK_WINSDK10_VERSION),)
|
|---|
| 82 | $(warning kBuild: SDK_WINSDK10_VERSION could not be determined for PATH_SDK_WINSDK10=$(PATH_SDK_WINSDK10))
|
|---|
| 83 | SDK_WINSDK10_VERSION := 10.0.10240.0
|
|---|
| 84 | endif
|
|---|
| 85 | endif
|
|---|
| 86 | endif
|
|---|
| 87 |
|
|---|
| 88 | # Non-versioned base directory paths:
|
|---|
| 89 | ifndef PATH_SDK_WINSDK10_BASE_INC
|
|---|
| 90 | PATH_SDK_WINSDK10_BASE_INC := $(firstfile $(qwildcard ,$(PATH_SDK_WINSDK10)/[Ii][Nn][Cc][Ll][Uu][Dd][Ee]) $(PATH_SDK_WINSDK10)/Include)
|
|---|
| 91 | endif
|
|---|
| 92 | ifndef PATH_SDK_WINSDK10_BASE_LIB
|
|---|
| 93 | PATH_SDK_WINSDK10_BASE_LIB := $(firstfile $(qwildcard ,$(PATH_SDK_WINSDK10)/[Ll][Ii][Bb]) $(PATH_SDK_WINSDK10)/lib)
|
|---|
| 94 | endif
|
|---|
| 95 | ifndef PATH_SDK_WINSDK10_BASE_BIN
|
|---|
| 96 | PATH_SDK_WINSDK10_BASE_BIN := $(firstfile $(qwildcard ,$(PATH_SDK_WINSDK10)/[Bb][Ii][Nn]) $(PATH_SDK_WINSDK10)/bin)
|
|---|
| 97 | endif
|
|---|
| 98 |
|
|---|
| 99 | # Universal CRT (UCRT).
|
|---|
| 100 | ifndef PATH_SDK_WINSDK10_UCRT_INC
|
|---|
| 101 | PATH_SDK_WINSDK10_UCRT_INC := $(PATH_SDK_WINSDK10_BASE_INC)/$(SDK_WINSDK10_VERSION)/ucrt
|
|---|
| 102 | endif
|
|---|
| 103 | ifndef PATH_SDK_WINSDK10_UCRT_LIB.amd64
|
|---|
| 104 | PATH_SDK_WINSDK10_UCRT_LIB.amd64 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/ucrt/x64
|
|---|
| 105 | endif
|
|---|
| 106 | ifndef PATH_SDK_WINSDK10_UCRT_LIB.arm32
|
|---|
| 107 | PATH_SDK_WINSDK10_UCRT_LIB.arm32 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/ucrt/arm
|
|---|
| 108 | endif
|
|---|
| 109 | ifndef PATH_SDK_WINSDK10_UCRT_LIB.arm64
|
|---|
| 110 | PATH_SDK_WINSDK10_UCRT_LIB.arm64 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/ucrt/arm64
|
|---|
| 111 | endif
|
|---|
| 112 | ifndef PATH_SDK_WINSDK10_UCRT_LIB.x86
|
|---|
| 113 | PATH_SDK_WINSDK10_UCRT_LIB.x86 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/ucrt/x86
|
|---|
| 114 | endif
|
|---|
| 115 | PATH_SDK_WINSDK10_UCRT_LIB = $(PATH_SDK_WINSDK10_UCRT_LIB.$(KBUILD_TARGET_ARCH))
|
|---|
| 116 | SDK_WINSDK10_UCRT_IMPLIB_NAME := ucrt.lib
|
|---|
| 117 | SDK_WINSDK10_UCRT_IMPLIB_DBG_NAME := ucrtd.lib
|
|---|
| 118 | SDK_WINSDK10_UCRT_STATIC_NAME := libucrt.lib
|
|---|
| 119 | SDK_WINSDK10_UCRT_STATIC_DBG_NAME := libucrtd.lib
|
|---|
| 120 |
|
|---|
| 121 | # Shared API headers
|
|---|
| 122 | ifndef PATH_SDK_WINSDK10_SHARED_INC
|
|---|
| 123 | PATH_SDK_WINSDK10_SHARED_INC := $(PATH_SDK_WINSDK10_BASE_INC)/$(SDK_WINSDK10_VERSION)/shared
|
|---|
| 124 | endif
|
|---|
| 125 |
|
|---|
| 126 | # User-mode API (MS WIN SDK)
|
|---|
| 127 | ifndef PATH_SDK_WINSDK10_UM_INC
|
|---|
| 128 | PATH_SDK_WINSDK10_UM_INC := $(PATH_SDK_WINSDK10_BASE_INC)/$(SDK_WINSDK10_VERSION)/um
|
|---|
| 129 | endif
|
|---|
| 130 | ifndef PATH_SDK_WINSDK10_UM_LIB.amd64
|
|---|
| 131 | PATH_SDK_WINSDK10_UM_LIB.amd64 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/um/x64
|
|---|
| 132 | endif
|
|---|
| 133 | ifndef PATH_SDK_WINSDK10_UM_LIB.arm32
|
|---|
| 134 | PATH_SDK_WINSDK10_UM_LIB.arm32 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/um/arm
|
|---|
| 135 | endif
|
|---|
| 136 | ifndef PATH_SDK_WINSDK10_UM_LIB.arm64
|
|---|
| 137 | PATH_SDK_WINSDK10_UM_LIB.arm64 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/um/arm64
|
|---|
| 138 | endif
|
|---|
| 139 | ifndef PATH_SDK_WINSDK10_UM_LIB.x86
|
|---|
| 140 | PATH_SDK_WINSDK10_UM_LIB.x86 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/um/x86
|
|---|
| 141 | endif
|
|---|
| 142 | PATH_SDK_WINSDK10_UM_LIB = $(PATH_SDK_WINSDK10_UM_LIB.$(KBUILD_TARGET_ARCH))
|
|---|
| 143 | ifndef SDK_WINSDK10_UM_LIB_NAMES
|
|---|
| 144 | SDK_WINSDK10_UM_LIB_NAMES := \
|
|---|
| 145 | Kernel32.Lib \
|
|---|
| 146 | User32.Lib \
|
|---|
| 147 | Gdi32.Lib \
|
|---|
| 148 | AdvAPI32.Lib \
|
|---|
| 149 | shell32.lib \
|
|---|
| 150 | ShLwApi.Lib \
|
|---|
| 151 | SetupAPI.Lib \
|
|---|
| 152 | Uuid.Lib \
|
|---|
| 153 | Version.Lib \
|
|---|
| 154 | WS2_32.Lib \
|
|---|
| 155 | \
|
|---|
| 156 | Ole32.Lib \
|
|---|
| 157 | OleAut32.Lib \
|
|---|
| 158 | OleDlg.Lib \
|
|---|
| 159 | RpcRT4.Lib \
|
|---|
| 160 | DbgHelp.Lib \
|
|---|
| 161 | \
|
|---|
| 162 | ImageHlp.Lib \
|
|---|
| 163 | IPHlpApi.Lib \
|
|---|
| 164 | ComCtl32.Lib \
|
|---|
| 165 | ComDlg32.Lib \
|
|---|
| 166 | WinSpool.Lib \
|
|---|
| 167 | WinMM.Lib
|
|---|
| 168 | endif
|
|---|
| 169 |
|
|---|
| 170 | # Kernel-mode API headers (WDK).
|
|---|
| 171 | ifndef PATH_SDK_WINSDK10_KM_INC
|
|---|
| 172 | PATH_SDK_WINSDK10_KM_INC := $(PATH_SDK_WINSDK10_BASE_INC)/$(SDK_WINSDK10_VERSION)/km
|
|---|
| 173 | endif
|
|---|
| 174 | ifndef PATH_SDK_WINSDK10_KM_LIB.amd64
|
|---|
| 175 | PATH_SDK_WINSDK10_KM_LIB.amd64 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/km/x64
|
|---|
| 176 | endif
|
|---|
| 177 | ifndef PATH_SDK_WINSDK10_KM_LIB.arm32
|
|---|
| 178 | PATH_SDK_WINSDK10_KM_LIB.arm32 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/km/arm
|
|---|
| 179 | endif
|
|---|
| 180 | ifndef PATH_SDK_WINSDK10_KM_LIB.arm64
|
|---|
| 181 | PATH_SDK_WINSDK10_KM_LIB.arm64 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/km/arm64
|
|---|
| 182 | endif
|
|---|
| 183 | ifndef PATH_SDK_WINSDK10_KM_LIB.x86
|
|---|
| 184 | PATH_SDK_WINSDK10_KM_LIB.x86 := $(PATH_SDK_WINSDK10_BASE_LIB)/$(SDK_WINSDK10_VERSION)/km/x86
|
|---|
| 185 | endif
|
|---|
| 186 | PATH_SDK_WINSDK10_KM_LIB = $(PATH_SDK_WINSDK10_KM_LIB.$(KBUILD_TARGET_ARCH))
|
|---|
| 187 |
|
|---|
| 188 | # Binary directory for host.
|
|---|
| 189 | ifndef PATH_SDK_WINSDK10_BIN
|
|---|
| 190 | ifeq ($(KBUILD_HOST_ARCH),amd64)
|
|---|
| 191 | PATH_SDK_WINSDK10_BIN := $(PATH_SDK_WINSDK10_BASE_BIN)/$(SDK_WINSDK10_VERSION)/x64
|
|---|
| 192 | else ifeq ($(KBUILD_HOST_ARCH),arm)
|
|---|
| 193 | PATH_SDK_WINSDK10_BIN := $(PATH_SDK_WINSDK10_BASE_BIN)/$(SDK_WINSDK10_VERSION)/arm
|
|---|
| 194 | else
|
|---|
| 195 | PATH_SDK_WINSDK10_BIN := $(PATH_SDK_WINSDK10_BASE_BIN)/$(SDK_WINSDK10_VERSION)/$(KBUILD_HOST_ARCH)
|
|---|
| 196 | endif
|
|---|
| 197 | endif
|
|---|
| 198 |
|
|---|
| 199 | #
|
|---|
| 200 | # Properties used by kBuild.
|
|---|
| 201 | #
|
|---|
| 202 | SDK_WINSDK10_INCS ?= $(PATH_SDK_WINSDK10_INC)
|
|---|
| 203 | SDK_WINSDK10_LIBPATH.amd64 ?= $(PATH_SDK_WINSDK10_UM_LIB.amd64)
|
|---|
| 204 | SDK_WINSDK10_LIBPATH.arm32 ?= $(PATH_SDK_WINSDK10_UM_LIB.arm32)
|
|---|
| 205 | SDK_WINSDK10_LIBPATH.arm64 ?= $(PATH_SDK_WINSDK10_UM_LIB.arm64)
|
|---|
| 206 | SDK_WINSDK10_LIBPATH.x86 ?= $(PATH_SDK_WINSDK10_UM_LIB.x86)
|
|---|
| 207 | ifndef SDK_WINSDK10_LIBS.amd64
|
|---|
| 208 | SDK_WINSDK10_LIBS.amd64 := $(addprefix $(PATH_SDK_WINSDK10_UM_LIB.amd64)/,$(SDK_WINSDK10_UM_LIB_NAMES))
|
|---|
| 209 | endif
|
|---|
| 210 | ifndef SDK_WINSDK10_LIBS.arm32
|
|---|
| 211 | SDK_WINSDK10_LIBS.arm32 := $(addprefix $(PATH_SDK_WINSDK10_UM_LIB.arm32)/,$(SDK_WINSDK10_UM_LIB_NAMES))
|
|---|
| 212 | endif
|
|---|
| 213 | ifndef SDK_WINSDK10_LIBS.arm64
|
|---|
| 214 | SDK_WINSDK10_LIBS.arm64 := $(addprefix $(PATH_SDK_WINSDK10_UM_LIB.arm64)/,$(SDK_WINSDK10_UM_LIB_NAMES))
|
|---|
| 215 | endif
|
|---|
| 216 | ifndef SDK_WINSDK10_LIBS.x86
|
|---|
| 217 | SDK_WINSDK10_LIBS.x86 := $(addprefix $(PATH_SDK_WINSDK10_UM_LIB.x86)/,$(SDK_WINSDK10_UM_LIB_NAMES))
|
|---|
| 218 | endif
|
|---|
| 219 |
|
|---|