Blame view

kernel/linux-rt-4.4.41/drivers/crypto/ux500/cryp/cryp_irq.c 1.24 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
  /**
   * Copyright (C) ST-Ericsson SA 2010
   * Author: Shujuan Chen <shujuan.chen@stericsson.com> for ST-Ericsson.
   * Author: Jonas Linde <jonas.linde@stericsson.com> for ST-Ericsson.
   * Author: Joakim Bech <joakim.xx.bech@stericsson.com> for ST-Ericsson.
   * Author: Berne Hebark <berne.herbark@stericsson.com> for ST-Ericsson.
   * Author: Niklas Hernaeus <niklas.hernaeus@stericsson.com> for ST-Ericsson.
   * License terms: GNU General Public License (GPL) version 2.
   */
  
  #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;
  }