Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  1) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  2)  * Broadcom 43xx PCI-SSB bridge module
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  3)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  4)  * This technically is a separate PCI driver module, but
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  5)  * because of its small size we include it in the SSB core
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  6)  * instead of creating a standalone module.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  7)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  8)  * Copyright 2007  Michael Buesch <m@bues.ch>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  9)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10)  * Licensed under the GNU/GPL. See COPYING for details.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) #include "ssb_private.h"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) #include <linux/pci.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) #include <linux/module.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #include <linux/ssb/ssb.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) static const struct pci_device_id b43_pci_bridge_tbl[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4301) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4306) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4307) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4311) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4312) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4315) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4318) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) 	{ PCI_DEVICE(PCI_VENDOR_ID_BCM_GVC,  0x4318) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4319) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4320) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4321) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4322) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 43222) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4324) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4325) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4328) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4329) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x432b) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x432c) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4350) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) 	{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4351) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) 	{ 0, },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) MODULE_DEVICE_TABLE(pci, b43_pci_bridge_tbl);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) static struct pci_driver b43_pci_bridge_driver = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) 	.name = "b43-pci-bridge",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) 	.id_table = b43_pci_bridge_tbl,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) int __init b43_pci_ssb_bridge_init(void)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) 	return ssb_pcihost_register(&b43_pci_bridge_driver);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) void __exit b43_pci_ssb_bridge_exit(void)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) 	ssb_pcihost_unregister(&b43_pci_bridge_driver);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) }