/** * Copyright (C) ST-Ericsson SA 2010 * Author: Shujuan Chen for ST-Ericsson. * Author: Jonas Linde for ST-Ericsson. * Author: Joakim Bech for ST-Ericsson. * Author: Berne Hebark for ST-Ericsson. * Author: Niklas Hernaeus for ST-Ericsson. * License terms: GNU General Public License (GPL) version 2. */ #include #include #include #include "cryp.h" #include "cryp_p.h" #include "cryp_irq.h" #include "cryp_irqp.h" void cryp_enable_irq_src(struct cryp_device_data *device_data, u32 irq_src) { u32 i; dev_dbg(device_data->dev, "[%s]", __func__); i = readl_relaxed(&device_data->base->imsc); i = i | irq_src; writel_relaxed(i, &device_data->base->imsc); } void cryp_disable_irq_src(struct cryp_device_data *device_data, u32 irq_src) { u32 i; dev_dbg(device_data->dev, "[%s]", __func__); i = readl_relaxed(&device_data->base->imsc); i = i & ~irq_src; writel_relaxed(i, &device_data->base->imsc); } bool cryp_pending_irq_src(struct cryp_device_data *device_data, u32 irq_src) { return (readl_relaxed(&device_data->base->mis) & irq_src) > 0; }