forked from M-Labs/artiq
spi2: use new rtio_output() API
This commit is contained in:
parent
d18546550e
commit
e8d58b35b4
|
@ -7,7 +7,7 @@ Output event replacement is not supported and issuing commands at the same
|
||||||
time is an error.
|
time is an error.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from artiq.language.core import syscall, kernel, portable, now_mu, delay_mu
|
from artiq.language.core import syscall, kernel, portable, delay_mu
|
||||||
from artiq.language.types import TInt32, TNone
|
from artiq.language.types import TInt32, TNone
|
||||||
from artiq.coredevice.rtio import rtio_output, rtio_input_data
|
from artiq.coredevice.rtio import rtio_output, rtio_input_data
|
||||||
|
|
||||||
|
@ -166,7 +166,7 @@ class SPIMaster:
|
||||||
raise ValueError("Invalid SPI transfer length")
|
raise ValueError("Invalid SPI transfer length")
|
||||||
if div > 257 or div < 2:
|
if div > 257 or div < 2:
|
||||||
raise ValueError("Invalid SPI clock divider")
|
raise ValueError("Invalid SPI clock divider")
|
||||||
rtio_output(now_mu(), self.channel, SPI_CONFIG_ADDR, flags |
|
rtio_output((self.channel << 8) | SPI_CONFIG_ADDR, flags |
|
||||||
((length - 1) << 8) | ((div - 2) << 16) | (cs << 24))
|
((length - 1) << 8) | ((div - 2) << 16) | (cs << 24))
|
||||||
self.update_xfer_duration_mu(div, length)
|
self.update_xfer_duration_mu(div, length)
|
||||||
delay_mu(self.ref_period_mu)
|
delay_mu(self.ref_period_mu)
|
||||||
|
@ -216,7 +216,7 @@ class SPIMaster:
|
||||||
|
|
||||||
:param data: SPI output data to be written.
|
:param data: SPI output data to be written.
|
||||||
"""
|
"""
|
||||||
rtio_output(now_mu(), self.channel, SPI_DATA_ADDR, data)
|
rtio_output((self.channel << 8) | SPI_DATA_ADDR, data)
|
||||||
delay_mu(self.xfer_duration_mu)
|
delay_mu(self.xfer_duration_mu)
|
||||||
|
|
||||||
@kernel
|
@kernel
|
||||||
|
|
Loading…
Reference in New Issue