mirror of
https://github.com/m-labs/artiq.git
synced 2025-01-07 09:33:33 +08:00
reorganize for devices/controllers
This commit is contained in:
parent
c5acb68258
commit
61a50ee53c
0
artiq/coredevice/__init__.py
Normal file
0
artiq/coredevice/__init__.py
Normal file
@ -1,7 +1,7 @@
|
|||||||
from operator import itemgetter
|
from operator import itemgetter
|
||||||
from fractions import Fraction
|
from fractions import Fraction
|
||||||
|
|
||||||
from artiq.devices.runtime import LinkInterface
|
from artiq.coredevice.runtime import LinkInterface
|
||||||
|
|
||||||
|
|
||||||
class _RuntimeEnvironment(LinkInterface):
|
class _RuntimeEnvironment(LinkInterface):
|
||||||
@ -12,7 +12,7 @@ class _RuntimeEnvironment(LinkInterface):
|
|||||||
return str(self.llvm_module)
|
return str(self.llvm_module)
|
||||||
|
|
||||||
|
|
||||||
class CoreCom:
|
class Comm:
|
||||||
def get_runtime_env(self):
|
def get_runtime_env(self):
|
||||||
return _RuntimeEnvironment(Fraction(1, 1000000000))
|
return _RuntimeEnvironment(Fraction(1, 1000000000))
|
||||||
|
|
@ -7,8 +7,8 @@ from fractions import Fraction
|
|||||||
import logging
|
import logging
|
||||||
|
|
||||||
from artiq.language import core as core_language
|
from artiq.language import core as core_language
|
||||||
from artiq.devices.runtime import Environment
|
from artiq.coredevice.runtime import Environment
|
||||||
from artiq.devices import runtime_exceptions
|
from artiq.coredevice import runtime_exceptions
|
||||||
|
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
@ -54,7 +54,7 @@ def _read_exactly(f, n):
|
|||||||
return r
|
return r
|
||||||
|
|
||||||
|
|
||||||
class CoreCom:
|
class Comm:
|
||||||
def __init__(self, dev="/dev/ttyUSB1", baud=115200):
|
def __init__(self, dev="/dev/ttyUSB1", baud=115200):
|
||||||
self._fd = os.open(dev, os.O_RDWR | os.O_NOCTTY)
|
self._fd = os.open(dev, os.O_RDWR | os.O_NOCTTY)
|
||||||
self.port = os.fdopen(self._fd, "r+b", buffering=0)
|
self.port = os.fdopen(self._fd, "r+b", buffering=0)
|
@ -1,13 +1,13 @@
|
|||||||
from artiq.language.core import *
|
from artiq.language.core import *
|
||||||
from artiq.language.units import *
|
from artiq.language.units import *
|
||||||
from artiq.devices import rtio_core
|
from artiq.coredevice import rtio
|
||||||
|
|
||||||
|
|
||||||
class DDS(AutoContext):
|
class DDS(AutoContext):
|
||||||
"""Core device Direct Digital Synthesis (DDS) driver.
|
"""Core device Direct Digital Synthesis (DDS) driver.
|
||||||
|
|
||||||
Controls DDS devices managed directly by the core device's runtime. It also
|
Controls DDS devices managed directly by the core device's runtime. It also
|
||||||
uses a RTIO channel (through :class:`artiq.devices.rtio_core.RTIOOut`) to
|
uses a RTIO channel (through :class:`artiq.coredevice.rtio.RTIOOut`) to
|
||||||
control a RF switch that gates the output of the DDS device.
|
control a RF switch that gates the output of the DDS device.
|
||||||
|
|
||||||
:param dds_sysclk: DDS system frequency, used for computing the frequency
|
:param dds_sysclk: DDS system frequency, used for computing the frequency
|
||||||
@ -21,7 +21,7 @@ class DDS(AutoContext):
|
|||||||
|
|
||||||
def build(self):
|
def build(self):
|
||||||
self.previous_frequency = 0*MHz
|
self.previous_frequency = 0*MHz
|
||||||
self.sw = rtio_core.RTIOOut(self, channel=self.rtio_switch)
|
self.sw = rtio.RTIOOut(self, channel=self.rtio_switch)
|
||||||
|
|
||||||
kernel_attr = "previous_frequency"
|
kernel_attr = "previous_frequency"
|
||||||
|
|
@ -1,5 +1,5 @@
|
|||||||
from artiq.language.core import *
|
from artiq.language.core import *
|
||||||
from artiq.devices.runtime_exceptions import RTIOSequenceError
|
from artiq.coredevice.runtime_exceptions import RTIOSequenceError
|
||||||
|
|
||||||
|
|
||||||
class LLRTIOOut(AutoContext):
|
class LLRTIOOut(AutoContext):
|
@ -1,6 +1,6 @@
|
|||||||
from artiq.language.core import *
|
from artiq.language.core import *
|
||||||
from artiq.language.units import *
|
from artiq.language.units import *
|
||||||
from artiq.devices import rtio_core
|
from artiq.coredevice import rtio
|
||||||
|
|
||||||
|
|
||||||
# FIXME: check those numbers
|
# FIXME: check those numbers
|
||||||
@ -104,10 +104,10 @@ class CompoundPDQ2(AutoContext):
|
|||||||
parameters = "ids rtio_trigger rtio_frame"
|
parameters = "ids rtio_trigger rtio_frame"
|
||||||
|
|
||||||
def build(self):
|
def build(self):
|
||||||
self.trigger = rtio_core.LLRTIOOut(self, channel=self.rtio_trigger)
|
self.trigger = rtio.LLRTIOOut(self, channel=self.rtio_trigger)
|
||||||
self.frame0 = rtio_core.LLRTIOOut(self, channel=self.rtio_frame[0])
|
self.frame0 = rtio.LLRTIOOut(self, channel=self.rtio_frame[0])
|
||||||
self.frame1 = rtio_core.LLRTIOOut(self, channel=self.rtio_frame[1])
|
self.frame1 = rtio.LLRTIOOut(self, channel=self.rtio_frame[1])
|
||||||
self.frame2 = rtio_core.LLRTIOOut(self, channel=self.rtio_frame[2])
|
self.frame2 = rtio.LLRTIOOut(self, channel=self.rtio_frame[2])
|
||||||
|
|
||||||
self.frames = []
|
self.frames = []
|
||||||
self.current_frame = -1
|
self.current_frame = -1
|
@ -9,7 +9,7 @@ import logging
|
|||||||
from scipy import interpolate
|
from scipy import interpolate
|
||||||
import numpy as np
|
import numpy as np
|
||||||
|
|
||||||
from artiq.devices.pdq2com import Pdq2
|
from pdq2com import Pdq2
|
||||||
|
|
||||||
|
|
||||||
def _main():
|
def _main():
|
@ -395,7 +395,7 @@ def EncodedException(eid):
|
|||||||
|
|
||||||
class RuntimeException(Exception):
|
class RuntimeException(Exception):
|
||||||
"""Base class for all exceptions used by the device runtime.
|
"""Base class for all exceptions used by the device runtime.
|
||||||
Those exceptions are defined in ``artiq.devices.runtime_exceptions``.
|
Those exceptions are defined in ``artiq.coredevice.runtime_exceptions``.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
pass
|
pass
|
||||||
|
@ -1,20 +1,20 @@
|
|||||||
Drivers reference
|
Drivers reference
|
||||||
=================
|
=================
|
||||||
|
|
||||||
:mod:`artiq.devices.rtio_core` module
|
:mod:`artiq.coredevice.rtio` module
|
||||||
-------------------------------------
|
-----------------------------------
|
||||||
|
|
||||||
.. automodule:: artiq.devices.rtio_core
|
.. automodule:: artiq.coredevice.rtio
|
||||||
:members:
|
:members:
|
||||||
|
|
||||||
:mod:`artiq.devices.dds_core` module
|
:mod:`artiq.coredevice.dds` module
|
||||||
-------------------------------------
|
----------------------------------
|
||||||
|
|
||||||
.. automodule:: artiq.devices.dds_core
|
.. automodule:: artiq.coredevice.dds
|
||||||
:members:
|
:members:
|
||||||
|
|
||||||
:mod:`artiq.devices.runtime_exceptions` module
|
:mod:`artiq.coredevice.runtime_exceptions` module
|
||||||
----------------------------------------------
|
-------------------------------------------------
|
||||||
|
|
||||||
.. automodule:: artiq.devices.runtime_exceptions
|
.. automodule:: artiq.coredevice.runtime_exceptions
|
||||||
:members:
|
:members:
|
||||||
|
@ -7,7 +7,7 @@ Connecting to the core device
|
|||||||
As a very first step, we will turn on a LED on the core device. Create a file ``led.py`` containing the following: ::
|
As a very first step, we will turn on a LED on the core device. Create a file ``led.py`` containing the following: ::
|
||||||
|
|
||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, gpio_core
|
from artiq.coredevice import comm_serial, core, gpio
|
||||||
|
|
||||||
class LED(AutoContext):
|
class LED(AutoContext):
|
||||||
parameters = "led"
|
parameters = "led"
|
||||||
@ -17,9 +17,9 @@ As a very first step, we will turn on a LED on the core device. Create a file ``
|
|||||||
self.led.set(1)
|
self.led.set(1)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
core_driver = core.Core(com)
|
core_driver = core.Core(comm)
|
||||||
led_driver = gpio_core.GPIOOut(core=core_driver, channel=0)
|
led_driver = gpio.GPIOOut(core=core_driver, channel=0)
|
||||||
exp = LED(core=core_driver, led=led_driver)
|
exp = LED(core=core_driver, led=led_driver)
|
||||||
exp.run()
|
exp.run()
|
||||||
|
|
||||||
@ -82,7 +82,7 @@ The point of running code on the core device is the ability to meet demanding re
|
|||||||
Create a new file ``rtio.py`` containing the following: ::
|
Create a new file ``rtio.py`` containing the following: ::
|
||||||
|
|
||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, rtio_core
|
from artiq.coredevice import comm_serial, core, rtio
|
||||||
|
|
||||||
class Tutorial(AutoContext):
|
class Tutorial(AutoContext):
|
||||||
parameters = "o"
|
parameters = "o"
|
||||||
@ -94,9 +94,9 @@ Create a new file ``rtio.py`` containing the following: ::
|
|||||||
delay(2*us)
|
delay(2*us)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
core_driver = core.Core(com)
|
core_driver = core.Core(comm)
|
||||||
out_driver = rtio_core.RTIOOut(core=core_driver, channel=1)
|
out_driver = rtio.RTIOOut(core=core_driver, channel=1)
|
||||||
exp = Tutorial(core=core_driver, o=out_driver)
|
exp = Tutorial(core=core_driver, o=out_driver)
|
||||||
exp.run()
|
exp.run()
|
||||||
|
|
||||||
@ -106,7 +106,7 @@ Instead, inside the core device, output timing is generated by the gateware and
|
|||||||
|
|
||||||
Try reducing the period of the generated waveform until the CPU cannot keep up with the generation of switching events and the underflow exception is raised. Then try catching it: ::
|
Try reducing the period of the generated waveform until the CPU cannot keep up with the generation of switching events and the underflow exception is raised. Then try catching it: ::
|
||||||
|
|
||||||
from artiq.devices.runtime_exceptions import RTIOUnderflow
|
from artiq.coredevice.runtime_exceptions import RTIOUnderflow
|
||||||
|
|
||||||
def print_underflow():
|
def print_underflow():
|
||||||
print("RTIO underflow occured")
|
print("RTIO underflow occured")
|
||||||
|
@ -30,18 +30,18 @@ class CompilerTest(AutoContext):
|
|||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
from artiq.devices import corecom_dummy, core, dds_core
|
from artiq.coredevice import comm_dummy, core, dds
|
||||||
|
|
||||||
coredev = core.Core(corecom_dummy.CoreCom())
|
coredev = core.Core(comm_dummy.Comm())
|
||||||
exp = CompilerTest(
|
exp = CompilerTest(
|
||||||
core=coredev,
|
core=coredev,
|
||||||
a=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
a=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=0, rtio_switch=0),
|
reg_channel=0, rtio_switch=0),
|
||||||
b=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
b=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=1, rtio_switch=1),
|
reg_channel=1, rtio_switch=1),
|
||||||
A=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
A=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=2, rtio_switch=2),
|
reg_channel=2, rtio_switch=2),
|
||||||
B=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
B=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=3, rtio_switch=3)
|
reg_channel=3, rtio_switch=3)
|
||||||
)
|
)
|
||||||
exp.run(3, 100*us)
|
exp.run(3, 100*us)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, dds_core, gpio_core
|
from artiq.coredevice import comm_serial, core, dds, gpio
|
||||||
|
|
||||||
|
|
||||||
class DDSTest(AutoContext):
|
class DDSTest(AutoContext):
|
||||||
@ -23,19 +23,19 @@ class DDSTest(AutoContext):
|
|||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
exp = DDSTest(
|
exp = DDSTest(
|
||||||
core=coredev,
|
core=coredev,
|
||||||
a=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
a=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=0, rtio_switch=0),
|
reg_channel=0, rtio_switch=0),
|
||||||
b=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
b=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=1, rtio_switch=1),
|
reg_channel=1, rtio_switch=1),
|
||||||
c=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
c=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=2, rtio_switch=2),
|
reg_channel=2, rtio_switch=2),
|
||||||
d=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
d=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=3, rtio_switch=3),
|
reg_channel=3, rtio_switch=3),
|
||||||
led=gpio_core.GPIOOut(core=coredev, channel=0)
|
led=gpio.GPIOOut(core=coredev, channel=0)
|
||||||
)
|
)
|
||||||
exp.run()
|
exp.run()
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import sys
|
import sys
|
||||||
|
|
||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core
|
from artiq.coredevice import comm_serial, core
|
||||||
|
|
||||||
|
|
||||||
class Mandelbrot(AutoContext):
|
class Mandelbrot(AutoContext):
|
||||||
@ -39,8 +39,8 @@ class Mandelbrot(AutoContext):
|
|||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
exp = Mandelbrot(core=core.Core(com))
|
exp = Mandelbrot(core=core.Core(comm))
|
||||||
exp.run()
|
exp.run()
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, dds_core, rtio_core
|
from artiq.coredevice import comm_serial, core, dds, rtio
|
||||||
|
|
||||||
|
|
||||||
class PhotonHistogram(AutoContext):
|
class PhotonHistogram(AutoContext):
|
||||||
@ -36,15 +36,15 @@ class PhotonHistogram(AutoContext):
|
|||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
exp = PhotonHistogram(
|
exp = PhotonHistogram(
|
||||||
core=coredev,
|
core=coredev,
|
||||||
bd=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
bd=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=0, rtio_switch=1),
|
reg_channel=0, rtio_switch=1),
|
||||||
bdd=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
bdd=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=1, rtio_switch=2),
|
reg_channel=1, rtio_switch=2),
|
||||||
pmt=rtio_core.RTIOIn(core=coredev, channel=0),
|
pmt=rtio.RTIOIn(core=coredev, channel=0),
|
||||||
repeats=100,
|
repeats=100,
|
||||||
nbins=100
|
nbins=100
|
||||||
)
|
)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, rtio_core
|
from artiq.coredevice import comm_serial, core, rtio
|
||||||
from artiq.devices.runtime_exceptions import RTIOUnderflow
|
from artiq.coredevice.runtime_exceptions import RTIOUnderflow
|
||||||
|
|
||||||
|
|
||||||
def print_min_period(p):
|
def print_min_period(p):
|
||||||
@ -27,8 +27,8 @@ class PulsePerformance(AutoContext):
|
|||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
exp = PulsePerformance(core=coredev,
|
exp = PulsePerformance(core=coredev,
|
||||||
o=rtio_core.RTIOOut(core=coredev, channel=1))
|
o=rtio.RTIOOut(core=coredev, channel=1))
|
||||||
exp.run()
|
exp.run()
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, rtio_core
|
from artiq.coredevice import comm_serial, core, rtio
|
||||||
|
|
||||||
|
|
||||||
def print_skew(p):
|
def print_skew(p):
|
||||||
@ -28,9 +28,9 @@ class RTIOSkew(AutoContext):
|
|||||||
print_skew(int((out_t - in_t)/(1*ns)))
|
print_skew(int((out_t - in_t)/(1*ns)))
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
exp = RTIOSkew(core=coredev,
|
exp = RTIOSkew(core=coredev,
|
||||||
i=rtio_core.RTIOIn(core=coredev, channel=0),
|
i=rtio.RTIOIn(core=coredev, channel=0),
|
||||||
o=rtio_core.RTIOOut(core=coredev, channel=1))
|
o=rtio.RTIOOut(core=coredev, channel=1))
|
||||||
exp.run()
|
exp.run()
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
import numpy as np
|
import numpy as np
|
||||||
|
|
||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, dds_core, rtio_core, pdq2
|
from artiq.coredevice import comm_serial, core, dds, rtio
|
||||||
|
from artiq.devices import pdq2
|
||||||
|
|
||||||
|
|
||||||
class Transport(AutoContext):
|
class Transport(AutoContext):
|
||||||
@ -114,15 +115,15 @@ if __name__ == "__main__":
|
|||||||
# 4 devices, 3 board each, 3 dacs each
|
# 4 devices, 3 board each, 3 dacs each
|
||||||
)
|
)
|
||||||
|
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
exp = Transport(
|
exp = Transport(
|
||||||
core=coredev,
|
core=coredev,
|
||||||
bd=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
bd=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=0, rtio_switch=1),
|
reg_channel=0, rtio_switch=1),
|
||||||
bdd=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
bdd=dds.DDS(core=coredev, dds_sysclk=1*GHz,
|
||||||
reg_channel=1, rtio_switch=2),
|
reg_channel=1, rtio_switch=2),
|
||||||
pmt=rtio_core.RTIOIn(core=coredev, channel=0),
|
pmt=rtio.RTIOIn(core=coredev, channel=0),
|
||||||
# a compound pdq device that wraps multiple usb devices (looked up
|
# a compound pdq device that wraps multiple usb devices (looked up
|
||||||
# by usb "serial number"/id) into one
|
# by usb "serial number"/id) into one
|
||||||
electrodes=pdq2.CompoundPDQ2(
|
electrodes=pdq2.CompoundPDQ2(
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
import argparse
|
import argparse
|
||||||
from artiq.devices import corecom_serial
|
from artiq.coredevice import comm_serial
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
@ -16,13 +16,13 @@ def main():
|
|||||||
|
|
||||||
with open(args.file, "rb") as f:
|
with open(args.file, "rb") as f:
|
||||||
binary = f.read()
|
binary = f.read()
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.CoreCom() as comm:
|
||||||
runtime_env = com.get_runtime_env()
|
runtime_env = comm.get_runtime_env()
|
||||||
if args.e:
|
if args.e:
|
||||||
print(runtime_env)
|
print(runtime_env)
|
||||||
com.load(binary)
|
comm.load(binary)
|
||||||
com.run(args.f)
|
comm.run(args.f)
|
||||||
com.serve(dict(), dict())
|
comm.serve(dict(), dict())
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
main()
|
main()
|
||||||
|
@ -3,7 +3,7 @@ include $(MSCDIR)/software/common.mak
|
|||||||
BOARD=papilio_pro
|
BOARD=papilio_pro
|
||||||
SERIAL=/dev/ttyUSB1
|
SERIAL=/dev/ttyUSB1
|
||||||
|
|
||||||
OBJECTS=isr.o elf_loader.o exception_jmp.o exceptions.o services.o corecom_serial.o gpio.o rtio.o dds.o main.o
|
OBJECTS=isr.o elf_loader.o exception_jmp.o exceptions.o services.o comm_serial.o gpio.o rtio.o dds.o main.o
|
||||||
|
|
||||||
all: runtime.bin
|
all: runtime.bin
|
||||||
|
|
||||||
|
17
soc/runtime/comm.h
Normal file
17
soc/runtime/comm.h
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
#ifndef __COMM_H
|
||||||
|
#define __COMM_H
|
||||||
|
|
||||||
|
enum {
|
||||||
|
KERNEL_RUN_FINISHED,
|
||||||
|
KERNEL_RUN_EXCEPTION,
|
||||||
|
KERNEL_RUN_STARTUP_FAILED
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef int (*object_loader)(void *, int);
|
||||||
|
typedef int (*kernel_runner)(const char *, int *);
|
||||||
|
|
||||||
|
void comm_serve(object_loader load_object, kernel_runner run_kernel);
|
||||||
|
int comm_rpc(int rpc_num, int n_args, ...);
|
||||||
|
void comm_log(const char *fmt, ...);
|
||||||
|
|
||||||
|
#endif /* __COMM_H */
|
@ -3,7 +3,7 @@
|
|||||||
#include <uart.h>
|
#include <uart.h>
|
||||||
#include <generated/csr.h>
|
#include <generated/csr.h>
|
||||||
|
|
||||||
#include "corecom.h"
|
#include "comm.h"
|
||||||
|
|
||||||
/* host to device */
|
/* host to device */
|
||||||
enum {
|
enum {
|
||||||
@ -139,12 +139,12 @@ static void receive_and_run_kernel(kernel_runner run_kernel)
|
|||||||
send_char(MSGTYPE_KERNEL_STARTUP_FAILED);
|
send_char(MSGTYPE_KERNEL_STARTUP_FAILED);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
corecom_log("BUG: run_kernel returned unexpected value '%d'", r);
|
comm_log("BUG: run_kernel returned unexpected value '%d'", r);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void corecom_serve(object_loader load_object, kernel_runner run_kernel)
|
void comm_serve(object_loader load_object, kernel_runner run_kernel)
|
||||||
{
|
{
|
||||||
char msgtype;
|
char msgtype;
|
||||||
|
|
||||||
@ -166,7 +166,7 @@ void corecom_serve(object_loader load_object, kernel_runner run_kernel)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int corecom_rpc(int rpc_num, int n_args, ...)
|
int comm_rpc(int rpc_num, int n_args, ...)
|
||||||
{
|
{
|
||||||
send_char(MSGTYPE_RPC_REQUEST);
|
send_char(MSGTYPE_RPC_REQUEST);
|
||||||
send_sint(rpc_num);
|
send_sint(rpc_num);
|
||||||
@ -181,7 +181,7 @@ int corecom_rpc(int rpc_num, int n_args, ...)
|
|||||||
return receive_int();
|
return receive_int();
|
||||||
}
|
}
|
||||||
|
|
||||||
void corecom_log(const char *fmt, ...)
|
void comm_log(const char *fmt, ...)
|
||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
int len;
|
int len;
|
@ -1,17 +0,0 @@
|
|||||||
#ifndef __CORECOM_H
|
|
||||||
#define __CORECOM_H
|
|
||||||
|
|
||||||
enum {
|
|
||||||
KERNEL_RUN_FINISHED,
|
|
||||||
KERNEL_RUN_EXCEPTION,
|
|
||||||
KERNEL_RUN_STARTUP_FAILED
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef int (*object_loader)(void *, int);
|
|
||||||
typedef int (*kernel_runner)(const char *, int *);
|
|
||||||
|
|
||||||
void corecom_serve(object_loader load_object, kernel_runner run_kernel);
|
|
||||||
int corecom_rpc(int rpc_num, int n_args, ...);
|
|
||||||
void corecom_log(const char *fmt, ...);
|
|
||||||
|
|
||||||
#endif /* __CORECOM_H */
|
|
@ -1,6 +1,6 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "corecom.h"
|
#include "comm.h"
|
||||||
#include "elf_loader.h"
|
#include "elf_loader.h"
|
||||||
|
|
||||||
#define EI_NIDENT 16
|
#define EI_NIDENT 16
|
||||||
@ -85,11 +85,11 @@ struct elf32_sym {
|
|||||||
|
|
||||||
#define SANITIZE_OFFSET_SIZE(offset, size) \
|
#define SANITIZE_OFFSET_SIZE(offset, size) \
|
||||||
if(offset > 0x10000000) { \
|
if(offset > 0x10000000) { \
|
||||||
corecom_log("Incorrect offset in ELF data"); \
|
comm_log("Incorrect offset in ELF data"); \
|
||||||
return 0; \
|
return 0; \
|
||||||
} \
|
} \
|
||||||
if((offset + size) > elf_length) { \
|
if((offset + size) > elf_length) { \
|
||||||
corecom_log("Attempted to access past the end of ELF data"); \
|
comm_log("Attempted to access past the end of ELF data"); \
|
||||||
return 0; \
|
return 0; \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,7 +121,7 @@ static int fixup(void *dest, int dest_length, struct elf32_rela *rela, void *tar
|
|||||||
val = _target - (_dest + offset);
|
val = _target - (_dest + offset);
|
||||||
_dest[offset] = (_dest[offset] & 0xfc000000) | (val & 0x03ffffff);
|
_dest[offset] = (_dest[offset] & 0xfc000000) | (val & 0x03ffffff);
|
||||||
} else
|
} else
|
||||||
corecom_log("Unsupported relocation type: %d", type);
|
comm_log("Unsupported relocation type: %d", type);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,15 +141,15 @@ int load_elf(symbol_resolver resolver, symbol_callback callback, void *elf_data,
|
|||||||
/* validate ELF */
|
/* validate ELF */
|
||||||
GET_POINTER_SAFE(ehdr, struct elf32_ehdr, 0);
|
GET_POINTER_SAFE(ehdr, struct elf32_ehdr, 0);
|
||||||
if(memcmp(ehdr->ident, elf_magic_header, sizeof(elf_magic_header)) != 0) {
|
if(memcmp(ehdr->ident, elf_magic_header, sizeof(elf_magic_header)) != 0) {
|
||||||
corecom_log("Incorrect ELF header");
|
comm_log("Incorrect ELF header");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if(ehdr->type != ET_REL) {
|
if(ehdr->type != ET_REL) {
|
||||||
corecom_log("ELF is not relocatable");
|
comm_log("ELF is not relocatable");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if(ehdr->machine != EM_OR1K) {
|
if(ehdr->machine != EM_OR1K) {
|
||||||
corecom_log("ELF is for a different machine");
|
comm_log("ELF is for a different machine");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -190,7 +190,7 @@ int load_elf(symbol_resolver resolver, symbol_callback callback, void *elf_data,
|
|||||||
|
|
||||||
/* load .text section */
|
/* load .text section */
|
||||||
if(textsize > dest_length) {
|
if(textsize > dest_length) {
|
||||||
corecom_log(".text section is too large");
|
comm_log(".text section is too large");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
memcpy(dest, (char *)elf_data + textoff, textsize);
|
memcpy(dest, (char *)elf_data + textoff, textsize);
|
||||||
@ -209,13 +209,13 @@ int load_elf(symbol_resolver resolver, symbol_callback callback, void *elf_data,
|
|||||||
name = (char *)elf_data + strtaboff + sym->name;
|
name = (char *)elf_data + strtaboff + sym->name;
|
||||||
target = resolver(name);
|
target = resolver(name);
|
||||||
if(target == NULL) {
|
if(target == NULL) {
|
||||||
corecom_log("Undefined symbol: %s", name);
|
comm_log("Undefined symbol: %s", name);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if(!fixup(dest, dest_length, rela, target))
|
if(!fixup(dest, dest_length, rela, target))
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
corecom_log("Unsupported relocation");
|
comm_log("Unsupported relocation");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#include "exceptions.h"
|
#include "exceptions.h"
|
||||||
#include "corecom.h"
|
#include "comm.h"
|
||||||
|
|
||||||
#define MAX_EXCEPTION_CONTEXTS 64
|
#define MAX_EXCEPTION_CONTEXTS 64
|
||||||
|
|
||||||
@ -34,7 +34,7 @@ void exception_raise(int id)
|
|||||||
stored_id = id;
|
stored_id = id;
|
||||||
exception_longjmp(exception_contexts[--ec_top].jb);
|
exception_longjmp(exception_contexts[--ec_top].jb);
|
||||||
} else {
|
} else {
|
||||||
corecom_log("ERROR: uncaught exception, ID=%d\n", id);
|
comm_log("ERROR: uncaught exception, ID=%d\n", id);
|
||||||
while(1);
|
while(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <generated/csr.h>
|
#include <generated/csr.h>
|
||||||
|
|
||||||
#include "corecom.h"
|
#include "comm.h"
|
||||||
#include "elf_loader.h"
|
#include "elf_loader.h"
|
||||||
#include "exceptions.h"
|
#include "exceptions.h"
|
||||||
#include "services.h"
|
#include "services.h"
|
||||||
@ -31,7 +31,7 @@ static void symtab_init(void)
|
|||||||
static int symtab_add(const char *name, void *target)
|
static int symtab_add(const char *name, void *target)
|
||||||
{
|
{
|
||||||
if(_symtab_count >= sizeof(symtab)/sizeof(symtab[0])) {
|
if(_symtab_count >= sizeof(symtab)/sizeof(symtab[0])) {
|
||||||
corecom_log("Too many provided symbols in object");
|
comm_log("Too many provided symbols in object");
|
||||||
symtab_init();
|
symtab_init();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -41,7 +41,7 @@ static int symtab_add(const char *name, void *target)
|
|||||||
|
|
||||||
while(1) {
|
while(1) {
|
||||||
if(_symtab_strptr >= &_symtab_strings[sizeof(_symtab_strings)]) {
|
if(_symtab_strptr >= &_symtab_strings[sizeof(_symtab_strings)]) {
|
||||||
corecom_log("Provided symbol string table overflow");
|
comm_log("Provided symbol string table overflow");
|
||||||
symtab_init();
|
symtab_init();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -72,7 +72,7 @@ static int run_kernel(const char *kernel_name, int *eid)
|
|||||||
|
|
||||||
k = find_symbol(symtab, kernel_name);
|
k = find_symbol(symtab, kernel_name);
|
||||||
if(k == NULL) {
|
if(k == NULL) {
|
||||||
corecom_log("Failed to find kernel entry point '%s' in object", kernel_name);
|
comm_log("Failed to find kernel entry point '%s' in object", kernel_name);
|
||||||
return KERNEL_RUN_STARTUP_FAILED;
|
return KERNEL_RUN_STARTUP_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,6 +113,6 @@ int main(void)
|
|||||||
rtio_init();
|
rtio_init();
|
||||||
dds_init();
|
dds_init();
|
||||||
blink_led();
|
blink_led();
|
||||||
corecom_serve(load_object, run_kernel);
|
comm_serve(load_object, run_kernel);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "elf_loader.h"
|
#include "elf_loader.h"
|
||||||
#include "corecom.h"
|
#include "comm.h"
|
||||||
#include "gpio.h"
|
#include "gpio.h"
|
||||||
#include "rtio.h"
|
#include "rtio.h"
|
||||||
#include "dds.h"
|
#include "dds.h"
|
||||||
@ -9,7 +9,7 @@
|
|||||||
#include "services.h"
|
#include "services.h"
|
||||||
|
|
||||||
static const struct symbol syscalls[] = {
|
static const struct symbol syscalls[] = {
|
||||||
{"rpc", corecom_rpc},
|
{"rpc", comm_rpc},
|
||||||
{"gpio_set", gpio_set},
|
{"gpio_set", gpio_set},
|
||||||
{"rtio_oe", rtio_oe},
|
{"rtio_oe", rtio_oe},
|
||||||
{"rtio_set", rtio_set},
|
{"rtio_set", rtio_set},
|
||||||
|
@ -2,13 +2,13 @@ import unittest
|
|||||||
from operator import itemgetter
|
from operator import itemgetter
|
||||||
|
|
||||||
from artiq import *
|
from artiq import *
|
||||||
from artiq.devices import corecom_serial, core, runtime_exceptions, rtio_core
|
from artiq.coredevice import comm_serial, core, runtime_exceptions, rtio
|
||||||
from artiq.sim import devices as sim_devices
|
from artiq.sim import devices as sim_devices
|
||||||
|
|
||||||
|
|
||||||
def _run_on_device(k_class, **parameters):
|
def _run_on_device(k_class, **parameters):
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
k_inst = k_class(core=coredev, **parameters)
|
k_inst = k_class(core=coredev, **parameters)
|
||||||
k_inst.run()
|
k_inst.run()
|
||||||
|
|
||||||
@ -190,33 +190,33 @@ class _RTIOSequenceError(AutoContext):
|
|||||||
class RTIOCase(unittest.TestCase):
|
class RTIOCase(unittest.TestCase):
|
||||||
def test_loopback(self):
|
def test_loopback(self):
|
||||||
npulses = 4
|
npulses = 4
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
uut = _RTIOLoopback(
|
uut = _RTIOLoopback(
|
||||||
core=coredev,
|
core=coredev,
|
||||||
i=rtio_core.RTIOIn(core=coredev, channel=0),
|
i=rtio.RTIOIn(core=coredev, channel=0),
|
||||||
o=rtio_core.RTIOOut(core=coredev, channel=1),
|
o=rtio.RTIOOut(core=coredev, channel=1),
|
||||||
npulses=npulses
|
npulses=npulses
|
||||||
)
|
)
|
||||||
uut.run()
|
uut.run()
|
||||||
self.assertEqual(uut.result, npulses)
|
self.assertEqual(uut.result, npulses)
|
||||||
|
|
||||||
def test_underflow(self):
|
def test_underflow(self):
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
uut = _RTIOUnderflow(
|
uut = _RTIOUnderflow(
|
||||||
core=coredev,
|
core=coredev,
|
||||||
o=rtio_core.RTIOOut(core=coredev, channel=1)
|
o=rtio.RTIOOut(core=coredev, channel=1)
|
||||||
)
|
)
|
||||||
with self.assertRaises(runtime_exceptions.RTIOUnderflow):
|
with self.assertRaises(runtime_exceptions.RTIOUnderflow):
|
||||||
uut.run()
|
uut.run()
|
||||||
|
|
||||||
def test_sequence_error(self):
|
def test_sequence_error(self):
|
||||||
with corecom_serial.CoreCom() as com:
|
with comm_serial.Comm() as comm:
|
||||||
coredev = core.Core(com)
|
coredev = core.Core(comm)
|
||||||
uut = _RTIOSequenceError(
|
uut = _RTIOSequenceError(
|
||||||
core=coredev,
|
core=coredev,
|
||||||
o=rtio_core.RTIOOut(core=coredev, channel=1)
|
o=rtio.RTIOOut(core=coredev, channel=1)
|
||||||
)
|
)
|
||||||
with self.assertRaises(runtime_exceptions.RTIOSequenceError):
|
with self.assertRaises(runtime_exceptions.RTIOSequenceError):
|
||||||
uut.run()
|
uut.run()
|
||||||
|
Loading…
Reference in New Issue
Block a user