From 37a80138686668c455fb07af475ee7abbb8b6fbb Mon Sep 17 00:00:00 2001 From: Francesco Conti Date: Tue, 26 Mar 2024 21:42:42 +0000 Subject: [PATCH] Add Astral option to N-EUREKA's BSP --- neureka/bsp/astral/neureka_astral_bsp.c | 101 ++++++++++++++++++++++++ neureka/bsp/astral/neureka_astral_bsp.h | 67 ++++++++++++++++ neureka/bsp/neureka_bsp.h | 8 +- 3 files changed, 175 insertions(+), 1 deletion(-) create mode 100644 neureka/bsp/astral/neureka_astral_bsp.c create mode 100644 neureka/bsp/astral/neureka_astral_bsp.h diff --git a/neureka/bsp/astral/neureka_astral_bsp.c b/neureka/bsp/astral/neureka_astral_bsp.c new file mode 100644 index 0000000..4668588 --- /dev/null +++ b/neureka/bsp/astral/neureka_astral_bsp.c @@ -0,0 +1,101 @@ +/* + * Luka Macan + * + * Copyright 2023 ETH Zurich and University of Bologna + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include "neureka_astral_bsp.h" +#include + +#define NEUREKA_ASTRAL_CLUSTER_CTRL_BASE_ADDR (0x50200000) +#define NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_OFFS 0x18 +#define NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR \ + (NEUREKA_ASTRAL_CLUSTER_CTRL_BASE_ADDR + \ + NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_OFFS) +#define NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_CG_EN 0x800 +#define NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_NEUREKA_SEL 0x2000 +#define NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_HCI_PRIO 0x100 +#define NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_HCI_MAXSTALL 0xff +#define NEUREKA_ASTRAL_MAX_STALL (8) +#define NEUREKA_ASTRAL_EVENT (1 << 12) +#define NEUREKA_ASTRAL_BASE_ADDR (0x50201000) + +void neureka_astral_cg_enable() { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR |= + NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_CG_EN; +} + +void neureka_astral_cg_disable() { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR &= + ~NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_CG_EN; +} + +void neureka_astral_neureka_select() { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR |= + NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_NEUREKA_SEL; +} + +void neureka_astral_neureka_unselect() { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR &= + ~NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_NEUREKA_SEL; +} + +void neureka_astral_hci_setpriority_neureka() { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR |= + NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_HCI_PRIO; +} + +void neureka_astral_hci_setpriority_core() { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR &= + ~NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_HCI_PRIO; +} + +void neureka_astral_hci_reset_max_stall() { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR &= + ~NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_HCI_MAXSTALL; +} + +void neureka_astral_hci_set_max_stall(uint32_t max_stall) { + *(volatile uint32_t *)NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_ADDR |= + max_stall & NEUREKA_ASTRAL_CLUSTER_CTRL_HWPE_MASK_HCI_MAXSTALL; +} + +void neureka_astral_open(neureka_astral_conf_t *conf) { + neureka_astral_cg_enable(); + neureka_astral_neureka_select(); + neureka_astral_hci_setpriority_neureka(); + neureka_astral_hci_set_max_stall(conf->max_stall); +} + +void neureka_astral_close() { + neureka_astral_cg_disable(); + neureka_astral_neureka_unselect(); + neureka_astral_hci_reset_max_stall(); + neureka_astral_hci_setpriority_core(); +} + +void neureka_astral_event_wait_and_clear() { + eu_evt_maskWaitAndClr(NEUREKA_ASTRAL_EVENT); +} + +static const neureka_dev_t neureka_astral_dev = { + .hwpe_dev = (struct hwpe_dev_t){ + .base_addr = (volatile uint32_t *)NEUREKA_ASTRAL_BASE_ADDR}}; + +const neureka_dev_t *neureka_astral_get_dev() { + return &neureka_astral_dev; +} diff --git a/neureka/bsp/astral/neureka_astral_bsp.h b/neureka/bsp/astral/neureka_astral_bsp.h new file mode 100644 index 0000000..193f619 --- /dev/null +++ b/neureka/bsp/astral/neureka_astral_bsp.h @@ -0,0 +1,67 @@ +/* + * Luka Macan + * + * Copyright 2023 ETH Zurich and University of Bologna + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#ifndef __NEUREKA_ASTRAL_BSP_H__ +#define __NEUREKA_ASTRAL_BSP_H__ + +#include "neureka.h" +#include + +/** + * neureka_astral_setpriority_neureka + * + * Set HCI interconnect bus priority to prioritize neureka. + */ +void neureka_astral_hci_setpriority_neureka(); + +/** + * neureka_astral_setpriority_core + * + * Set HCI bus priority to prioritize cores. + */ +void neureka_astral_hci_setpriority_core(); + +/** + * neureka_astral_hci_reset_maxstall + * + * Reset the HCI bus maxstall parameter. + * TODO: Check if it disables it also or just resets? + */ +void neureka_astral_hci_reset_max_stall(); + +/** + * neureka_astral_hci_set_maxstall + * + * Set the HCI bus maxstall. Maxstall defines how many cycles + * will the HCI bus stall the lower priority master, i.e. neureka or core, + * before letting it do a transaction. + */ +void neureka_astral_hci_set_max_stall(uint32_t max_stall); + +typedef struct neureka_astral_conf_t { + int max_stall; +} neureka_astral_conf_t; + +void neureka_astral_open(neureka_astral_conf_t *conf); +void neureka_astral_close(); +void neureka_astral_event_wait_and_clear(); +const neureka_dev_t *neureka_astral_get_dev(); + +#endif // !__NEUREKA_ASTRAL_BSP_H__ diff --git a/neureka/bsp/neureka_bsp.h b/neureka/bsp/neureka_bsp.h index 41df5c7..d3c3f17 100644 --- a/neureka/bsp/neureka_bsp.h +++ b/neureka/bsp/neureka_bsp.h @@ -4,10 +4,16 @@ #define neureka_bsp_open neureka_testbench_open #define neureka_bsp_close neureka_testbench_close #define neureka_bsp_event_wait_and_clear neureka_testbench_event_wait_and_clear +#elif NNX_NEUREKA_ASTRAL + #include "neureka_astral_bsp.h" + #define neureka_bsp_conf_t neureka_astral_conf_t + #define neureka_bsp_open neureka_astral_open + #define neureka_bsp_close neureka_astral_close + #define neureka_bsp_event_wait_and_clear neureka_astral_event_wait_and_clear #else #include "neureka_siracusa_bsp.h" #define neureka_bsp_conf_t neureka_siracusa_conf_t #define neureka_bsp_open neureka_siracusa_open #define neureka_bsp_close neureka_siracusa_close #define neureka_bsp_event_wait_and_clear neureka_siracusa_event_wait_and_clear -#endif \ No newline at end of file +#endif