void hw_aes_hash_cfg_dma(const uint8 *src, uint8 *dst, unsigned int len) { /* Source address setting */ AES_HASH->CRYPTO_FETCH_ADDR_REG = DA15000_phy_addr((uint32)src); /* Destination address setting */ if (dst) { unsigned int remap_type = REG_GETF(CRG_TOP, SYS_CTRL_REG, REMAP_ADR0); if (IS_SYSRAM_ADDRESS(dst) || (IS_REMAPPED_ADDRESS(dst) && (remap_type == 0x3))) { AES_HASH->CRYPTO_DEST_ADDR_REG = DA15000_phy_addr((uint32)dst); #if dg_configEXEC_MODE != MODE_IS_CACHED } else if (IS_CACHERAM_ADDRESS(dst)) { AES_HASH->CRYPTO_DEST_ADDR_REG = DA15000_phy_addr((uint32)dst); #endif } else { /* * Destination address can only reside in RAM or Cache RAM, but in case of remapped * address, REMAP_ADR0 cannot be 0x6 (Cache Data RAM) */ ASSERT_ERROR(0); } } /* Data length setting */ AES_HASH->CRYPTO_LEN_REG = (uint32)len; }
void hw_aes_hash_cfg_dma(const uint8 *src, uint8 *dst, unsigned int len) { /* Source address setting */ AES_HASH->CRYPTO_FETCH_ADDR_REG = black_orca_phy_addr((uint32)src); /* Destination address setting */ if (dst) { unsigned int remap_type = REG_GETF(CRG_TOP, SYS_CTRL_REG, REMAP_ADR0); if (IS_SYSRAM_ADDRESS(dst) || (IS_REMAPPED_ADDRESS(dst) && (remap_type == 0x3))) { AES_HASH->CRYPTO_DEST_ADDR_REG = black_orca_phy_addr((uint32)dst); } else { /* Destination address can only reside in RAM */ ASSERT_ERROR(0); } } /* Data length setting */ AES_HASH->CRYPTO_LEN_REG = (uint32)len; }