Blame view

drivers/gpu/drm/msm/mdp/mdp4/mdp4_irq.c 2.69 KB
c8afe684c   Rob Clark   drm/msm: basic KM...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
  /*
   * Copyright (C) 2013 Red Hat
   * Author: Rob Clark <robdclark@gmail.com>
   *
   * This program is free software; you can redistribute it and/or modify it
   * under the terms of the GNU General Public License version 2 as published by
   * the Free Software Foundation.
   *
   * This program is distributed in the hope that it will be useful, but WITHOUT
   * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
   * more details.
   *
   * You should have received a copy of the GNU General Public License along with
   * this program.  If not, see <http://www.gnu.org/licenses/>.
   */
  
  
  #include "msm_drv.h"
  #include "mdp4_kms.h"
9e0efa635   Rob Clark   drm/msm: move irq...
21
  void mdp4_set_irqmask(struct mdp_kms *mdp_kms, uint32_t irqmask)
c8afe684c   Rob Clark   drm/msm: basic KM...
22
  {
9e0efa635   Rob Clark   drm/msm: move irq...
23
  	mdp4_write(to_mdp4_kms(mdp_kms), REG_MDP4_INTR_ENABLE, irqmask);
c8afe684c   Rob Clark   drm/msm: basic KM...
24
  }
9e0efa635   Rob Clark   drm/msm: move irq...
25
  static void mdp4_irq_error_handler(struct mdp_irq *irq, uint32_t irqstatus)
c8afe684c   Rob Clark   drm/msm: basic KM...
26
27
28
29
30
31
32
  {
  	DRM_ERROR("errors: %08x
  ", irqstatus);
  }
  
  void mdp4_irq_preinstall(struct msm_kms *kms)
  {
9e0efa635   Rob Clark   drm/msm: move irq...
33
  	struct mdp4_kms *mdp4_kms = to_mdp4_kms(to_mdp_kms(kms));
aa80a4a51   Rob Clark   drm/msm: kexec fixes
34
  	mdp4_enable(mdp4_kms);
c8afe684c   Rob Clark   drm/msm: basic KM...
35
  	mdp4_write(mdp4_kms, REG_MDP4_INTR_CLEAR, 0xffffffff);
aa80a4a51   Rob Clark   drm/msm: kexec fixes
36
37
  	mdp4_write(mdp4_kms, REG_MDP4_INTR_ENABLE, 0x00000000);
  	mdp4_disable(mdp4_kms);
c8afe684c   Rob Clark   drm/msm: basic KM...
38
39
40
41
  }
  
  int mdp4_irq_postinstall(struct msm_kms *kms)
  {
9e0efa635   Rob Clark   drm/msm: move irq...
42
43
44
  	struct mdp_kms *mdp_kms = to_mdp_kms(kms);
  	struct mdp4_kms *mdp4_kms = to_mdp4_kms(mdp_kms);
  	struct mdp_irq *error_handler = &mdp4_kms->error_handler;
c8afe684c   Rob Clark   drm/msm: basic KM...
45
46
47
48
  
  	error_handler->irq = mdp4_irq_error_handler;
  	error_handler->irqmask = MDP4_IRQ_PRIMARY_INTF_UDERRUN |
  			MDP4_IRQ_EXTERNAL_INTF_UDERRUN;
9e0efa635   Rob Clark   drm/msm: move irq...
49
  	mdp_irq_register(mdp_kms, error_handler);
c8afe684c   Rob Clark   drm/msm: basic KM...
50
51
52
53
54
55
  
  	return 0;
  }
  
  void mdp4_irq_uninstall(struct msm_kms *kms)
  {
9e0efa635   Rob Clark   drm/msm: move irq...
56
  	struct mdp4_kms *mdp4_kms = to_mdp4_kms(to_mdp_kms(kms));
aa80a4a51   Rob Clark   drm/msm: kexec fixes
57
  	mdp4_enable(mdp4_kms);
c8afe684c   Rob Clark   drm/msm: basic KM...
58
  	mdp4_write(mdp4_kms, REG_MDP4_INTR_ENABLE, 0x00000000);
aa80a4a51   Rob Clark   drm/msm: kexec fixes
59
  	mdp4_disable(mdp4_kms);
c8afe684c   Rob Clark   drm/msm: basic KM...
60
61
62
63
  }
  
  irqreturn_t mdp4_irq(struct msm_kms *kms)
  {
9e0efa635   Rob Clark   drm/msm: move irq...
64
65
  	struct mdp_kms *mdp_kms = to_mdp_kms(kms);
  	struct mdp4_kms *mdp4_kms = to_mdp4_kms(mdp_kms);
c8afe684c   Rob Clark   drm/msm: basic KM...
66
67
  	struct drm_device *dev = mdp4_kms->dev;
  	struct msm_drm_private *priv = dev->dev_private;
c8afe684c   Rob Clark   drm/msm: basic KM...
68
69
70
71
72
73
74
  	unsigned int id;
  	uint32_t status;
  
  	status = mdp4_read(mdp4_kms, REG_MDP4_INTR_STATUS);
  	mdp4_write(mdp4_kms, REG_MDP4_INTR_CLEAR, status);
  
  	VERB("status=%08x", status);
7d8d9f670   Rob Clark   drm/msm/mdp4: cur...
75
  	mdp_dispatch_irqs(mdp_kms, status);
c8afe684c   Rob Clark   drm/msm: basic KM...
76
77
78
  	for (id = 0; id < priv->num_crtcs; id++)
  		if (status & mdp4_crtc_vblank(priv->crtcs[id]))
  			drm_handle_vblank(dev, id);
c8afe684c   Rob Clark   drm/msm: basic KM...
79
80
81
82
83
  	return IRQ_HANDLED;
  }
  
  int mdp4_enable_vblank(struct msm_kms *kms, struct drm_crtc *crtc)
  {
9e0efa635   Rob Clark   drm/msm: move irq...
84
85
  	mdp_update_vblank_mask(to_mdp_kms(kms),
  			mdp4_crtc_vblank(crtc), true);
c8afe684c   Rob Clark   drm/msm: basic KM...
86
87
88
89
90
  	return 0;
  }
  
  void mdp4_disable_vblank(struct msm_kms *kms, struct drm_crtc *crtc)
  {
9e0efa635   Rob Clark   drm/msm: move irq...
91
92
  	mdp_update_vblank_mask(to_mdp_kms(kms),
  			mdp4_crtc_vblank(crtc), false);
c8afe684c   Rob Clark   drm/msm: basic KM...
93
  }