blob: 45ef5de8b5fbe372aa57801f5b29db437fa72c98 [file] [log] [blame]
/*
* Copyright 2023 Google LLC
* Copyright lowRISC contributors
*
* 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.
*/
#ifndef MATCHA_SW_DEVICE_LIB_DIF_AUTOGEN_DIF_RV_PLIC_AUTOGEN_H_
#define MATCHA_SW_DEVICE_LIB_DIF_AUTOGEN_DIF_RV_PLIC_AUTOGEN_H_
// THIS FILE HAS BEEN GENERATED, DO NOT EDIT MANUALLY. COMMAND:
// util/make_new_dif.py --mode=regen --only=autogen
/**
* @file
* @brief <a href="/hw/ip/rv_plic/doc/">RV_PLIC</a> Device Interface Functions
*/
#include <stdbool.h>
#include <stdint.h>
#include "sw/device/lib/base/macros.h"
#include "sw/device/lib/base/mmio.h"
#include "sw/device/lib/dif/dif_base.h"
#ifdef __cplusplus
extern "C" {
#endif // __cplusplus
/**
* A handle to rv_plic.
*
* This type should be treated as opaque by users.
*/
typedef struct dif_rv_plic {
/**
* The base address for the rv_plic hardware registers.
*/
mmio_region_t base_addr;
} dif_rv_plic_t;
/**
* Creates a new handle for a(n) rv_plic peripheral.
*
* This function does not actuate the hardware.
*
* @param base_addr The MMIO base address of the rv_plic peripheral.
* @param[out] rv_plic Out param for the initialized handle.
* @return The result of the operation.
*/
OT_WARN_UNUSED_RESULT
dif_result_t dif_rv_plic_init(mmio_region_t base_addr, dif_rv_plic_t *rv_plic);
/**
* A rv_plic alert type.
*/
typedef enum dif_rv_plic_alert {
/**
* This fatal alert is triggered when a fatal TL-UL bus integrity fault is
* detected.
*/
kDifRvPlicAlertFatalFault = 0,
} dif_rv_plic_alert_t;
/**
* Forces a particular alert, causing it to be escalated as if the hardware
* had raised it.
*
* @param rv_plic A rv_plic handle.
* @param alert The alert to force.
* @return The result of the operation.
*/
OT_WARN_UNUSED_RESULT
dif_result_t dif_rv_plic_alert_force(const dif_rv_plic_t *rv_plic,
dif_rv_plic_alert_t alert);
#ifdef __cplusplus
} // extern "C"
#endif // __cplusplus
#endif // MATCHA_SW_DEVICE_LIB_DIF_AUTOGEN_DIF_RV_PLIC_AUTOGEN_H_