Page MenuHomeFreeBSD

bhnd(4) chipc child enumeration using the chipc capabilities.
ClosedPublic

Authored by landonf on Jun 20 2016, 4:36 AM.
Tags
None
Referenced Files
Unknown Object (File)
Nov 28 2024, 5:05 AM
Unknown Object (File)
Nov 28 2024, 5:01 AM
Unknown Object (File)
Nov 18 2024, 10:30 PM
Unknown Object (File)
Nov 6 2024, 6:06 AM
Unknown Object (File)
Nov 6 2024, 6:06 AM
Unknown Object (File)
Nov 6 2024, 6:05 AM
Unknown Object (File)
Nov 6 2024, 6:05 AM
Unknown Object (File)
Nov 4 2024, 5:47 AM
Subscribers

Details

Summary

Replaces use of DEVICE_IDENTIFY with explicit enumeration of chipc
child devices using the chipc capability structure.

This is a precursor to PMU support, which requires more complex resource
assignment handling than achievable with the static device name-based
hints table.

Test Plan

Tested on:

  • RT-N16
  • RT-N53
  • WGT634U
  • BCM43225
  • BCM4312

Diff Detail

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

Event Timeline

landonf retitled this revision from to bhnd(4) chipc child enumeration using the chipc capabilities..
landonf updated this object.
landonf edited the test plan for this revision. (Show Details)
landonf added a reviewer: adrian.
adrian edited edge metadata.

ok, this looks ok to me. what's michael think?

This revision is now accepted and ready to land.Jun 20 2016, 6:19 AM
landonf added a reviewer: mizhka.

ok, this looks ok to me. what's michael think?

Let's find out :-)

Hi,

I've scan changes briefly:

  • what is test strategy? is it just kernel loading or passing over rc to multiuser mode?
  • changes are more than announced ;) for instance, flashmap is removed. What is new alternative to flashmap?
In D6896#144860, @mizhka_gmail.com wrote:

Hi,

I've scan changes briefly:

  • what is test strategy? is it just kernel loading or passing over rc to multiuser mode?

I've only been testing up to (not including) root mount, pending working CFI on RT-N16 (D5674).
I just got an RT-N53, which uses SPI flash, I should be able to test beyond just flash probing there.

  • changes are more than announced ;) for instance, flashmap is removed. What is new alternative to flashmap?

Thanks for catching that; I missed flash_register_slicer().

I also want to solve CFI issue on RT-N16, hope Alex will look on it.
My laziness forced me to code following test for MIPS boards:

  • CFE load kernel
  • login as root
  • call devinfo, uname, hostname, ifconfig

https://github.com/Cka3o4Huk/uart-mips-test/blob/master/src/main/java/com/github/Cka3o4Huk/CallUnixWrapper.java#L67

May be it worth to have 2 resources for PMU drivers to avoid significant change from DEVICE_IDENTIFY to old-style children creation code?

sys/dev/bhnd/cores/chipc/chipc.c
290–296

BTW, it may be more straigthforward to define 2 different resources (RID=0 / RID=1), isn't it?

In D6896#144912, @mizhka_gmail.com wrote:

May be it worth to have 2 resources for PMU drivers to avoid significant change from DEVICE_IDENTIFY to old-style children creation code?

In terms of being good newbus citizens, we're ultimately better off doing device identification at the bus level; the resource hint table mechanism really just gave us a way to perform bus-level resource enumeration while working around the inversion of control that DEVICE_IDENTIFY creates in the bus/driver relationship.

Quoth the DEVICE_IDENTIFY documentation:

The identify function for a device is only needed for devices on busses that cannot identify their children independently, e.g. the ISA bus.

landonf edited edge metadata.

Re-introduced missing chipc_slicer support.

Verified boot to multiuser on:

  • RT-N16 (with D5674)
  • RT-N52 (with ROOTDEVNAME=ufs:flash/spi0s.rootfs)
This revision now requires review to proceed.Jun 21 2016, 9:33 PM
mizhka requested changes to this revision.Jun 21 2016, 9:47 PM
mizhka edited edge metadata.
This comment was removed by mizhka.
This revision now requires changes to proceed.Jun 21 2016, 9:47 PM
mizhka edited edge metadata.
This revision is now accepted and ready to land.Jun 21 2016, 9:59 PM
adrian edited edge metadata.
This revision was automatically updated to reflect the committed changes.