occheung
f0febe0ee4
change catch type to single reference
2022-05-31 18:26:30 +08:00
mwojcik
7a8f96dbd9
rtio_mgt: use mutex's async_lock
2022-05-25 10:39:06 +08:00
mwojcik
596edb480c
cargo: update zynq-rs
2022-05-25 10:37:38 +08:00
mwojcik
4f457d9c24
moninj: log link down at debug level
2022-05-25 10:37:38 +08:00
mwojcik
24df52268e
moninj: restructure timeout
...
stop logging errors if satellite is unavailable
drtio: don't even send message if link is down
2022-05-25 10:37:38 +08:00
mwojcik
48c9b43171
moninj: make it use async drtioaux
2022-05-25 10:37:38 +08:00
mwojcik
57d7f01b04
drtio: port 64-bit padding from mainline
2022-05-24 15:43:01 +08:00
mwojcik
efc432352e
zc706: no syncrtio for master, fixes hangs ( #188 )
2022-05-03 14:36:10 +08:00
mwojcik
def4d989cd
kasli_soc: fix si5324 pins routed to GTX
2022-04-25 12:33:21 +08:00
mwojcik
1d731a3589
zc706 master: route sma clock to si5324
2022-04-13 16:35:52 +08:00
mwojcik
3cf86a6335
satellites: add rtio_crg cfg
2022-04-12 13:44:53 +08:00
mwojcik
78bc162749
rtio_clocking: remove loop
2022-04-12 13:33:52 +08:00
mwojcik
14f7778732
update libconfig features
2022-04-08 10:30:21 +08:00
mwojcik
dcfb28ce61
fix drtioaux packet corruption
...
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2022-04-01 14:15:14 +08:00
mwojcik
433a9cdaf1
runtime: fix warnings on nondrtio systems
2022-03-29 10:05:11 +08:00
Sebastien Bourdeauducq
a79bef2243
runtime: provide/fix more libc mem functions
2022-03-28 13:24:01 +08:00
Sebastien Bourdeauducq
c6ef9b117c
fix previous commit
2022-03-26 20:08:11 +08:00
Sebastien Bourdeauducq
dcfaf587ec
firmware: add UnwrapNoneError exception
2022-03-26 15:29:40 +08:00
mwojcik
a92561b9d3
implement rtio_get_destination_status ( #177 )
...
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2022-03-25 18:20:05 +08:00
Sebastien Bourdeauducq
161044e78f
drop support for big-endian moninj
2022-03-19 23:01:36 +08:00
Sebastien Bourdeauducq
426500d2f9
firmware: support 64-bit moninj probes
2022-03-17 20:26:44 +08:00
Sebastien Bourdeauducq
ebdb08180d
drtio: demote default routing table message to info
2022-03-16 21:04:12 +08:00
Sebastien Bourdeauducq
0530e596ba
mgmt: remove spurious config write warning
2022-03-16 08:24:52 +08:00
Sebastien Bourdeauducq
7502f3a765
update dependencies
2022-03-10 17:25:40 +08:00
pca006132
ae0d724bf8
runtime: use &CSlice for lists
2022-03-10 16:30:34 +08:00
occheung
6c834899e9
si5324: fix clock source
2022-03-09 13:55:36 +08:00
occheung
a22b13cc46
kasli_soc: forward SMA clkin
2022-03-09 12:43:47 +08:00
spaqin
85e5c08d7f
kasli_soc: use si5324 in master
2022-03-04 13:17:53 +08:00
spaqin
3c17362fad
satman: fix i2cswitch
2022-03-03 17:18:22 +08:00
spaqin
4f2a0986da
rtio_clocking: fix wrong descriptions
2022-03-03 10:24:13 +08:00
spaqin
4a2218641f
fix BorrowMutError in moninj
2022-03-02 15:45:17 +08:00
mwojcik
9a06cd9d27
expose pca954x_select api ( #167 )
...
PR accompanying to ARTIQ's PCA954X support (#1860 ).
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2022-03-02 10:52:27 +08:00
Sebastien Bourdeauducq
b56b50b147
add comment about EXCEPTION_ID_LOOKUP sync
2022-03-01 09:50:28 +08:00
pca006132
f38117774f
runtime/eh_artiq: updated exception IDs
...
Fixes #166
2022-02-28 21:15:07 +08:00
Sebastien Bourdeauducq
880ba6b206
runtime: add nac3 exception symbols
2022-02-23 11:05:08 +08:00
mwojcik
accac99f48
updated zynq-rs with pca9547 support ( #165 )
...
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2022-02-11 13:53:58 +08:00
pca006132
6f5ba46e89
runtime/eh_artiq: support exception allocation
...
The backtrace is now nested, and should be used together with the stack
pointer array to construct the full backtrace for each exception.
We now allocate exception objects in a stack, but their names are still
not allocated. This is fine for exceptions raised in the driver or artiq
code, but we will have to implement allocation for names of exceptions
raised in RPC calls. The compiler should also emit code to store the
exception names once they catch it, to prepare for later reraising.
2022-01-23 21:31:22 +08:00
pca006132
8923feceac
runtime/eh_artiq: use forced unwind
...
This patches ports the LLVM libunwind newly added forced unwinding
function. This enables us to run forced unwinding to obtain correct
backtrace when uncaught exceptions occur.
This patch also changes the exception handling scheme from the standard
two-phase unwinding to single phase using forced unwinding. This brings
some performance improvement and prepared for later nested exception
support. For nested exceptions, we will have to record the backtrace
regardless if the exception is an uncaught exception, as there can be
another exception being thrown while executing the finally block for
caught exceptions, and we will lose the backtrace if we don't store it
earlier before running the cleanup pads.
2022-01-14 13:35:24 +08:00
pca006132
97ca72f7f1
libunwind: enable lto
2022-01-06 14:04:04 +08:00
pca006132
acaf388dbb
eh_artiq: handle catch clauses appropriately
2022-01-06 13:41:47 +08:00
pca006132
8788d6458e
runtime/rpc: fixes alignment and size problem
2022-01-04 18:25:53 +08:00
pca006132
efe315c21d
libdyld: accepts R_ARM_ABS32
...
Somehow this relocation type is emitted by nac3.
According to table 4-9 of ARM ELF ABI and discussion in ld bugzilla
(https://sourceware.org/bugzilla/show_bug.cgi?id=16163 ), this behaves
the same as R_ARM_GLOB_DAT and R_ARM_JUMP_SLOT.
2021-12-30 00:05:47 +08:00
stevefan1999
84becfe2c0
report async errors upon kernel termination
...
Port of 4a6bea479a
Co-authored-by: Steve Fan <sf@m-labs.hk>
Reviewed-on: M-Labs/artiq-zynq#156
Co-authored-by: stevefan1999 <sf@m-labs.hk>
Co-committed-by: stevefan1999 <sf@m-labs.hk>
2021-12-06 17:38:55 +08:00
mwojcik
31fb2b388a
Support for DRTIO 100MHz ( #155 )
...
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-12-03 17:19:42 +08:00
mwojcik
e045837b67
zc706: not actually ultrascale
2021-11-29 12:48:45 +08:00
mwojcik
ada3f2e704
drtio: reading still needs work buffer after all
2021-11-29 12:46:08 +08:00
mwojcik
8be5048cd3
upgrade to new clock configuration system ( #152 )
...
As mentioned in https://github.com/m-labs/artiq/issues/1735 - this is the Zynq version.
Reviewed-on: M-Labs/artiq-zynq#152
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-11-29 11:17:59 +08:00
mwojcik
e8db2a4b49
drtio: crc from mainline, removed byte swap
2021-11-24 12:12:40 +08:00
mwojcik
0b27349ec4
dummy_spi -> pmod_spi
2021-10-14 16:37:13 +08:00
mwojcik
21eb1cab1a
zc706: added dummy spi in place of sdio
2021-10-14 15:43:51 +08:00
mwojcik
3096daaaee
zc706: removed nist_clock sdcard, put pmod instead
2021-10-14 15:01:38 +08:00
mwojcik
4fbfccf575
zc706: fix nist_qc2 extension, ams101 iostandard
2021-10-14 12:39:09 +08:00
mwojcik
5c40115945
make ZC706 RTIO channels consistent with KC705
...
Reviewed-on: M-Labs/artiq-zynq#147
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-13 17:20:25 +08:00
Sebastien Bourdeauducq
a5e3580d18
Revert "runtime: expose rint from libm"
...
This reverts commit 3582af564d
.
2021-10-11 08:13:26 +08:00
Sebastien Bourdeauducq
3582af564d
runtime: expose rint from libm
2021-10-10 20:40:29 +08:00
mwojcik
219c075931
added explicit runtime/satman targets for makefile
...
Reviewed-on: M-Labs/artiq-zynq#144
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-08 21:06:23 +08:00
mwojcik
d04a7decfe
removed simple variants from zc706
2021-10-08 11:07:12 +02:00
mwojcik
0efa83e956
update build scripts for DRTIO
...
Reviewed-on: M-Labs/artiq-zynq#135
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-08 16:25:13 +08:00
Sebastien Bourdeauducq
4fa824f42b
kasli-soc: remove irrelevant comment
2021-10-08 16:13:17 +08:00
mwojcik
ab0c205dd2
gateware: add DRTIO
...
Reviewed-on: M-Labs/artiq-zynq#140
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-08 16:12:30 +08:00
mwojcik
8d2bb09149
add satman firmware ( #136 )
...
Reviewed-on: M-Labs/artiq-zynq#136
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-08 16:04:50 +08:00
mwojcik
aaec0abdf6
fix build/warnings before drtio is fully merged
2021-10-06 16:17:19 +08:00
mwojcik
e241957419
add libbuild_zynq
...
Reviewed-on: M-Labs/artiq-zynq#141
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-06 16:16:49 +08:00
mwojcik
50262b3f0c
runtime: link_thread -> link_task
2021-10-06 07:59:55 +02:00
mwojcik
827c6c1306
runtime: switch to libio/libboard_artiq, add DRTIO mastering support
...
Reviewed-on: M-Labs/artiq-zynq#137
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-06 13:05:45 +08:00
mwojcik
e6863263b4
add libboard_artiq (to be shared between runtime and satman)
...
Reviewed-on: M-Labs/artiq-zynq#139
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-06 13:02:28 +08:00
mwojcik
d7f45d473e
add libio (to be shared between runtime and satman)
...
Reviewed-on: M-Labs/artiq-zynq#138
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-10-06 13:01:52 +08:00
pca006132
35250b3f56
libdyld: fixed symbol relocation
...
Note that in libdyld/src/lib.rs #117-118, image pointer is already added
to the symbol offset, so we do not need to add the pointer again
2021-09-25 11:30:45 +08:00
Sebastien Bourdeauducq
2ed2ffe417
update dependencies
2021-08-09 15:16:54 +08:00
Sebastien Bourdeauducq
18e05c91e1
zc706: si5324 is not needed for standalone target
2021-08-04 09:14:19 +08:00
mwojcik
e3d3cb2311
si5324: bring on par with mainline ARTIQ ( #132 )
...
si5324 driver in runtime should be now equal in function to the one in artiq.
kasli-soc has no way of doing a hard reset on the peripheral, but zc706 does.
Reviewed-on: M-Labs/artiq-zynq#132
Co-authored-by: mwojcik <mw@m-labs.hk>
Co-committed-by: mwojcik <mw@m-labs.hk>
2021-08-04 09:12:38 +08:00
Sebastien Bourdeauducq
f543501012
si5324: remove debug print
2021-08-02 14:14:59 +08:00
Sebastien Bourdeauducq
111ac0c716
runtime: clock Si5324 from its crystal
2021-07-30 17:07:58 +08:00
Sebastien Bourdeauducq
8128dc0b56
Revert "kasli-soc: work around I2C breakage ( #130 )"
...
This reverts commit f1fd55dee5
.
2021-07-30 16:55:06 +08:00
Sebastien Bourdeauducq
dcb6129b0e
update dependencies
2021-07-05 13:56:40 +08:00
Sebastien Bourdeauducq
f25e261bdd
update dependencies
2021-06-25 17:12:47 +08:00
Sebastien Bourdeauducq
2ba4d8935d
fix compilation with nixpkgs 21.05
...
The environment variable is optional to keep compatibility with other build environments.
Closes #131
2021-06-25 15:57:39 +08:00
Sebastien Bourdeauducq
8c8a5d53b9
update dependencies
2021-06-19 22:51:25 +08:00
Sebastien Bourdeauducq
852123b42a
kasli-soc: add RTIO LEDs
2021-05-30 20:40:53 +08:00
Sebastien Bourdeauducq
f1fd55dee5
kasli-soc: work around I2C breakage ( #130 )
2021-05-29 17:13:41 +08:00
Sebastien Bourdeauducq
21d98711c1
use new smoltcp error code
2021-05-29 17:13:22 +08:00
Sebastien Bourdeauducq
0ae2138034
kasli-soc: preliminary si5324 support
2021-05-29 16:15:27 +08:00
Sebastien Bourdeauducq
1b474d2dd4
update dependencies
2021-05-29 14:20:23 +08:00
Sebastien Bourdeauducq
506c741238
support absence of gateware RTIO clock selection mux
2021-02-15 21:41:30 +08:00
Sebastien Bourdeauducq
8815f76114
kasli_soc: fix has_grabber
2021-02-15 21:41:02 +08:00
Sebastien Bourdeauducq
ef18fa4c6d
kasli_soc: add RTIO log channel
2021-02-15 19:56:59 +08:00
Sebastien Bourdeauducq
faf9714e10
add demo build for Kasli-SoC
2021-02-15 19:52:13 +08:00
Sebastien Bourdeauducq
8d4e42be32
remove redpitaya and coraz7 support
2021-02-15 19:30:13 +08:00
Astro
fcb38fae6c
runtime: disable TCP delayed ack
2021-02-08 03:24:18 +01:00
Astro
bfd8343876
update zynq-rs and dependencies (smoltcp 0.7.0)
2021-02-08 03:24:18 +01:00
Sebastien Bourdeauducq
4039431533
kasli_soc: fix eem iostandards
2021-02-07 22:34:29 +08:00
Sebastien Bourdeauducq
3f9bd06468
add Kasli-SoC generic gateware builder (WIP)
2021-02-07 14:44:32 +08:00
pca006132
bb65074254
updated zynq-rs and IRQ handling
2021-01-28 12:56:54 +08:00
pca006132
c2a6fb72f7
updated zynq-rs dependency
2021-01-26 12:38:09 +08:00
pca006132
faa335461d
runtime: modified protocols to use device endian
2021-01-22 13:36:38 +08:00
pca006132
be01fbd943
runtime/irq: use assembly for naked IRQ handler
...
and solves the bug introduced due to stack unwinding...
2021-01-18 17:08:04 +08:00
pca006132
9e8b554c6d
runtime/kernel/core1: use correct ABI
2021-01-18 16:43:30 +08:00
pca006132
b4ff6dda24
runtime: use naked function for IRQ
...
non-naked IRQ would somehow trigger interrupts after several kernel
restarts, investigating
2021-01-18 10:38:50 +08:00
pca006132
35204d4716
fixed new compiler warnings
2021-01-15 17:55:58 +08:00
pca006132
93493397ae
updated zynq-rs dependency
2021-01-15 17:55:47 +08:00
Astro
e5207b86db
update rust dependencies
2020-12-24 01:17:24 +01:00
Astro
28fe61b061
runtime: add feature target_kasli_soc
2020-12-23 20:11:43 +01:00
Astro
ce55e2ed23
update rust dependencies
2020-12-23 17:02:19 +01:00
Astro
cb9dae1951
update rust dependencies
2020-11-20 17:54:09 +01:00
Sebastien Bourdeauducq
07b425a67a
fix other compilation warnings
2020-11-16 14:57:20 +08:00
Sebastien Bourdeauducq
57ae8619f8
remove unnecessary no_mangle
...
no_mangle does nothing on extern items as per https://github.com/rust-lang/rust/issues/78989#issuecomment-726163973
Closes #115
2020-11-16 14:51:30 +08:00
Astro
32048ead20
gateware/coraz7: remove unused VARIANTS
2020-11-14 02:24:29 +01:00
Astro
113c8eb0b8
add coraz7 + redpitaya targets
2020-11-13 20:17:18 +01:00
Astro
9259cffeb2
i2c: add stubs for targets without i2c
2020-11-12 15:26:06 +01:00
David Nadlinger
7c336f7770
kernel/api: Add additional binary libm functions
...
Also factored out (f64, f64) -> f64 libm wrappers into
a macro, similar to the unary ones.
2020-11-11 01:24:44 +01:00
Sebastien Bourdeauducq
291a782db0
fix compiler warning
...
Feature is now stable.
2020-11-06 12:22:34 +08:00
Sebastien Bourdeauducq
479e6afd12
update Rust dependencies
2020-11-06 12:20:48 +08:00
pca006132
7dbffadf08
mgmt: implemented config write
2020-11-04 21:16:47 +08:00
Sebastien Bourdeauducq
b7155c9ded
Makefile: cleanup
2020-10-14 13:06:15 +08:00
Sebastien Bourdeauducq
5c62d6a141
update dependencies, disable custom compiler_builtins ( #113 )
2020-10-13 21:51:40 +08:00
Sebastien Bourdeauducq
eab839aed0
follow changes in zynq-rs
2020-10-13 19:12:55 +08:00
pca006132
a374d8a02f
runtime/kernel/dma: reduced replay overhead
...
We can just flush the cache once when we get the handle, instead of
everytime before replay.
2020-09-09 21:25:03 +08:00
pca006132
03d9827a5a
acpki: working
2020-09-09 21:24:49 +08:00
Sebastien Bourdeauducq
86b9045417
use liconfig, libcoreio, szl from zynq-rs
2020-09-09 18:44:12 +08:00
Sebastien Bourdeauducq
7e26a87aed
fix previous commit
2020-09-09 18:12:39 +08:00
Sebastien Bourdeauducq
a277e89b3a
Makefile: fix runtime.bin target
2020-09-09 17:01:14 +08:00
pca006132
1e742cc390
updated zynq-rs dependency
2020-09-07 16:18:50 +08:00
Sebastien Bourdeauducq
2fe73505c8
improve i2c error reporting
2020-09-06 00:38:28 +08:00
Sebastien Bourdeauducq
36d8ffec3b
expose i2c to kernels
2020-09-06 00:11:19 +08:00
Sebastien Bourdeauducq
91ed035bef
makefile: fix szl rebuild ( #108 )
2020-09-06 00:10:44 +08:00
pca006132
d5a91a7697
updated zynq-rs for more CPU options
2020-09-04 16:43:07 +08:00
pca006132
5da76f2abb
enabled cpu program flow prediction
2020-09-04 13:25:17 +08:00
pca006132
5e4bf8bbf7
runtime/comms: Faster RPC alloc
...
We do busy polling for some time before doing await, for small
allocations we could avoid the context switching and reduce the latency.
2020-09-03 16:58:44 +08:00
pca006132
cdc8ad8aee
runtime/kernel/control: fixed memory leak
2020-09-03 16:51:51 +08:00
pca006132
805f1d4eff
runtime: increased heap size
2020-09-02 10:15:52 +08:00
pca006132
ae07c05db4
runtime: optimize for speed and fix deadlock
...
The previous method of taking the channel could cause deadlock, we now
use semaphore to signal if the channel is available instead of busy
polling the mutex.
2020-09-02 10:15:52 +08:00
Sebastien Bourdeauducq
b0706f470d
runtime: set default log level to Info
2020-09-01 17:11:21 +08:00
pca006132
ccf8ae5b5d
szl: implemented #96
...
SZL no longer do self-extraction for runtime binary, it would boot from
SD/ethernet depending on the boot mode settings.
This allows a larger runtime binary, so we can optimize for speed in the
runtime firmware for better performance, and allow more features to be
added later.
2020-09-01 15:57:20 +08:00
pca006132
050b2457a4
runtime/main: removed bitstream loading code
2020-09-01 15:43:54 +08:00
pca006132
eb78e4e2da
libconfig: refactored load_pl into bootgen
...
Now allows loading firmware.
2020-09-01 14:48:19 +08:00
pca006132
afecc83ecf
libconfig/net_settings: made ipv6 optional feature
...
This is to prepare for szl, which cannot use ipv6 due to memory
limitation.
2020-09-01 14:48:19 +08:00
pca006132
04437e876c
libconfig/load_pl: added alignment for devc buffer
...
According to the TRM, the buffer should be 64B aligned.
Without the alignment would cause failure for the DMA transaction.
It seems that the allocator would give some alignment, but to be more
correct we should specify that with the alloc interface.
2020-09-01 14:48:19 +08:00
pca006132
42f94487cf
split config code into libconfig
2020-09-01 14:48:09 +08:00
pca006132
d474cf58a5
runtime/rpc: optimizations for list and arrays
...
Requires https://github.com/m-labs/artiq/pull/1510
This is the commit producing the result in the table.
2020-08-26 13:47:41 +08:00
pca006132
71427f8ec8
runtime/proto_async: simplify functions
...
And the compiler can use its intrinsic for byte rev.
2020-08-26 13:46:51 +08:00
Sebastien Bourdeauducq
538c012bc4
use new repos location for compiler-builtins-zynq
2020-08-25 16:24:30 +08:00
pca006132
ba162b3997
Fix pure build
2020-08-25 14:51:39 +08:00
pca006132
321a8e1522
runtime/kernel/core1: reset rtio after interrupted
2020-08-25 14:51:39 +08:00
pca006132
0fb278f7cb
runtime/kernel/core1: allows getting backtrace when kernel is not loaded
2020-08-25 14:51:39 +08:00
pca006132
fa187fb37a
runtime/kernel: use mutable static for shared channel
...
Mutex would prevent restart if we failed while waiting for RPC.
2020-08-25 14:51:39 +08:00
pca006132
e592efb2b8
enabled L2 cache and optimized ethernet
2020-08-25 14:51:39 +08:00
Astro
760f46a115
update dependencies
2020-08-17 19:17:42 +02:00
David Nadlinger
6ccd0cb389
runtime/kernel: Expose libm::atanh
2020-08-09 20:06:09 +01:00
David Nadlinger
63250240d2
runtime/kernel: Expose __powidf2
2020-08-09 19:17:38 +01:00
David Nadlinger
9f898dd2b8
runtime/rpc: Support new TArray layout (ndarrays)
...
This is a port of the respective commit in the main ARTIQ
repository.
2020-08-09 19:17:38 +01:00
pca006132
7342736124
szl: reduced binary size.
...
* Compiled unlzma with -Oz and enable LTO.
* Changed one unwrap to manual handling to remove fmt code.
* Implemented custom panic handler with minimal code.
2020-08-07 13:25:16 +08:00
Sebastien Bourdeauducq
3a8a025d5f
update dependencies, zc706 -> zynq-rs
2020-08-06 20:33:23 +08:00
Sebastien Bourdeauducq
2f6310f8bd
cleanup
2020-08-06 20:26:48 +08:00
Sebastien Bourdeauducq
8dabc8e6fd
runtime: remove access to obsolete i_overflow_reset CSR
2020-08-06 20:23:36 +08:00
Sebastien Bourdeauducq
1eeee43d64
acpki: implement input interface
2020-08-06 18:15:34 +08:00
pca006132
0354699ae3
runtime/kernel/dma: fixed missing end of buffer marker.
...
The DMA transfer would halt before.
2020-08-06 14:00:20 +08:00
Sebastien Bourdeauducq
7873565917
runtime: expose libm tan
2020-08-06 11:45:41 +08:00
pca006132
05e1614313
runtime/kernel: fixed duration bug.
...
Fixes #89 .
2020-08-06 11:12:24 +08:00
Sebastien Bourdeauducq
323191b9fc
runtime: expose more libm functions
2020-08-06 10:32:20 +08:00
Sebastien Bourdeauducq
2f7cc6fc38
tune compiler optimizations
2020-08-06 10:32:20 +08:00
pca006132
5becf0af0a
runtime/kernel: fixed memory corruption for cache and DMA.
2020-08-06 10:29:31 +08:00
pca006132
e7752a3d6d
runtime/kernel: fixes core0 memory leak.
...
Fixes #85
2020-08-06 09:39:49 +08:00
Sebastien Bourdeauducq
984bb08d27
Makefile: optimize
2020-08-05 19:14:18 +08:00
Sebastien Bourdeauducq
de2d7ecf48
typo
2020-08-05 18:52:08 +08:00
pca006132
c85e85aa6d
runtime/logger: use blocking wait.
...
Fixes #84 using the first solution.
If the performance is considered too slow,
we can do the second option later.
2020-08-05 18:51:27 +08:00
pca006132
4b6c5d5679
runtime/kernel: store DMA and cache buffer on core0.
...
Closes #77 .
2020-08-05 15:33:40 +08:00
Sebastien Bourdeauducq
72427dbebb
runtime: cleanup core_log
2020-08-05 00:40:54 +08:00
Sebastien Bourdeauducq
6d654de3d5
runtime: implement core_log
2020-08-04 23:27:51 +08:00
Sebastien Bourdeauducq
3092bfc21a
runtime: expose __aeabi_idivmod to kernel
2020-08-04 22:45:28 +08:00
Sebastien Bourdeauducq
b915176b29
runtime: implement acpki RTIO output
2020-08-04 17:32:43 +08:00
Sebastien Bourdeauducq
537f4968eb
acpki: add legacy i_status/o_status registers
2020-08-04 17:31:35 +08:00
Sebastien Bourdeauducq
62988a580e
acpki: update for combined RTIO channel/address
2020-08-04 17:28:15 +08:00
pca006132
fc21fcc920
runtime/comms: removed sync_channel hack.
...
Fixes #80
2020-08-04 14:40:02 +08:00
pca006132
6a4d871917
runtime/irq: use spinlock functions instead of asm.
...
Closes #81
2020-08-04 14:40:02 +08:00
Sebastien Bourdeauducq
8337c9173e
runtime: share rtio_log format function
2020-08-04 13:27:18 +08:00
Sebastien Bourdeauducq
1e20259c36
fix acpki selection
2020-08-04 13:26:45 +08:00
Sebastien Bourdeauducq
f8d4036451
add ACP kernel initiator
...
Based on work by Chris Ballance
https://github.com/m-labs/artiq/issues/1167#issuecomment-427188287
M-Labs/artiq-zynq#55
Work-in-progress, only gateware part and build system, untested.
2020-08-04 13:15:26 +08:00
Sebastien Bourdeauducq
c9bac028bf
dma: call rtio module to get time cursor position
...
More portable across RTIO implementations.
2020-08-04 13:14:00 +08:00
pca006132
56e7cc822c
runtime/comms: limited concurrent connections to 1 only.
2020-08-04 10:31:03 +08:00
pca006132
d58a3ef12c
runtime/comms: restart core1 before kernel load.
2020-08-04 10:17:19 +08:00
pca006132
fa00ab211d
Updated zc706 dependency and fixed compiler errors.
2020-08-04 10:15:57 +08:00
Sebastien Bourdeauducq
7caee2bf88
improve DMA logging
2020-07-30 22:25:49 +08:00
Sebastien Bourdeauducq
2e7090a359
remove unused import
2020-07-30 22:07:44 +08:00
Astro
b388b529ad
dyld: remove KERNEL_EXIDX_START/END globals, move dl_unwind_find_exidx() into runtime::kernel::core1
...
Gitea issue #16
2020-07-27 19:56:06 +02:00
Astro
641204425e
dyld: obtain EXIDX offsets from section headers
...
Gitea issue #16
2020-07-27 01:58:42 +02:00
Sebastien Bourdeauducq
7f983a453d
implement core device cache
2020-07-25 17:04:40 +08:00
Sebastien Bourdeauducq
630dcc274e
fix compilation warning with new rustc
2020-07-25 12:15:50 +08:00
Sebastien Bourdeauducq
e64f59723c
dma: use const initializer for manager
2020-07-25 12:12:56 +08:00
Sebastien Bourdeauducq
26874030fc
retry RTIO PLL lock
2020-07-25 11:15:33 +08:00
pca006132
0ce45b145e
kernel: proper type for static shared variables.
...
* Changed the KERNEL_CHANNEL_* to Mutex<T> with proper type, remove the
need for unsafe.
* Exposed a const pointer to KernelImage, with UnsafeCell holding
the library field for unbind with interior mutability.
2020-07-24 12:24:01 +08:00
pca006132
0310421085
RTIO DMA: Compiled but not working.
...
* Cache flush should be done before playback instead when getting the
handler.
* `csr::rtio_dma::enable_read()` would loop forever, probably bug in the
gateware.
2020-07-23 17:04:15 +08:00
pca006132
64dad88a32
Kernel exception: fixed top level finally. ( #70 )
...
Fixes #70 .
2020-07-23 14:09:15 +08:00
Astro
4846f2891b
use blocking timer api, update microseconds api
2020-07-22 23:58:55 +02:00
Astro
536f50f122
update dependencies
2020-07-22 23:51:09 +02:00
Sebastien Bourdeauducq
9b07468e50
add libm functions from legacy runtime
2020-07-21 22:58:56 +08:00
pca006132
d11e3fdad8
runtime/mgmt: mgmt.rs consistency
...
Closes #67 .
2020-07-21 13:54:32 +08:00
Sebastien Bourdeauducq
e0560a2db9
expose libm functions to kernel
2020-07-21 13:50:33 +08:00
Sebastien Bourdeauducq
59cf2764ce
dma: report AXI bus error
2020-07-21 12:47:20 +08:00
Sebastien Bourdeauducq
21135c6a41
analyzer: report AXI bus errors
2020-07-20 19:51:22 +08:00
Sebastien Bourdeauducq
9a8f8e2d7b
szl: add startup banner
2020-07-20 19:51:09 +08:00
Sebastien Bourdeauducq
0b47ac75f0
comms,mgmt: log connections as soon as they arrive
2020-07-20 19:09:56 +08:00
Sebastien Bourdeauducq
8c60947291
moninj: better connection logging
2020-07-20 19:07:44 +08:00
Sebastien Bourdeauducq
4af29e8eca
comms: report error on incorrect connection start pattern
2020-07-20 19:07:12 +08:00
Sebastien Bourdeauducq
d65e893d1c
more conservative RTIO PLL reset timing
2020-07-20 14:19:13 +08:00
Sebastien Bourdeauducq
db2a8e7726
implement RTIO log
2020-07-20 14:10:46 +08:00
Sebastien Bourdeauducq
f5db0e06f4
update dependencies, use new libasync smoltcp recv API
2020-07-19 16:16:39 +08:00
Sebastien Bourdeauducq
3ec9788eb1
proto_async: always consume one byte in recv
2020-07-19 16:07:55 +08:00
Sebastien Bourdeauducq
523524c319
zc706: add RTIO log channels
2020-07-19 14:05:35 +08:00
Sebastien Bourdeauducq
6e75741aa3
analyzer: remove debug print
2020-07-16 18:37:15 +08:00
Sebastien Bourdeauducq
f69e41af5e
gateware: fix VADJ I/O standard conflict
2020-07-16 17:58:31 +08:00
Sebastien Bourdeauducq
6a361893c2
gateware: make LEDs common to all variants
...
Makes quick testing easier.
2020-07-16 17:36:27 +08:00
Sebastien Bourdeauducq
ae7ca22db9
dma: fix endianness issues
2020-07-16 17:27:08 +08:00
pca006132
a9f725dd33
kernel: added error message after uncaught exception
2020-07-16 17:11:35 +08:00
pca006132
caef2a9f84
runtime/panic: prevent nested panic and added core ID in panic msg.
2020-07-16 17:11:35 +08:00
Sebastien Bourdeauducq
16158acfa9
analyzer: close connection gracefully
2020-07-16 17:10:24 +08:00
Sebastien Bourdeauducq
10a12245a3
analyzer: fix endianness issue
2020-07-16 17:10:09 +08:00
pca006132
84630d66e3
rpc: added `#[repr(C)]` for structs.
2020-07-16 15:48:17 +08:00
pca006132
4457af7277
rpc: Fixed alignment problem.
...
Fixes issue #42 .
Previously there was no fix for the variable alignment.
We calculate the position of the variable based on the size
of the previous variable, so we could break the alignment requirement
for variables. For example, having a `i64` after `bool` could break
the alignment required for `i64` and trigger DataAbort or data
corruption.
However, this requires the same data layout and LLVM type for the
variables. If this cannot be maintained, this would break the alignment
on the other side of the RPC, either from host to kernel or kernel to
host.
2020-07-16 14:06:39 +08:00
Sebastien Bourdeauducq
2e10922715
analyzer: implement firmware part
2020-07-16 11:47:55 +08:00
Sebastien Bourdeauducq
b62fbce826
mgmt: log incoming connection
2020-07-16 11:36:26 +08:00
Sebastien Bourdeauducq
0c6db0d12c
analyzer: use 32-bit byte_count
2020-07-16 11:36:04 +08:00
Sebastien Bourdeauducq
36338ea3b2
Makefile: fix pl.rs dependencies
2020-07-16 11:35:40 +08:00
Sebastien Bourdeauducq
0b0ca8de49
analyzer: drive wid and wstrb
2020-07-15 23:11:19 +08:00
Sebastien Bourdeauducq
8e758ecc17
add RTIO analyzer core (untested)
2020-07-15 23:06:34 +08:00
Sebastien Bourdeauducq
b68cb137e5
dma: style
2020-07-15 23:06:14 +08:00
pca006132
92405ffe91
logger: changed from RefCell to Mutex.
2020-07-15 17:04:16 +08:00
pca006132
2568d62865
mgmt: fixed pull log
2020-07-15 16:05:00 +08:00
pca006132
5149d37be9
szl: added cache flush and memory barriers.
...
Resolves #50 .
2020-07-14 17:02:42 +08:00
pca006132
8e3574080c
core1: added cache flush and barriers.
2020-07-14 10:53:35 +08:00
Astro
49d93e20dd
dyld: add Image.rebind()
2020-07-14 01:31:54 +02:00
Sebastien Bourdeauducq
12ba867268
dma: fix and cleanup test
2020-07-13 18:58:08 +08:00
Sebastien Bourdeauducq
5c3c3c26b5
dma: fix inflight_cnt and eop generation
2020-07-13 18:51:55 +08:00
Sebastien Bourdeauducq
fa2d71615a
report async RTIO errors
2020-07-13 16:06:05 +08:00
Sebastien Bourdeauducq
b42ab0634b
complete RTIO exceptions
2020-07-13 15:47:34 +08:00
pca006132
62f39e2c08
mgmt: Implemented network log access.
2020-07-13 15:15:06 +08:00
pca006132
855b26aa19
Logger: ported log_buffer.
2020-07-13 14:59:56 +08:00
Sebastien Bourdeauducq
ea96cf96d3
dma: add simulation test (WIP)
2020-07-13 12:04:10 +08:00
Sebastien Bourdeauducq
10888cc6c6
dma: remove unneeded import
2020-07-13 10:42:02 +08:00
Sebastien Bourdeauducq
a7073edf79
add DMA core (untested)
2020-07-13 10:37:17 +08:00
Sebastien Bourdeauducq
e3ff21b1b5
create gateware folder
2020-07-11 17:49:54 +08:00
pca006132
7aec419ed6
kernel: added core1 instruction cache flush
2020-07-10 17:21:55 +08:00
pca006132
68d27ca2ee
comms: removed core1 restart
2020-07-10 17:21:55 +08:00
Sebastien Bourdeauducq
407e18a6a0
fix typos
2020-07-10 16:36:45 +08:00
pca006132
2d58193930
Panic: single line backtrace for addr2line.
2020-07-10 12:26:28 +08:00
Sebastien Bourdeauducq
c935e450df
makefile: automate runtime dependencies
2020-07-09 09:41:45 +08:00
Sebastien Bourdeauducq
656e768f06
makefile: update dependencies
2020-07-09 09:31:36 +08:00
Astro
2c1773b91b
kernel: refactor main_core1 into KernelImage
2020-07-08 23:49:43 +02:00
Astro
b3d4590eec
kernel: split into {api,control,core1,rpc}
2020-07-08 23:49:32 +02:00
Sebastien Bourdeauducq
68045ce0c5
mark RTIO clock as asychronous to system clock
2020-07-08 20:37:53 +08:00
Sebastien Bourdeauducq
7ee67db8e3
use IOSERDES TTL
2020-07-08 20:02:46 +08:00