blob: d934cd64044ef0975fb059d6760597d5315a783b [file] [log] [blame]
/****************************************************************************
* arch/risc-v/src/mpfs/mpfs_mpu.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you 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 __ARCH_RISC_V_SRC_MPFS_MPFS_MPU_H
#define __ARCH_RISC_V_SRC_MPFS_MPFS_MPU_H
/****************************************************************************
* Included Files
****************************************************************************/
#include <stdint.h>
#include <stdbool.h>
/****************************************************************************
* Public Function Prototypes
****************************************************************************/
/****************************************************************************
* Name: mpfs_mpu_set
*
* Description:
* Set value to MPFS MPUCFG register.
*
* Input Parameters:
* reg - The MPUCFG register to write.
* perm - The region permissions.
* base - The base address of the region.
* size - The length of the region.
*
* Note:
* Only NAPOT encoded regions are supported, thus the base address and
* size must align with each other.
*
* Returned Value:
* 0 on success; negated error on failure.
*
****************************************************************************/
int mpfs_mpu_set(uintptr_t reg, uintptr_t perm, uintptr_t base,
uintptr_t size);
/****************************************************************************
* Name: mpfs_mpu_access_ok
*
* Description:
* Check if MPFS MPUCFG access is OK for register.
*
* Input Parameters:
* reg - The MPUCFG register to check.
* perm - The region permissions.
* base - The base address of the region.
* size - The length of the region.
*
* Returned Value:
* true if access OK; false if not.
*
****************************************************************************/
bool mpfs_mpu_access_ok(uintptr_t reg, uintptr_t perm, uintptr_t base,
uintptr_t size);
/****************************************************************************
* Name: mpfs_mpu_lock
*
* Description:
* Lock an MPUCFG register from further modifications.
*
* Input Parameters:
* reg - The MPUCFG register to lock.
*
* Returned Value:
* 0 on success; negated error on failure.
*
****************************************************************************/
int mpfs_mpu_lock(uintptr_t reg);
#endif /* __ARCH_RISC_V_SRC_MPFS_MPFS_MPU_H */