Page MenuHomeFreeBSD

pci_dw: Support modern "unroll" iATU mode
ClosedPublic

Authored by jrtc27 on Jul 5 2021, 12:09 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 15, 4:14 PM
Unknown Object (File)
Tue, Jan 7, 7:20 AM
Unknown Object (File)
Sat, Dec 28, 3:13 AM
Unknown Object (File)
Dec 23 2024, 6:55 PM
Unknown Object (File)
Dec 20 2024, 4:31 PM
Unknown Object (File)
Dec 13 2024, 4:49 PM
Unknown Object (File)
Dec 8 2024, 5:50 AM
Unknown Object (File)
Nov 21 2024, 6:49 AM
Subscribers

Details

Summary

This supersedes the old legacy mode where a viewport register was used
to mux multiple regions behind a single set of registers, and is used on
the SiFive FU740.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 40276
Build 37165: arc lint + arc unit

Event Timeline

On correctly implemented systems, reading from an unimplemented device register will cause an exception (external asynchronous interrupt on arm64), on real systems it will return an arbitrary value.
Therefore, pci_dw_detect_atu_unroll() should only be called for modern core versions (which have the DW_IATU_VIEWPORT register implemented) - so we should check the core version first.
Otherwise looks good to me.

Please, ignore my previous comment - I overlooked register name :(

Tested on MACCHIATObin and HoneyComb LX2.

This revision is now accepted and ready to land.Jul 10 2021, 11:46 AM
This revision was automatically updated to reflect the committed changes.