blob: f1888150751b47db306e583b0034d7fa978481fd [file] [log] [blame]
// SPDX-License-Identifier: BSD-2-Clause
/*
* Copyright 2018-2019 NXP
*
* Brief CAAM Job Rings Hardware Abstration Layer.
* Implementation of primitives to access HW.
*/
#include <caam_common.h>
#include <caam_hal_jr.h>
#include <caam_io.h>
#include <caam_pwr.h>
#include <registers/ctrl_regs.h>
#include <registers/jr_regs.h>
/*
* List of JR configuration registers to save/restore
*/
static const struct reglist jrcfg_backup[] = {
BACKUP_REG(JR0DID_MS, 1, 0, 0),
BACKUP_REG(JR0DID_LS, 1, 0, 0),
};
enum caam_status caam_hal_jr_setowner(vaddr_t ctrl_base, paddr_t jr_offset,
enum caam_jr_owner owner)
{
enum caam_status retstatus = CAAM_FAILURE;
uint32_t val = 0;
uint32_t cfg_ms = 0;
uint32_t cfg_ls = 0;
unsigned int jr_idx = JRX_IDX(jr_offset);
/* Read the Job Ring Lock bit */
val = io_caam_read32(ctrl_base + JRxDID_MS(jr_idx));
HAL_TRACE("JR%" PRIu32 "DID_MS value 0x%" PRIx32, jr_idx, val);
/* Prepare the Job Ring MS/LS registers */
if (owner & JROWNER_SECURE) {
/* Configuration only locked for the Secure JR */
cfg_ms = JRxDID_MS_PRIM_DID(owner & ~JROWNER_SECURE);
cfg_ms |= JRxDID_MS_PRIM_TZ | JRxDID_MS_TZ_OWN;
cfg_ms |= JRxDID_MS_AMTD;
cfg_ms |= JRxDID_MS_PRIM_ICID(owner & ~JROWNER_SECURE);
#ifdef CFG_NXP_CAAM_RUNTIME_JR
cfg_ms |= JRxDID_MS_LDID;
cfg_ms |= JRxDID_MS_LAMTD;
#endif
} else {
cfg_ms = JRxDID_MS_PRIM_DID(owner);
cfg_ms |= JRxDID_MS_PRIM_ICID(owner);
}
if (val & JRxDID_MS_LDID) {
/*
* Configuration already locked, check it is the
* expected configuration.
*/
HAL_TRACE("JR%" PRIu32 "DID_MS value 0x%" PRIx32 " (0x%" PRIx32
")",
jr_idx, val, cfg_ms);
if ((cfg_ms | JRxDID_MS_LDID) == val) {
/* Read LS register and compare with expected value */
val = io_caam_read32(ctrl_base + JRxDID_LS(jr_idx));
HAL_TRACE("JR%" PRIu32 "DID_LS value 0x%" PRIx32
" (0x%" PRIx32 ")",
jr_idx, val, cfg_ls);
if (val == cfg_ls)
retstatus = CAAM_NO_ERROR;
}
} else {
HAL_TRACE("JR%" PRIu32 "DID_LS set value 0x%" PRIx32, jr_idx,
cfg_ls);
HAL_TRACE("JR%" PRIu32 "DID_MS set value 0x%" PRIx32, jr_idx,
cfg_ms);
/* Set the configuration */
io_caam_write32(ctrl_base + JRxDID_LS(jr_idx), cfg_ls);
io_caam_write32(ctrl_base + JRxDID_MS(jr_idx), cfg_ms);
retstatus = CAAM_NO_ERROR;
}
return retstatus;
}
void caam_hal_jr_prepare_backup(vaddr_t ctrl_base, paddr_t jr_offset)
{
unsigned int jr_idx = JRX_IDX(jr_offset);
caam_pwr_add_backup(ctrl_base + (jr_idx * JRxDID_SIZE), jrcfg_backup,
ARRAY_SIZE(jrcfg_backup));
}