| History log of /src/sys/arch/mips/rmi/rmixl_obio.c |
| Revision | | Date | Author | Comments |
| 1.10 |
| 29-Sep-2022 |
skrll | Remove unnecessary include of <sys/malloc.h>.
|
| 1.9 |
| 22-Jan-2022 |
skrll | Ensure bus_dmatag_subregion is called with an inclusive max_addr everywhere.
|
| 1.8 |
| 22-Jan-2022 |
skrll | Trailing whitespace
|
| 1.7 |
| 07-Aug-2021 |
thorpej | Merge thorpej-cfargs2.
|
| 1.6 |
| 24-Apr-2021 |
thorpej | branches: 1.6.8; Merge thorpej-cfargs branch:
Simplify and make extensible the config_search() / config_found() / config_attach() interfaces: rather than having different variants for which arguments you want pass along, just have a single call that takes a variadic list of tag-value arguments.
Adjust all call sites: - Simplify wherever possible; don't pass along arguments that aren't actually needed. - Don't be explicit about what interface attribute is attaching if the device only has one. (More simplification.) - Add a config_probe() function to be used in indirect configuiration situations, making is visibly easier to see when indirect config is in play, and allowing for future change in semantics. (As of now, this is just a wrapper around config_match(), but that is an implementation detail.)
Remove unnecessary or redundant interface attributes where they're not needed.
There are currently 5 "cfargs" defined: - CFARG_SUBMATCH (submatch function for direct config) - CFARG_SEARCH (search function for indirect config) - CFARG_IATTR (interface attribte) - CFARG_LOCATORS (locators array) - CFARG_DEVHANDLE (devhandle_t - wraps OFW, ACPI, etc. handles)
...and a sentinel value CFARG_EOL.
Add some extra sanity checking to ensure that interface attributes aren't ambiguous.
Use CFARG_DEVHANDLE in MI FDT, OFW, and ACPI code, and macppc and shark ports to associate those device handles with device_t instance. This will trickle trough to more places over time (need back-end for pre-OFW Sun OBP; any others?).
|
| 1.5 |
| 10-Jul-2011 |
matt | branches: 1.5.68; Fix machine/ includes
|
| 1.4 |
| 01-Jul-2011 |
dyoung | #include <sys/bus.h> instead of <machine/bus.h>.
|
| 1.3 |
| 20-Feb-2011 |
matt | Merge forward from matt-nb5-mips64.
|
| 1.2 |
| 14-Dec-2009 |
matt | branches: 1.2.4; 1.2.6; 1.2.8; 1.2.10; Merge from matt-nb5-mips64 Merge mips-specific arch files.
|
| 1.1 |
| 13-Sep-2009 |
cliff | branches: 1.1.2; file rmixl_obio.c was initially added on branch matt-nb5-mips64.
|
| 1.1.2.18 |
| 31-Dec-2011 |
matt | Switch to using IST_<foo> instead of private enums.
|
| 1.1.2.17 |
| 24-Dec-2011 |
matt | Add XLP support (i2c, console, pci, sdhc works).
|
| 1.1.2.16 |
| 17-Apr-2010 |
cliff | - struct rmixl_config field 'rc_64bit_dmat' is now a bus_dma_tag_t and initially points at 'rc_dma_tag' which provides the store area. this allows rc_64bit_dmat to be subregioned for imposing bounce-buffering if needed.
|
| 1.1.2.15 |
| 12-Apr-2010 |
cliff | - specifiy if mpsafe when establishing interrupts (all are 'false' except comintr for now)
|
| 1.1.2.14 |
| 21-Mar-2010 |
cliff | - add use of the 'tmsk' locator - adapt to new rmixl_intr_establish() args - establishing the system bridge controller address error interrupt is now explicitly XLS specific
|
| 1.1.2.13 |
| 24-Jan-2010 |
cliff | remove include of "obio.h"
|
| 1.1.2.12 |
| 20-Jan-2010 |
matt | cleanup attachments so that other mips cpus can use the same scheme.
|
| 1.1.2.11 |
| 13-Jan-2010 |
cliff | - don't match if attach arg name doesn;t match cf_name
|
| 1.1.2.10 |
| 10-Jan-2010 |
matt | Actually use a 32bit limit for the 32bit bus_dma_tag.
|
| 1.1.2.9 |
| 10-Jan-2010 |
matt | Add generic support for DMA bounce buffers and real version of bus_dmatag_subregion. MALTA uses it for ISADMA. Make RMIXL use for creating 32bit and 29bit subregions.
|
| 1.1.2.8 |
| 14-Dec-2009 |
cliff | - replace single bus space with two (big & little endian) bus spaces for obio
|
| 1.1.2.7 |
| 18-Nov-2009 |
cliff | - use PRIxBUSADDR, PRIxBUSSIZE formats as needed
|
| 1.1.2.6 |
| 15-Nov-2009 |
cliff | - use PRIxPADDR and PRIxPSIZE as needed when printing bus address and size following change in typedef - use new obio bus space
|
| 1.1.2.5 |
| 09-Nov-2009 |
cliff | - convert to CFATTACH_DECL_NEW & related - add obio_dma_init_29() to allow DMA for addrs < 512MB - obio_dma_init_32() and obio_dma_init_64() are TBD (#ifdef NOTYET) - obio_bus_dmamap_sync() provides null DMA sync function, since DMA is cache coherent - rmixl_addr_error_init() establishes ISR for address error interrupt
|
| 1.1.2.4 |
| 15-Sep-2009 |
cliff | make functions static
|
| 1.1.2.3 |
| 15-Sep-2009 |
cliff | obio now provides both big endian and little endian bus spaces to allow child devices to use according to access method needs
also preparing for dual bus_dma methods, one for addrs <4GB, the other for all memory, including addrs >= 4GB the bulk of XLS DMA work is still TBD
|
| 1.1.2.2 |
| 13-Sep-2009 |
cliff | improve how some config data are managed
|
| 1.1.2.1 |
| 13-Sep-2009 |
cliff | add netbsd support for RMI XLS6ATX_7A board and XL SoC family
|
| 1.2.10.1 |
| 05-Mar-2011 |
bouyer | Sync with HEAD
|
| 1.2.8.1 |
| 06-Jun-2011 |
jruoho | Sync with HEAD.
|
| 1.2.6.1 |
| 05-Mar-2011 |
rmind | sync with head
|
| 1.2.4.2 |
| 11-Mar-2010 |
yamt | sync with head
|
| 1.2.4.1 |
| 14-Dec-2009 |
yamt | file rmixl_obio.c was added on branch yamt-nfs-mp on 2010-03-11 15:02:41 +0000
|
| 1.5.68.6 |
| 05-Apr-2021 |
thorpej | Treat config_probe() as if it were a boolean function; don't compare return value > 0... except for the odd balls, which are now really easy to spot.
|
| 1.5.68.5 |
| 05-Apr-2021 |
thorpej | config_match() -> config_probe() for the straight-forward indirect config cases. There are still a few odd balls using config_match() which should be sorted out later.
|
| 1.5.68.4 |
| 04-Apr-2021 |
thorpej | CFARG_SUBMATCH -> CFARG_SEARCH for the indirect configuration uses.
|
| 1.5.68.3 |
| 03-Apr-2021 |
thorpej | Give config_attach() the tagged variadic argument treatment and mechanically convert all call sites.
|
| 1.5.68.2 |
| 21-Mar-2021 |
thorpej | CFARG_IATTR usage audit:
If a device carries only one interface attribute, there is no need to specify it when calling config_search(); that specification is meant only to disambiguate which interface attribute (which is a proxy for "what kind of attach args are being used") is having children attached. cfparent_match() will take care of ensuring that any potential children can attach to one of the parent's iterface attributes, and if the parent only carries one, no disambiguation is necessary.
|
| 1.5.68.1 |
| 20-Mar-2021 |
thorpej | The proliferation if config_search_*() and config_found_*() combinations is a little absurd, so begin to tidy this up:
- Introduce a new cfarg_t enumerated type, that defines the types of tag-value variadic arguments that can be passed to the various config_*() functions (CFARG_SUBMATCH, CFARG_IATTR, and CFARG_LOCATORS, for now, plus a CFARG_EOL sentinel). - Collapse config_search_*() into config_search() that takes these variadic arguments. - Convert all call sites of config_search_*() to the new signature. Noticed several incorrect usages along the way, which will be audited in a future commit.
|
| 1.6.8.1 |
| 04-Aug-2021 |
thorpej | Adapt to CFARGS().
|