2008-01-08 08:19:24 +08:00
|
|
|
############################################################################
|
|
|
|
# drivers/Makefile
|
2007-02-18 07:21:28 +08:00
|
|
|
#
|
2024-11-05 20:02:24 +08:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
#
|
2021-02-19 18:57:46 +08:00
|
|
|
# Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
# contributor license agreements. See the NOTICE file distributed with
|
|
|
|
# this work for additional information regarding copyright ownership. The
|
|
|
|
# ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
# "License"); you may not use this file except in compliance with the
|
|
|
|
# License. You may obtain a copy of the License at
|
2007-02-18 07:21:28 +08:00
|
|
|
#
|
2021-02-19 18:57:46 +08:00
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
2007-02-18 07:21:28 +08:00
|
|
|
#
|
2021-02-19 18:57:46 +08:00
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
# License for the specific language governing permissions and limitations
|
|
|
|
# under the License.
|
2007-02-18 07:21:28 +08:00
|
|
|
#
|
2008-01-08 08:19:24 +08:00
|
|
|
############################################################################
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2020-05-19 03:42:11 +08:00
|
|
|
include $(TOPDIR)/Make.defs
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2022-03-11 22:52:32 +08:00
|
|
|
CSRCS = drivers_initialize.c
|
|
|
|
|
2011-05-16 23:09:39 +08:00
|
|
|
# Include support for various drivers. Each Make.defs file will add its
|
|
|
|
# files to the source file list, add its DEPPATH info, and will add
|
|
|
|
# the appropriate paths to the VPATH variable
|
2009-10-18 21:52:21 +08:00
|
|
|
|
2020-05-21 01:11:16 +08:00
|
|
|
include analog/Make.defs
|
|
|
|
include audio/Make.defs
|
|
|
|
include bch/Make.defs
|
|
|
|
include can/Make.defs
|
2021-11-26 11:13:58 +08:00
|
|
|
include clk/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include crypto/Make.defs
|
2023-05-07 15:13:31 +08:00
|
|
|
include devicetree/Make.defs
|
2018-03-28 15:30:23 +08:00
|
|
|
include dma/Make.defs
|
2021-07-14 20:41:25 +08:00
|
|
|
include math/Make.defs
|
2021-03-29 18:18:07 +08:00
|
|
|
include motor/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include i2c/Make.defs
|
|
|
|
include i2s/Make.defs
|
2023-03-06 22:24:08 +08:00
|
|
|
include i3c/Make.defs
|
2022-06-28 21:45:41 +08:00
|
|
|
include ipcc/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include input/Make.defs
|
|
|
|
include ioexpander/Make.defs
|
|
|
|
include lcd/Make.defs
|
|
|
|
include leds/Make.defs
|
|
|
|
include loop/Make.defs
|
2022-03-11 22:13:17 +08:00
|
|
|
include misc/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include mmcsd/Make.defs
|
|
|
|
include modem/Make.defs
|
|
|
|
include mtd/Make.defs
|
|
|
|
include eeprom/Make.defs
|
2021-01-15 21:52:43 +08:00
|
|
|
include efuse/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include net/Make.defs
|
2020-08-06 01:43:13 +08:00
|
|
|
include note/Make.defs
|
2023-09-20 15:27:12 +08:00
|
|
|
include pinctrl/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include pipes/Make.defs
|
|
|
|
include power/Make.defs
|
2023-07-19 20:17:15 +08:00
|
|
|
include regmap/Make.defs
|
2023-11-10 20:39:21 +08:00
|
|
|
include rmt/Make.defs
|
2023-12-12 10:53:45 +08:00
|
|
|
include rpmsg/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include rptun/Make.defs
|
|
|
|
include sensors/Make.defs
|
|
|
|
include serial/Make.defs
|
|
|
|
include spi/Make.defs
|
|
|
|
include syslog/Make.defs
|
2023-10-13 23:10:56 +08:00
|
|
|
include thermal/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include timers/Make.defs
|
|
|
|
include usbdev/Make.defs
|
|
|
|
include usbhost/Make.defs
|
|
|
|
include usbmisc/Make.defs
|
|
|
|
include usbmonitor/Make.defs
|
2024-03-27 20:32:31 +08:00
|
|
|
include vhost/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include video/Make.defs
|
2022-11-23 19:45:05 +08:00
|
|
|
include virtio/Make.defs
|
2020-05-21 01:11:16 +08:00
|
|
|
include wireless/Make.defs
|
|
|
|
include contactless/Make.defs
|
|
|
|
include 1wire/Make.defs
|
|
|
|
include rf/Make.defs
|
2020-10-23 16:36:11 +08:00
|
|
|
include rc/Make.defs
|
2022-01-21 20:00:26 +08:00
|
|
|
include segger/Make.defs
|
2022-09-09 20:58:51 +08:00
|
|
|
include usrsock/Make.defs
|
2023-06-06 16:32:15 +08:00
|
|
|
include reset/Make.defs
|
Various fixes for PCI work
Squashed commits:
1. Porting prior PCI work in place of jailhouse code
At this point the PCI enumeration works for x86_64 including over
pci-pci bridges.
Running QEMU with this configuration we see the bridge and the
device on the bridge. It also detected the qemu test device
qemu-system-x86_64 \
-cpu host,+pcid,+x2apic,+tsc-deadline,+xsave,+rdrand \
--enable-kvm -smp 1 -m 2G -cdrom boot.iso --nographic -no-reboot \
-device pci-testdev \
-device pci-bridge,id=bridge0,chassis_nr=2 \
-device e1000,bus=bridge0,addr=0x3
qemu_pci_init: Initializing PCI Bus
pci_probe_device: [00:00.0] Found 8086:1237, class/revision 06000002
pci_probe_device: [00:01.1] Found 8086:7010, class/revision 01018000
pci_probe_device: [00:01.2] Found ffff:ffff, class/revision ffffffff
pci_probe_device: [00:01.3] Found 8086:7113, class/revision 06800003
pci_probe_device: [00:01.4] Found ffff:ffff, class/revision ffffffff
pci_probe_device: [00:01.5] Found ffff:ffff, class/revision ffffffff
pci_probe_device: [00:01.6] Found ffff:ffff, class/revision ffffffff
pci_probe_device: [00:01.7] Found ffff:ffff, class/revision ffffffff
pci_probe_device: [00:02.0] Found 1234:1111, class/revision 03000002
pci_probe_device: [00:03.0] Found 8086:100e, class/revision 02000003
pci_probe_device: [00:04.0] Found 1b36:0005, class/revision 00ff0000
pci_probe_device: [00:04.0] Probing
pci_check_pci_bridge: [00:05.0] Found Bridge
pci_probe_device: [01:03.0] Found 8086:100e, class/revision 02000003
pci_probe_device: [00:05.0] Found 1b36:0001, class/revision 06040000
2. Remove unused CONFIG_PCI_MAX_BDF option
3. Add a workaround for Jailhouse pci scanning
4. Extend BAR parsing and handle PIO and MMIO for pci-testdev
Signed-off-by: Brennan Ashton <bashton@brennanashton.com>
5. PCI: Add initial support for QEMU 'edu' test device
Signed-off-by: Brennan Ashton <bashton@brennanashton.com>
6. Bring up PCI later in boot process
Signed-off-by: Brennan Ashton <bashton@brennanashton.com>
7. Add ISR and DMA support to QEMU edu test pci device
Signed-off-by: Brennan Ashton <bashton@brennanashton.com>
8. Fix bad function prototype definition in qemu_edu
9. intel64: Add a pci test configuration and instructions
Signed-off-by: Brennan Ashton <bashton@brennanashton.com>
10. PCI: Fix issue in identification of 64bit bar
Signed-off-by: Brennan Ashton <bashton@brennanashton.com>
2020-05-07 17:59:29 +08:00
|
|
|
include pci/Make.defs
|
2023-09-15 19:33:41 +08:00
|
|
|
include coresight/Make.defs
|
2024-03-25 17:36:46 +08:00
|
|
|
include aie/Make.defs
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2019-08-21 21:39:29 +08:00
|
|
|
ifeq ($(CONFIG_SPECIFIC_DRIVERS),y)
|
2021-08-19 13:25:19 +08:00
|
|
|
-include platform/Make.defs
|
2019-08-21 21:39:29 +08:00
|
|
|
endif
|
|
|
|
|
2012-11-23 05:21:48 +08:00
|
|
|
AOBJS = $(ASRCS:.S=$(OBJEXT))
|
|
|
|
COBJS = $(CSRCS:.c=$(OBJEXT))
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2012-11-23 05:21:48 +08:00
|
|
|
SRCS = $(ASRCS) $(CSRCS)
|
|
|
|
OBJS = $(AOBJS) $(COBJS)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2012-11-23 05:21:48 +08:00
|
|
|
BIN = libdrivers$(LIBEXT)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2012-11-23 05:21:48 +08:00
|
|
|
all: $(BIN)
|
2022-01-26 22:34:47 +08:00
|
|
|
.PHONY: context depend clean distclean
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2007-02-28 07:59:20 +08:00
|
|
|
$(AOBJS): %$(OBJEXT): %.S
|
2008-01-09 01:06:21 +08:00
|
|
|
$(call ASSEMBLE, $<, $@)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2007-02-28 21:42:19 +08:00
|
|
|
$(COBJS): %$(OBJEXT): %.c
|
2008-01-09 01:06:21 +08:00
|
|
|
$(call COMPILE, $<, $@)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2012-11-23 05:21:48 +08:00
|
|
|
$(BIN): $(OBJS)
|
2012-11-16 01:43:29 +08:00
|
|
|
$(call ARCHIVE, $@, $(OBJS))
|
2020-11-28 11:43:30 +08:00
|
|
|
|
2022-01-26 22:34:47 +08:00
|
|
|
context::
|
|
|
|
|
2024-09-15 12:41:42 +08:00
|
|
|
makedepfile: $(CSRCS:.c=.ddc) $(ASRCS:.S=.dds)
|
|
|
|
$(call CATFILE, Make.dep, $^)
|
|
|
|
$(call DELFILE, $^)
|
|
|
|
|
2020-07-22 15:54:29 +08:00
|
|
|
.depend: Makefile $(SRCS) $(TOPDIR)$(DELIM).config
|
2024-09-15 12:41:42 +08:00
|
|
|
$(Q) $(MAKE) makedepfile
|
2020-03-23 10:44:03 +08:00
|
|
|
$(Q) touch $@
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2020-03-23 10:44:03 +08:00
|
|
|
depend: .depend
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
clean:
|
2012-11-20 23:47:41 +08:00
|
|
|
$(call DELFILE, $(BIN))
|
2008-01-10 21:38:13 +08:00
|
|
|
$(call CLEAN)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2022-01-26 22:34:47 +08:00
|
|
|
distclean:: clean
|
2012-11-20 23:47:41 +08:00
|
|
|
$(call DELFILE, Make.dep)
|
2020-03-23 10:44:03 +08:00
|
|
|
$(call DELFILE, .depend)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
-include Make.dep
|