8053 beefd0184a 2022-08-08 ct_chen 2 years ago
..
Kconfig beefd0184a 2022-08-08 ct_chen 2 years ago
Makefile beefd0184a 2022-08-08 ct_chen 2 years ago
README beefd0184a 2022-08-08 ct_chen 2 years ago
TODO beefd0184a 2022-08-08 ct_chen 2 years ago
bcma_private.h beefd0184a 2022-08-08 ct_chen 2 years ago
core.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_chipcommon.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_chipcommon_b.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_chipcommon_nflash.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_chipcommon_pflash.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_chipcommon_pmu.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_chipcommon_sflash.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_gmac_cmn.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_gpio.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_mips.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_pci.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_pci_host.c beefd0184a 2022-08-08 ct_chen 2 years ago
driver_pcie2.c beefd0184a 2022-08-08 ct_chen 2 years ago
host_pci.c beefd0184a 2022-08-08 ct_chen 2 years ago
host_soc.c beefd0184a 2022-08-08 ct_chen 2 years ago
main.c beefd0184a 2022-08-08 ct_chen 2 years ago
scan.c beefd0184a 2022-08-08 ct_chen 2 years ago
scan.h beefd0184a 2022-08-08 ct_chen 2 years ago
sprom.c beefd0184a 2022-08-08 ct_chen 2 years ago

README

Broadcom introduced new bus as replacement for older SSB. It is based on AMBA,
however from programming point of view there is nothing AMBA specific we use.

Standard AMBA drivers are platform specific, have hardcoded addresses and use
AMBA standard fields like CID and PID.

In case of Broadcom's cards every device consists of:
1) Broadcom specific AMBA device. It is put on AMBA bus, but can not be treated
as standard AMBA device. Reading it's CID or PID can cause machine lockup.
2) AMBA standard devices called ports or wrappers. They have CIDs (AMBA_CID)
and PIDs (0x103BB369), but we do not use that info for anything. One of that
devices is used for managing Broadcom specific core.

Addresses of AMBA devices are not hardcoded in driver and have to be read from
EPROM.

In this situation we decided to introduce separated bus. It can contain up to
16 devices identified by Broadcom specific fields: manufacturer, id, revision
and class.