forked from M-Labs/artiq
1
0
Fork 0

devices/rtio_core: set OE, implement gate/count

This commit is contained in:
Sebastien Bourdeauducq 2014-09-15 22:48:22 +08:00
parent 8bf7b27a89
commit 140b4eb594
1 changed files with 34 additions and 5 deletions

View File

@ -1,7 +1,7 @@
from artiq.language.core import * from artiq.language.core import *
class RTIOOut(AutoContext): class _RTIOBase(AutoContext):
parameters = "channel" parameters = "channel"
def build(self): def build(self):
@ -10,6 +10,10 @@ class RTIOOut(AutoContext):
kernel_attr = "previous_timestamp previous_value" kernel_attr = "previous_timestamp previous_value"
@kernel
def _set_oe(self, oe):
syscall("rtio_oe", self.channel, oe)
@kernel @kernel
def _set_value(self, value): def _set_value(self, value):
if self.previous_value != value: if self.previous_value != value:
@ -20,6 +24,12 @@ class RTIOOut(AutoContext):
self.previous_timestamp = now() self.previous_timestamp = now()
self.previous_value = value self.previous_value = value
class RTIOOut(_RTIOBase):
def build(self):
_RTIOBase.build(self)
self._set_oe(1)
@kernel @kernel
def sync(self): def sync(self):
syscall("rtio_sync", self.channel) syscall("rtio_sync", self.channel)
@ -39,13 +49,32 @@ class RTIOOut(AutoContext):
self.off() self.off()
class RTIOCounter(AutoContext): class RTIOCounter(_RTIOBase):
parameters = "channel" def build(self):
_RTIOBase.build(self)
self._set_oe(0)
@kernel @kernel
def count_rising(self, duration): def count_rising(self, duration):
pass self._set_value(1)
delay(duration)
self._set_value(0)
@kernel
def count_falling(self, duration):
self._set_value(2)
delay(duration)
self._set_value(0)
@kernel
def count_both_edges(self, duration):
self._set_value(3)
delay(duration)
self._set_value(0)
@kernel @kernel
def sync(self): def sync(self):
return 42 count = 0
while syscall("rtio_get", self.channel) >= 0:
count += 1
return count