1 // SPDX-License-Identifier: GPL-2.0-only
2 /**
3  * Copyright (C) ST-Ericsson SA 2010
4  * Author: Shujuan Chen <shujuan.chen@stericsson.com> for ST-Ericsson.
5  * Author: Jonas Linde <jonas.linde@stericsson.com> for ST-Ericsson.
6  * Author: Joakim Bech <joakim.xx.bech@stericsson.com> for ST-Ericsson.
7  * Author: Berne Hebark <berne.herbark@stericsson.com> for ST-Ericsson.
8  * Author: Niklas Hernaeus <niklas.hernaeus@stericsson.com> for ST-Ericsson.
9  */
10 
11 #include <linux/kernel.h>
12 #include <linux/bitmap.h>
13 #include <linux/device.h>
14 
15 #include "cryp.h"
16 #include "cryp_p.h"
17 #include "cryp_irq.h"
18 #include "cryp_irqp.h"
19 
cryp_enable_irq_src(struct cryp_device_data * device_data,u32 irq_src)20 void cryp_enable_irq_src(struct cryp_device_data *device_data, u32 irq_src)
21 {
22 	u32 i;
23 
24 	dev_dbg(device_data->dev, "[%s]", __func__);
25 
26 	i = readl_relaxed(&device_data->base->imsc);
27 	i = i | irq_src;
28 	writel_relaxed(i, &device_data->base->imsc);
29 }
30 
cryp_disable_irq_src(struct cryp_device_data * device_data,u32 irq_src)31 void cryp_disable_irq_src(struct cryp_device_data *device_data, u32 irq_src)
32 {
33 	u32 i;
34 
35 	dev_dbg(device_data->dev, "[%s]", __func__);
36 
37 	i = readl_relaxed(&device_data->base->imsc);
38 	i = i & ~irq_src;
39 	writel_relaxed(i, &device_data->base->imsc);
40 }
41 
cryp_pending_irq_src(struct cryp_device_data * device_data,u32 irq_src)42 bool cryp_pending_irq_src(struct cryp_device_data *device_data, u32 irq_src)
43 {
44 	return (readl_relaxed(&device_data->base->mis) & irq_src) > 0;
45 }
46