Page MenuHomeFreeBSD

[mips/broadcom] Replace static frequency table with generic PMU clock handling.
ClosedPublic

Authored by landonf on Aug 18 2016, 4:54 AM.
Tags
None
Referenced Files
F107844338: D7552.id19462.diff
Sat, Jan 18, 4:34 PM
F107804637: D7552.id19431.diff
Sat, Jan 18, 7:53 AM
Unknown Object (File)
Fri, Jan 10, 2:15 AM
Unknown Object (File)
Dec 19 2024, 2:41 PM
Unknown Object (File)
Dec 18 2024, 12:37 AM
Unknown Object (File)
Dec 7 2024, 5:11 AM
Unknown Object (File)
Oct 29 2024, 5:33 AM
Unknown Object (File)
Oct 25 2024, 7:36 AM
Subscribers

Details

Summary

Changes:

  • Extended PWRCTL/PMU APIs to support querying clock frequency during very early boot, prior to bus attach.
  • Implement generic PMU-based calculation of UART rclk values.
  • Replaced use of static frequency tables (bcm_socinfo) with runtime-determined values.

Depends on D7492

Test Plan

For RT-N16, RT-N53, and WGT634U:

  • Verified computed clock values against those specified in static table.
  • Verified that I did not, in fact, break the serial console.

Diff Detail

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

Event Timeline

landonf retitled this revision from to [mips/broadcom] Replace static frequency table with generic PMU clock handling..
landonf updated this object.
landonf edited the test plan for this revision. (Show Details)
landonf added reviewers: adrian, mizhka.
  • Avoid using implicit global variables in BCM register macros. In theory, all the bcm_platform APIs should be usable with an arbitrary bcm_platform instance.
  • PMU watchdog writes were always sent to ChipCommon, even if a PMU core was found. Since none of our currently supported devices use a distinct PMU core (and map the register block to ChipCommon), this worked fine.
  • Due to a typo, the UART clock divisor register offset (instead of value) was improperly masked.
adrian edited edge metadata.
This revision is now accepted and ready to land.Aug 18 2016, 11:53 PM
This revision was automatically updated to reflect the committed changes.