1 # 2 # CDDL HEADER START 3 # 4 # The contents of this file are subject to the terms of the 5 # Common Development and Distribution License (the "License"). 6 # You may not use this file except in compliance with the License. 7 # 8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 # or http://www.opensolaris.org/os/licensing. 10 # See the License for the specific language governing permissions 11 # and limitations under the License. 12 # 13 # When distributing Covered Code, include this CDDL HEADER in each 14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 # If applicable, add the following below this CDDL HEADER, with the 16 # fields enclosed by brackets "[]" replaced with your own identifying 17 # information: Portions Copyright [yyyy] [name of copyright owner] 18 # 19 # CDDL HEADER END 20 # 21 22 # 23 # Copyright (c) 1992, 2010, Oracle and/or its affiliates. All rights reserved. 24 # 25 # Copyright (c) 2010, Intel Corporation. 26 # Copyright 2018 Joyent, Inc. 27 # Copyright 2019 OmniOS Community Edition (OmniOSce) Association. 28 # 29 # This Makefile defines file modules in the directory uts/i86pc 30 # and its children. These are the source files which are i86pc 31 # "implementation architecture" dependent. 32 # 33 34 # 35 # object lists 36 # 37 CORE_OBJS += \ 38 acpi_stubs.o \ 39 biosdisk.o \ 40 bios_call.o \ 41 cbe.o \ 42 cmi.o \ 43 cmi_hw.o \ 44 cms.o \ 45 comm_page.o \ 46 confunix.o \ 47 cpu_idle.o \ 48 cpuid.o \ 49 cpuid_subr.o \ 50 cpupm.o \ 51 cpupm_mach.o \ 52 cpupm_amd.o \ 53 cpupm_intel.o \ 54 cpupm_throttle.o \ 55 cpu_acpi.o \ 56 dis_tables.o \ 57 ddi_impl.o \ 58 dtrace_subr.o \ 59 dvma.o \ 60 fpu_subr.o \ 61 fakebop.o \ 62 fastboot.o \ 63 fb_swtch.o \ 64 graphics.o \ 65 hardclk.o \ 66 hat_i86.o \ 67 hat_kdi.o \ 68 hma_fpu.o \ 69 hment.o \ 70 hold_page.o \ 71 hrtimers.o \ 72 htable.o \ 73 hypercall.o \ 74 hypersubr.o \ 75 i86_mmu.o \ 76 ibft.o \ 77 instr_size.o \ 78 intr.o \ 79 kboot_mmu.o \ 80 kdi_idt.o \ 81 kdi_idthdl.o \ 82 kdi_asm.o \ 83 lgrpplat.o \ 84 mach_kdi.o \ 85 mach_sysconfig.o \ 86 machdep.o \ 87 md_clear.o \ 88 mem_config.o \ 89 mem_config_stubs.o \ 90 mem_config_arch.o \ 91 memlist_new.o \ 92 memnode.o \ 93 microcode.o \ 94 microfind.o \ 95 mlsetup.o \ 96 mp_call.o \ 97 mp_implfuncs.o \ 98 mp_machdep.o \ 99 mp_pc.o \ 100 mp_startup.o \ 101 memscrub.o \ 102 mpcore.o \ 103 notes.o \ 104 pci_bios.o \ 105 pci_cfgacc.o \ 106 pci_cfgacc_x86.o \ 107 pci_cfgspace.o \ 108 pci_mech1.o \ 109 pci_mech1_amd.o \ 110 pci_mech2.o \ 111 pci_neptune.o \ 112 pci_orion.o \ 113 pmem.o \ 114 ppage.o \ 115 pwrnow.o \ 116 smt.o \ 117 speedstep.o \ 118 ssp.o \ 119 startup.o \ 120 timestamp.o \ 121 todpc_subr.o \ 122 trap.o \ 123 turbo.o \ 124 vm_machdep.o \ 125 xpv_platform.o \ 126 x_call.o 127 128 # 129 # Add the SMBIOS subsystem object files directly to the list of objects 130 # built into unix itself; this is all common code except for smb_dev.c. 131 # 132 CORE_OBJS += $(SMBIOS_OBJS) 133 134 # 135 # These get compiled twice: 136 # - once in the dboot (direct boot) identity mapped code 137 # - once for use during early startup in unix 138 # 139 BOOT_DRIVER_OBJS = \ 140 boot_console.o \ 141 boot_keyboard.o \ 142 boot_keyboard_table.o \ 143 boot_vga.o \ 144 boot_fb.o \ 145 boot_mmu.o \ 146 dboot_multiboot2.o \ 147 $(FONT_OBJS) 148 149 CORE_OBJS += $(BOOT_DRIVER_OBJS) 150 151 # 152 # locore.o is special. It must be the first file relocated so that it 153 # it is relocated just where its name implies. 154 # 155 SPECIAL_OBJS_32 += \ 156 locore.o \ 157 fast_trap_asm.o \ 158 interrupt.o \ 159 syscall_asm.o 160 161 SPECIAL_OBJS_64 += \ 162 locore.o \ 163 fast_trap_asm.o \ 164 interrupt.o \ 165 syscall_asm_amd64.o \ 166 kpti_trampolines.o 167 168 SPECIAL_OBJS += $(SPECIAL_OBJS_$(CLASS)) 169 170 # 171 # Objects that get compiled into the identity mapped PT_LOAD section of unix 172 # to handle the earliest part of booting. 173 # 174 DBOOT_OBJS_32 = 175 176 DBOOT_OBJS_64 += dboot_elfload.o 177 178 DBOOT_OBJS += \ 179 dboot_asm.o \ 180 dboot_grub.o \ 181 dboot_printf.o \ 182 dboot_startkern.o \ 183 memcpy.o \ 184 memset.o \ 185 muldiv.o \ 186 sha1.o \ 187 string.o \ 188 $(BOOT_DRIVER_OBJS) \ 189 $(DBOOT_OBJS_$(CLASS)) 190 191 # 192 # driver and misc modules 193 # 194 GFX_PRIVATE_OBJS += gfx_private.o gfxp_pci.o gfxp_segmap.o \ 195 gfxp_devmap.o gfxp_vgatext.o gfxp_vm.o vgasubr.o \ 196 gfxp_fb.o gfxp_bitmap.o 197 FIPE_OBJS += fipe_drv.o fipe_pm.o 198 IOAT_OBJS += ioat.o ioat_rs.o ioat_ioctl.o ioat_chan.o 199 ISANEXUS_OBJS += isa.o dma_engine.o i8237A.o 200 PCIE_MISC_OBJS += pcie_acpi.o pciehpc_acpi.o pcie_x86.o 201 PCI_E_NEXUS_OBJS += npe.o npe_misc.o 202 PCI_E_NEXUS_OBJS += pci_common.o pci_kstats.o pci_tools.o 203 PCINEXUS_OBJS += pci.o pci_common.o pci_kstats.o pci_tools.o 204 PCPLUSMP_OBJS += apic.o apic_regops.o psm_common.o apic_introp.o \ 205 mp_platform_common.o mp_platform_misc.o \ 206 hpet_acpi.o apic_common.o apic_timer.o 207 APIX_OBJS += apix.o apic_regops.o psm_common.o apix_intr.o apix_utils.o \ 208 apix_irm.o mp_platform_common.o hpet_acpi.o apic_common.o \ 209 apic_timer.o apix_regops.o 210 211 212 ACPI_DRV_OBJS += acpi_drv.o acpi_video.o 213 ACPINEX_OBJS += acpinex_drv.o acpinex_event.o 214 215 CPUDRV_OBJS += \ 216 cpudrv.o \ 217 cpudrv_mach.o 218 219 PPM_OBJS += ppm_subr.o ppm.o ppm_plat.o 220 221 ACPIPPM_OBJS += acpippm.o acpisleep.o 222 ACPIDEV_OBJS += acpidev_drv.o \ 223 acpidev_scope.o acpidev_device.o \ 224 acpidev_container.o \ 225 acpidev_cpu.o \ 226 acpidev_dr.o \ 227 acpidev_memory.o \ 228 acpidev_pci.o \ 229 acpidev_resource.o \ 230 acpidev_usbport.o \ 231 acpidev_util.o 232 233 DRMACH_ACPI_OBJS += drmach_acpi.o dr_util.o drmach_err.o 234 235 DR_OBJS += dr.o dr_cpu.o dr_err.o dr_io.o dr_mem_acpi.o dr_quiesce.o dr_util.o 236 237 ROOTNEX_OBJS += rootnex.o immu.o immu_dmar.o immu_dvma.o \ 238 immu_intrmap.o immu_qinv.o immu_regs.o 239 240 TZMON_OBJS += tzmon.o 241 UPPC_OBJS += uppc.o psm_common.o 242 XSVC_OBJS += xsvc.o 243 AMD_IOMMU_OBJS += amd_iommu.o amd_iommu_impl.o amd_iommu_acpi.o \ 244 amd_iommu_cmd.o amd_iommu_log.o amd_iommu_page_tables.o 245 246 # 247 # Build up defines and paths. 248 # 249 ALL_DEFS += -Di86pc 250 INC_PATH += -I$(UTSBASE)/i86pc -I$(SRC)/common 251 INC_PATH += -I$(UTSBASE)/i86xpv -I$(UTSBASE)/common/xen 252 253 # 254 # Since the assym files are derived, the dependencies must be explicit for 255 # all files including this file. (This is only actually required in the 256 # instance when the .nse_depinfo file does not exist.) 257 # 258 259 ASSYM_DEPS += \ 260 copy.o \ 261 desctbls_asm.o \ 262 ddi_i86_asm.o \ 263 exception.o \ 264 fast_trap_asm.o \ 265 float.o \ 266 i86_subr.o \ 267 interrupt.o \ 268 lock_prim.o \ 269 locore.o \ 270 mpcore.o \ 271 sseblk.o \ 272 swtch.o \ 273 syscall_asm.o \ 274 syscall_asm_amd64.o \ 275 kpti_trampolines.o \ 276 cpr_wakecode.o 277 278 CPR_IMPL_OBJS = cpr_impl.o cpr_wakecode.o 279 280 $(KDI_ASSYM_DEPS:%=$(OBJS_DIR)/%): $(DSF_DIR)/$(OBJS_DIR)/kdi_assym.h