Page MenuHomeFreeBSD

Add SPI driver for Rockchip platform
ClosedPublic

Authored by gonzo on Oct 24 2019, 10:07 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 23, 5:04 PM
Unknown Object (File)
Thu, Jan 23, 5:01 PM
Unknown Object (File)
Thu, Jan 23, 5:00 PM
Unknown Object (File)
Thu, Jan 23, 4:46 PM
Unknown Object (File)
Thu, Jan 23, 12:08 PM
Unknown Object (File)
Wed, Jan 22, 4:18 AM
Unknown Object (File)
Tue, Jan 21, 11:43 AM
Unknown Object (File)
Tue, Jan 7, 4:26 AM
Subscribers

Details

Summary

SPI driver for Rockchip IP works only in PIO mode for now. DMA is not supported yet.
For now the driver supports only RK3399 compatibility string but it should work with older SoCs too.

Diff Detail

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

Event Timeline

Add GENERIC config change

sys/arm64/rockchip/clk/rk3399_cru.c
1587 ↗(On Diff #63668)

hack leftovers.

1618 ↗(On Diff #63668)

hack leftovers.

sys/arm64/rockchip/rk_spi.c
151

IP only have CS0 and CS1, we should add a checks here and return EINVAL

192

Is this needed ?
and if it is why not doing the same for the rxfifo ?

gonzo added inline comments.
sys/arm64/rockchip/rk_spi.c
192

This is what Linux driver does and I think it's to handle SPI chips on older SoCs. RX fifo has the same size as TX fifo AFAIK, so there is no need to do it twice.

Check value of CS and return EINVAL if it's more than max

OK for me.
If you could split the commits between clocks and driver that would be great.

This revision is now accepted and ready to land.Oct 25 2019, 8:26 PM