Page MenuHomeFreeBSD

Update OpenCores i2c driver for SiFive Unmatched.
ClosedPublic

Authored by skibo on Oct 29 2021, 5:44 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 10, 12:19 PM
Unknown Object (File)
Sun, Dec 28, 2:23 AM
Unknown Object (File)
Thu, Dec 25, 9:16 AM
Unknown Object (File)
Dec 12 2025, 9:16 AM
Unknown Object (File)
Dec 12 2025, 2:21 AM
Unknown Object (File)
Dec 8 2025, 11:43 AM
Unknown Object (File)
Dec 5 2025, 1:42 PM
Unknown Object (File)
Nov 27 2025, 3:03 PM

Details

Summary
  • Add compatibility strings for Unmatched.
  • Add support for building driver as a module.
  • Fix repeated start.
Test Plan

Testing on a SiFive Unmatched.

Diff Detail

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

Event Timeline

skibo requested review of this revision.Oct 29 2021, 5:44 PM
jrtc27 added inline comments.
sys/dev/iicbus/iicoc.c
152

Use bool

sys/dev/iicbus/iicoc_fdt.c
59

sifive,i2c0? Until devmatch is able to see secondary compatible strings in the device tree, the SoC-specific compats need to be here if you want the module to be auto-loaded (though maybe this will want to just be compiled into the GENERIC kernel?), but we should still have the generic one too.

sys/modules/i2c/controllers/Makefile
8

Does this need to be limited to RISC-V? The IP isn't tied to a specific core, unlike imcsmb which is Intel's.

sys/modules/i2c/controllers/iicoc/Makefile
1

I don't think we're adding this for new files?

  • Address review feed-back on iicoc driver.
skibo added inline comments.
sys/dev/iicbus/iicoc_fdt.c
59

I was on the fence between putting this in GENERIC or creating a module. But now I'm leaning towards putting it in GENERIC. I would also be inclined to drop the module if we did that. What do you think?

sys/modules/i2c/controllers/Makefile
8

The core is definitely not riscv specific but I thought it would save resources to only build it for riscv. If it shows up in other architectures, we can change it later.

philip added a subscriber: philip.

Looks good to me. Thanks!

I think this is fine in GENERIC. I would prefer this to a module.

This revision is now accepted and ready to land.Oct 31 2021, 10:51 AM