2020-05-04 17:44:11 +08:00
|
|
|
/****************************************************************************
|
2024-03-05 14:29:32 +08:00
|
|
|
* drivers/pci/pci_drivers.c
|
2020-05-04 17:44:11 +08:00
|
|
|
*
|
2024-11-05 20:02:24 +08:00
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*
|
2020-05-04 17:44:11 +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
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
2024-03-05 14:29:32 +08:00
|
|
|
#include <debug.h>
|
2020-05-04 17:44:11 +08:00
|
|
|
|
2024-03-05 14:29:32 +08:00
|
|
|
#include <nuttx/pci/pci.h>
|
2024-02-18 15:31:47 +08:00
|
|
|
#include <nuttx/rptun/rptun_ivshmem.h>
|
2024-02-23 14:57:40 +08:00
|
|
|
#include <nuttx/rpmsg/rpmsg_virtio_ivshmem.h>
|
2024-03-25 11:11:33 +08:00
|
|
|
#include <nuttx/virtio/virtio-pci.h>
|
2024-04-03 00:23:59 +08:00
|
|
|
#include <nuttx/net/e1000.h>
|
2024-09-12 18:31:22 +08:00
|
|
|
#include <nuttx/net/igc.h>
|
2024-10-24 19:25:47 +08:00
|
|
|
#include <nuttx/can/kvaser_pci.h>
|
2024-11-06 18:06:03 +08:00
|
|
|
#include <nuttx/can/ctucanfd_pci.h>
|
2020-05-04 17:44:11 +08:00
|
|
|
|
2024-02-28 21:14:01 +08:00
|
|
|
#include "pci_drivers.h"
|
|
|
|
|
2020-05-04 17:44:11 +08:00
|
|
|
/****************************************************************************
|
2024-03-05 14:29:32 +08:00
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: pci_register_drivers
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Register all the pci drivers to pci bus
|
|
|
|
*
|
2020-05-04 17:44:11 +08:00
|
|
|
****************************************************************************/
|
|
|
|
|
2024-03-05 14:29:32 +08:00
|
|
|
int pci_register_drivers(void)
|
2020-05-04 17:44:11 +08:00
|
|
|
{
|
2024-03-20 23:47:44 +08:00
|
|
|
int ret = OK;
|
2020-05-04 17:44:11 +08:00
|
|
|
|
2023-12-22 16:41:19 +08:00
|
|
|
#ifdef CONFIG_PCI_IVSHMEM
|
|
|
|
ret = pci_ivshmem_register();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_ivshemem_register failed ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-02-28 21:14:01 +08:00
|
|
|
#ifdef CONFIG_PCI_UIO_IVSHMEM
|
|
|
|
ret = pci_register_uio_ivshmem_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_uio_ivshmem_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-02-23 14:57:40 +08:00
|
|
|
/* Initialization rptun ivshmem driver */
|
|
|
|
|
|
|
|
#ifdef CONFIG_RPTUN_IVSHMEM
|
|
|
|
ret = pci_register_rptun_ivshmem_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_rptun_ivshmem_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_RPMSG_VIRTIO_IVSHMEM
|
|
|
|
ret = pci_register_rpmsg_virtio_ivshmem_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_rpmsg_virtio_ivshmem_driver failed, ret=%d\n",
|
|
|
|
ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-03-05 14:29:32 +08:00
|
|
|
/* Initialization pci qemu test driver */
|
2020-05-04 17:44:11 +08:00
|
|
|
|
2024-03-05 14:29:32 +08:00
|
|
|
#ifdef CONFIG_PCI_QEMU_TEST
|
|
|
|
ret = pci_register_qemu_test_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_qemu_test_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
2024-01-22 18:12:09 +08:00
|
|
|
#endif
|
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
|
|
|
|
2024-02-27 22:00:21 +08:00
|
|
|
/* Initialization qemu edu driver */
|
|
|
|
|
|
|
|
#ifdef CONFIG_PCI_QEMU_EDU
|
|
|
|
ret = pci_register_qemu_edu_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_qemu_edu_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-03-25 11:11:33 +08:00
|
|
|
/* Initialization virtio pci driver */
|
|
|
|
|
|
|
|
#ifdef CONFIG_DRIVERS_VIRTIO_PCI
|
|
|
|
ret = register_virtio_pci_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("register_virtio_pci_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-07-04 10:49:21 +08:00
|
|
|
#ifdef CONFIG_PCI_QEMU_EPC
|
|
|
|
ret = pci_register_qemu_epc_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_qemu_ep_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-07-09 20:26:23 +08:00
|
|
|
#ifdef CONFIG_PCI_EPF_TEST
|
|
|
|
ret = pci_register_epf_test_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_epf_test_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-07-18 09:50:28 +08:00
|
|
|
#ifdef CONFIG_PCI_EP_TEST
|
|
|
|
ret = pci_register_ep_test_driver();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_register_ep_test_driver failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-04-03 00:23:59 +08:00
|
|
|
/* Initialization e1000 driver */
|
|
|
|
|
|
|
|
#ifdef CONFIG_NET_E1000
|
|
|
|
ret = pci_e1000_init();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_e1000_init failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-09-12 18:31:22 +08:00
|
|
|
/* Initialization igc driver */
|
|
|
|
|
|
|
|
#ifdef CONFIG_NET_IGC
|
|
|
|
ret = pci_igc_init();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_igc_init failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-10-24 19:25:47 +08:00
|
|
|
/* Initialzie Kvaser pci driver */
|
|
|
|
|
|
|
|
#ifdef CONFIG_CAN_KVASER
|
|
|
|
ret = pci_kvaser_init();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_kvaser_init failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-11-06 18:06:03 +08:00
|
|
|
/* Initialzie CTU CAN FD pci driver */
|
|
|
|
|
|
|
|
#ifdef CONFIG_CAN_CTUCANFD
|
|
|
|
ret = pci_ctucanfd_init();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_ctucanfd_init failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-11-15 10:08:40 +08:00
|
|
|
ret = pci_dev_register();
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
pcierr("pci_dev_register failed, ret=%d\n", ret);
|
|
|
|
}
|
|
|
|
|
2024-03-05 14:29:32 +08:00
|
|
|
UNUSED(ret);
|
|
|
|
return ret;
|
2020-05-04 17:44:11 +08:00
|
|
|
}
|