123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- // SPDX-License-Identifier: GPL-2.0-only
- /*
- * Copyright (C) ST-Ericsson SA 2010
- * Author: Shujuan Chen <[email protected]> for ST-Ericsson.
- * Author: Jonas Linde <[email protected]> for ST-Ericsson.
- * Author: Joakim Bech <[email protected]> for ST-Ericsson.
- * Author: Berne Hebark <[email protected]> for ST-Ericsson.
- * Author: Niklas Hernaeus <[email protected]> for ST-Ericsson.
- */
- #include <linux/kernel.h>
- #include <linux/bitmap.h>
- #include <linux/device.h>
- #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;
- }
|