-
Notifications
You must be signed in to change notification settings - Fork 14
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fpga: Added omptarget device runtime (draft)
- Loading branch information
Showing
10 changed files
with
850 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
// Copyright 2021 ETH Zurich and University of Bologna. | ||
// Licensed under the Apache License, Version 2.0, see LICENSE for details. | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
|
||
// TODO(niwis) auto generate | ||
/dts-v1/; | ||
/plugin/; | ||
&{/dev@0,0} { | ||
axi-bus { | ||
#address-cells = <1>; | ||
#size-cells = <2>; | ||
compatible = "simple-bus"; | ||
ranges; | ||
// Create a reserved memory region for Snitch program memory | ||
reserved-memory { | ||
#address-cells = <2>; | ||
#size-cells = <2>; | ||
ranges; | ||
snitch_mem: buffer@c0000000 { | ||
reg = <0x0 0xc0000000 0x0 0x10000000>; | ||
}; | ||
}; | ||
cpus { | ||
#address-cells = <1>; | ||
#size-cells = <0>; | ||
timebase-frequency = <12500000>; | ||
CPU0: cpu@0 { | ||
device_type = "cpu"; | ||
status = "okay"; | ||
compatible = "eth,ariane", "riscv"; | ||
clock-frequency = <25000000>; | ||
riscv,isa = "rv64fimafd"; | ||
mmu-type = "riscv,sv39"; | ||
tlb-split; | ||
reg = <0>; | ||
// represents the destination of the mcause bits | ||
// ariane has 3 interrupt inputs: | ||
// - software (ipi_i[0], IRQ_M_SOFT) | ||
// - timer (time_irq_i[0], IRQ_M_TIMER) | ||
// - external (irq_i[1:0], {IRQ_S_EXT, IRQ_M_EXT}) | ||
CPU0_intc: interrupt-controller { | ||
#interrupt-cells = <1>; | ||
#address-cells = <1>; | ||
interrupt-controller; | ||
compatible = "riscv,cpu-intc"; | ||
}; | ||
}; | ||
}; | ||
sysclk: virt_25mhz { | ||
#clock-cells = <0>; | ||
compatible = "fixed-clock"; | ||
clock-frequency = <25000000>; | ||
}; | ||
soc: soc { | ||
#address-cells = <2>; | ||
#size-cells = <2>; | ||
compatible = "eth,occamy-soc", "simple-bus"; | ||
ranges; | ||
debug@0 { | ||
compatible = "riscv,debug-013"; | ||
// interrupts-extended = <&CPU0_intc 65535>; | ||
reg-names = "control"; | ||
reg = <0x0 0x0 0x0 0x1000>; | ||
}; | ||
serial@2002000 { | ||
compatible = "ns16550a"; | ||
reg = <0x0 0x2002000 0x0 0x1000>; | ||
clock-frequency = <25000000>; | ||
current-speed = <115200>; | ||
interrupt-parent = <&PLIC0>; | ||
interrupts = <36>; | ||
reg-offset = <0>; | ||
reg-shift = <2>; // regs are spaced on 32 bit boundary | ||
reg-io-width = <4>; // only 32-bit access are supported | ||
// fifo-size = <64>; | ||
}; | ||
timer@2006000 { | ||
compatible = "pulp,apb_timer"; | ||
interrupt-parent = <&PLIC0>; | ||
interrupts = <0x00000068 0x00000069 0x00000070 0x00000071>; | ||
reg = <0x00000000 0x2006000 0x00000000 0x00001000>; | ||
reg-names = "control"; | ||
}; | ||
clint0: clint@4000000 { | ||
clock-frequency = <12500000>; | ||
compatible = "riscv,clint0"; | ||
// clint generates software and timer interrupts to the core. Attach them | ||
// to the CPU | ||
// bits in mip and exception code in mcause: | ||
// - IRQ_M_SOFT = 3: Machine software interrupt | ||
// - IRQ_M_TIMER = 7: Machine timer interrupt | ||
interrupts-extended = <&CPU0_intc 3 &CPU0_intc 7>; | ||
reg-names = "clint"; | ||
reg = <0x0 0x4000000 0x0 0x100000>; | ||
}; | ||
PLIC0: interrupt-controller@c000000 { | ||
compatible = "riscv,plic0"; | ||
#address-cells = <0>; | ||
#interrupt-cells = <1>; | ||
interrupt-controller; | ||
// PLIC generates external interrupts to the core, M and S mode | ||
// - IRQ_M_EXT = 11: Machine external interrupt | ||
// - IRQ_S_EXT = 9: Supervisor external interrupt | ||
interrupts-extended = <&CPU0_intc 11 &CPU0_intc 9>; | ||
riscv,max-priority = <6>; | ||
riscv,ndev = <72>; | ||
reg = <0x0 0xc000000 0x0 0x4000000>; | ||
}; | ||
soc_ctl0: soc-control@2000000 { | ||
compatible = "eth,occamy-soc-control"; | ||
reg-names = "soc-control"; | ||
reg = <0x0 0x02000000 0x0 0x1000>; | ||
}; | ||
quadrant_ctrl0: quadrant-control@b000000 { | ||
compatible = "eth,occamy-quadrant-control"; | ||
reg-names = "quadrant-control"; | ||
reg = <0x0 0x0b000000 0x0 0x10000>; | ||
}; | ||
scratchpad-narrow@70000000 { | ||
compatible = "eth,scratchpad-narrow"; | ||
reg = <0x0 0x70000000 0x0 0x80000>; | ||
}; | ||
// Instantiate a snitch cluster | ||
snitch-cluster@10000000 { | ||
compatible = "eth,snitch-cluster"; | ||
// TCDM and Peripheral spaces | ||
reg = <0x0 0x10000000 0x0 0x40000>; | ||
// points to a memory region reserved for use by the cluster | ||
memory-region = <&snitch_mem>; | ||
// cluster specific properties | ||
eth,compute-cores = <8>; | ||
eth,dm-cores = <1>; | ||
eth,quadrant-idx = <0>; | ||
eth,cluster-idx = <0>; // Used to calculate offsets in clint, soc-ctrl etc.. | ||
// A handle to the soc-control register where isolates etc are located | ||
eth,soc-ctl = <&soc_ctl0>; | ||
// Handle to the associated quadrant controller | ||
eth,quadrant-ctrl = <&quadrant_ctrl0>; | ||
// handle to the clint where IPI interrupts are attached | ||
eth,clint = <&clint0>; | ||
}; | ||
}; | ||
}; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
// Copyright 2020 ETH Zurich and University of Bologna. | ||
// Licensed under the Apache License, Version 2.0, see LICENSE for details. | ||
// SPDX-License-Identifier: Apache-2.0 | ||
#pragma once | ||
|
||
#include <stdint.h> | ||
|
||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
extern uint32_t snrt_log_level; | ||
|
||
static inline void snrt_debug_set_loglevel(uint32_t lvl) { snrt_log_level = lvl; }; | ||
|
||
#define LOG_ERROR 0 | ||
#define LOG_WARN 1 | ||
#define LOG_INFO 2 | ||
#define LOG_DEBUG 3 | ||
#define LOG_TRACE 4 | ||
|
||
#if defined(DEBUG) | ||
|
||
#define snrt_error(fmt, ...) \ | ||
({ \ | ||
if (LOG_ERROR <= snrt_log_level) \ | ||
snrt_printf("[\033[31msnrt(%d,%d):error:%s\033[0m] " fmt, snrt_cluster_idx(), \ | ||
snrt_cluster_core_idx(), __func__, ##__VA_ARGS__); \ | ||
}) | ||
#define snrt_warn(fmt, ...) \ | ||
({ \ | ||
if (LOG_WARN <= snrt_log_level) \ | ||
snrt_printf("[\033[91msnrt(%d,%d):warn:%s\033[0m] " fmt, snrt_cluster_idx(), \ | ||
snrt_cluster_core_idx(), __func__, ##__VA_ARGS__); \ | ||
}) | ||
#define snrt_info(fmt, ...) \ | ||
({ \ | ||
if (LOG_INFO <= snrt_log_level) \ | ||
snrt_printf("[\033[33msnrt(%d,%d):info:%s\033[0m] " fmt, snrt_cluster_idx(), \ | ||
snrt_cluster_core_idx(), __func__, ##__VA_ARGS__); \ | ||
}) | ||
#define snrt_debug(fmt, ...) \ | ||
({ \ | ||
if (LOG_DEBUG <= snrt_log_level) \ | ||
snrt_printf("[\033[35msnrt(%d,%d):debug:%s\033[0m] " fmt, snrt_cluster_idx(), \ | ||
snrt_cluster_core_idx(), __func__, ##__VA_ARGS__); \ | ||
}) | ||
#define snrt_trace(fmt, ...) \ | ||
({ \ | ||
if (LOG_TRACE <= snrt_log_level) \ | ||
snrt_printf("[\033[96msnrt(%d,%d):trace:%s\033[0m] " fmt, snrt_cluster_idx(), \ | ||
snrt_cluster_core_idx(), __func__, ##__VA_ARGS__); \ | ||
}) | ||
|
||
#else // #if defined(DEBUG) | ||
|
||
#define snrt_error(x...) \ | ||
do { \ | ||
} while (0) | ||
#define snrt_warn(x...) \ | ||
do { \ | ||
} while (0) | ||
#define snrt_info(x...) \ | ||
do { \ | ||
} while (0) | ||
#define snrt_debug(x...) \ | ||
do { \ | ||
} while (0) | ||
#define snrt_trace(x...) \ | ||
do { \ | ||
} while (0) | ||
|
||
#endif // defined(SNRT_DEBUG) | ||
|
||
#ifdef __cplusplus | ||
} | ||
#endif |
Oops, something went wrong.