Home
last modified time | relevance | path

Searched refs:vblank (Results 1 – 25 of 82) sorted by relevance

1234

/drivers/gpu/drm/
Ddrm_vblank.c101 struct drm_vblank_crtc *vblank = &dev->vblank[pipe]; in store_vblank() local
105 vblank->last = last; in store_vblank()
107 write_seqlock(&vblank->seqlock); in store_vblank()
108 vblank->time = t_vblank; in store_vblank()
109 vblank->count += vblank_count_inc; in store_vblank()
110 write_sequnlock(&vblank->seqlock); in store_vblank()
115 struct drm_vblank_crtc *vblank = &dev->vblank[pipe]; in drm_max_vblank_count() local
117 return vblank->max_vblank_count ?: dev->max_vblank_count; in drm_max_vblank_count()
207 struct drm_vblank_crtc *vblank = &dev->vblank[pipe]; in drm_update_vblank_count() local
212 int framedur_ns = vblank->framedur_ns; in drm_update_vblank_count()
[all …]
Ddrm_irq.c191 struct drm_vblank_crtc *vblank = &dev->vblank[i]; in drm_irq_uninstall() local
193 if (!vblank->enabled) in drm_irq_uninstall()
199 wake_up(&vblank->queue); in drm_irq_uninstall()
/drivers/gpu/drm/nouveau/nvkm/engine/sw/
Dnv50.c42 container_of(notify, typeof(*chan), vblank.notify[notify->index]); in nv50_sw_chan_vblsem_release()
47 nvkm_wr32(device, 0x001710, 0x80000000 | chan->vblank.ctxdma); in nv50_sw_chan_vblsem_release()
51 nvkm_wr32(device, 0x001570, chan->vblank.offset); in nv50_sw_chan_vblsem_release()
52 nvkm_wr32(device, 0x001574, chan->vblank.value); in nv50_sw_chan_vblsem_release()
54 nvkm_wr32(device, 0x060010, chan->vblank.offset); in nv50_sw_chan_vblsem_release()
55 nvkm_wr32(device, 0x060014, chan->vblank.value); in nv50_sw_chan_vblsem_release()
68 case 0x018c: chan->vblank.ctxdma = data; return true; in nv50_sw_chan_mthd()
69 case 0x0400: chan->vblank.offset = data; return true; in nv50_sw_chan_mthd()
70 case 0x0404: chan->vblank.value = data; return true; in nv50_sw_chan_mthd()
72 if (data < device->disp->vblank.index_nr) { in nv50_sw_chan_mthd()
[all …]
Dgf100.c42 container_of(notify, typeof(*chan), vblank.notify[notify->index]); in gf100_sw_chan_vblsem_release()
49 nvkm_wr32(device, 0x06000c, upper_32_bits(chan->vblank.offset)); in gf100_sw_chan_vblsem_release()
50 nvkm_wr32(device, 0x060010, lower_32_bits(chan->vblank.offset)); in gf100_sw_chan_vblsem_release()
51 nvkm_wr32(device, 0x060014, chan->vblank.value); in gf100_sw_chan_vblsem_release()
64 chan->vblank.offset &= 0x00ffffffffULL; in gf100_sw_chan_mthd()
65 chan->vblank.offset |= (u64)data << 32; in gf100_sw_chan_mthd()
68 chan->vblank.offset &= 0xff00000000ULL; in gf100_sw_chan_mthd()
69 chan->vblank.offset |= data; in gf100_sw_chan_mthd()
72 chan->vblank.value = data; in gf100_sw_chan_mthd()
75 if (data < device->disp->vblank.index_nr) { in gf100_sw_chan_mthd()
[all …]
Dnv50.h17 } vblank; member
/drivers/media/platform/vivid/
Dvivid-osd.c74 struct fb_vblank vblank; in vivid_fb_ioctl() local
76 memset(&vblank, 0, sizeof(vblank)); in vivid_fb_ioctl()
77 vblank.flags = FB_VBLANK_HAVE_COUNT | FB_VBLANK_HAVE_VCOUNT | in vivid_fb_ioctl()
79 vblank.count = 0; in vivid_fb_ioctl()
80 vblank.vcount = 0; in vivid_fb_ioctl()
81 vblank.hcount = 0; in vivid_fb_ioctl()
82 if (copy_to_user((void __user *)arg, &vblank, sizeof(vblank))) in vivid_fb_ioctl()
/drivers/gpu/drm/vkms/
Dvkms_crtc.c60 struct drm_vblank_crtc *vblank = &dev->vblank[pipe]; in vkms_enable_vblank() local
67 out->period_ns = ktime_set(0, vblank->framedur_ns); in vkms_enable_vblank()
86 struct drm_vblank_crtc *vblank = &dev->vblank[pipe]; in vkms_get_vblank_timestamp() local
90 if (WARN_ON(*vblank_time == vblank->time)) in vkms_get_vblank_timestamp()
/drivers/video/fbdev/matrox/
Dmatroxfb_crtc2.c403 …ic int matroxfb_dh_get_vblank(const struct matroxfb_dh_fb_info* m2info, struct fb_vblank* vblank) { in matroxfb_dh_get_vblank() argument
407 memset(vblank, 0, sizeof(*vblank)); in matroxfb_dh_get_vblank()
408 vblank->flags = FB_VBLANK_HAVE_VCOUNT | FB_VBLANK_HAVE_VBLANK; in matroxfb_dh_get_vblank()
410 vblank->vcount = mga_inl(0x3C48) & 0x000007FF; in matroxfb_dh_get_vblank()
412 if (vblank->vcount >= m2info->fbcon.var.yres) in matroxfb_dh_get_vblank()
413 vblank->flags |= FB_VBLANK_VBLANKING; in matroxfb_dh_get_vblank()
415 vblank->flags |= FB_VBLANK_HAVE_COUNT; in matroxfb_dh_get_vblank()
418 vblank->count = minfo->crtc2.vsync.cnt; in matroxfb_dh_get_vblank()
435 struct fb_vblank vblank; in matroxfb_dh_ioctl() local
438 err = matroxfb_dh_get_vblank(m2info, &vblank); in matroxfb_dh_ioctl()
[all …]
Dmatroxfb_base.c842 struct fb_vblank *vblank) in matroxfb_get_vblank() argument
847 memset(vblank, 0, sizeof(*vblank)); in matroxfb_get_vblank()
848 vblank->flags = FB_VBLANK_HAVE_VCOUNT | FB_VBLANK_HAVE_VSYNC | in matroxfb_get_vblank()
851 vblank->vcount = mga_inl(M_VCOUNT); in matroxfb_get_vblank()
856 vblank->flags |= FB_VBLANK_HBLANKING; in matroxfb_get_vblank()
858 vblank->flags |= FB_VBLANK_VSYNCING; in matroxfb_get_vblank()
859 if (vblank->vcount >= minfo->fbcon.var.yres) in matroxfb_get_vblank()
860 vblank->flags |= FB_VBLANK_VBLANKING; in matroxfb_get_vblank()
862 vblank->flags |= FB_VBLANK_HAVE_COUNT; in matroxfb_get_vblank()
865 vblank->count = minfo->crtc1.vsync.cnt; in matroxfb_get_vblank()
[all …]
/drivers/gpu/drm/nouveau/nvkm/engine/disp/
Dbase.c45 struct nvkm_disp *disp = container_of(event, typeof(*disp), vblank); in nvkm_disp_vblank_fini()
54 struct nvkm_disp *disp = container_of(event, typeof(*disp), vblank); in nvkm_disp_vblank_init()
65 container_of(notify->event, typeof(*disp), vblank); in nvkm_disp_vblank_ctor()
73 if (ret = -ENXIO, req->v0.head <= disp->vblank.index_nr) { in nvkm_disp_vblank_ctor()
94 nvkm_event_send(&disp->vblank, 1, head, &rep, sizeof(rep)); in nvkm_disp_vblank()
137 *event = &disp->vblank; in nvkm_disp_ntfy()
420 return nvkm_event_init(&nvkm_disp_vblank_func, 1, i, &disp->vblank); in nvkm_disp_oneinit()
434 nvkm_event_fini(&disp->vblank); in nvkm_disp_dtor()
/drivers/gpu/drm/gma500/
Dpsb_irq.c314 if (dev->vblank[0].enabled) in psb_irq_preinstall()
316 if (dev->vblank[1].enabled) in psb_irq_preinstall()
352 if (dev->vblank[0].enabled) in psb_irq_postinstall()
357 if (dev->vblank[1].enabled) in psb_irq_postinstall()
362 if (dev->vblank[2].enabled) in psb_irq_postinstall()
386 if (dev->vblank[0].enabled) in psb_irq_uninstall()
389 if (dev->vblank[1].enabled) in psb_irq_uninstall()
392 if (dev->vblank[2].enabled) in psb_irq_uninstall()
Dmdfld_device.c194 pipe->vblank = PSB_RVDC32(map->vblank); in mdfld_save_display_registers()
320 PSB_WVDC32(pipe->vblank, map->vblank); in mdfld_restore_display_registers()
449 .vblank = VBLANK_A,
471 .vblank = VBLANK_B,
494 .vblank = VBLANK_C,
Doaktrail_device.c207 p->vblank = PSB_RVDC32(VBLANK_A); in oaktrail_save_display_registers()
327 PSB_WVDC32(p->vblank, VBLANK_A); in oaktrail_restore_display_registers()
465 .vblank = VBLANK_A,
489 .vblank = VBLANK_B,
/drivers/gpu/drm/msm/disp/mdp4/
Dmdp4_crtc.c56 struct mdp_irq vblank; member
72 mdp_irq_register(&get_kms(crtc)->base, &mdp4_crtc->vblank); in request_pending()
497 struct mdp4_crtc *mdp4_crtc = container_of(irq, struct mdp4_crtc, vblank); in mdp4_crtc_vblank_irq()
502 mdp_irq_unregister(&get_kms(crtc)->base, &mdp4_crtc->vblank); in mdp4_crtc_vblank_irq()
535 ret = wait_event_timeout(dev->vblank[drm_crtc_index(crtc)].queue, in mdp4_crtc_wait_for_flush_done()
550 return mdp4_crtc->vblank.irqmask; in mdp4_crtc_vblank()
635 mdp4_crtc->vblank.irqmask = dma2irq(mdp4_crtc->dma); in mdp4_crtc_init()
636 mdp4_crtc->vblank.irq = mdp4_crtc_vblank_irq; in mdp4_crtc_init()
/drivers/gpu/drm/nouveau/
Dnouveau_display.c51 container_of(notify, typeof(*nv_crtc), vblank); in nouveau_display_vblank_handler()
67 nvif_notify_get(&nv_crtc->vblank); in nouveau_display_vblank_enable()
83 nvif_notify_put(&nv_crtc->vblank); in nouveau_display_vblank_disable()
112 struct drm_vblank_crtc *vblank = &crtc->dev->vblank[drm_crtc_index(crtc)]; in nouveau_display_scanoutpos_head() local
126 if (retry) ndelay(vblank->linedur_ns); in nouveau_display_scanoutpos_head()
163 nvif_notify_fini(&nv_crtc->vblank); in nouveau_display_vblank_fini()
184 &nv_crtc->vblank); in nouveau_display_vblank_init()
/drivers/video/fbdev/core/
Dfbmon.c1022 u32 vblank; member
1044 u32 vblank; in fb_get_vblank() local
1046 vblank = (hfreq * FLYBACK)/1000; in fb_get_vblank()
1047 vblank = (vblank + 500)/1000; in fb_get_vblank()
1048 return (vblank + V_FRONTPORCH); in fb_get_vblank()
1151 timings->vblank = fb_get_vblank(timings->hfreq); in fb_timings_vfreq()
1152 timings->vtotal = timings->vactive + timings->vblank; in fb_timings_vfreq()
1161 timings->vblank = fb_get_vblank(timings->hfreq); in fb_timings_hfreq()
1162 timings->vtotal = timings->vactive + timings->vblank; in fb_timings_hfreq()
1176 timings->vblank = fb_get_vblank(timings->hfreq); in fb_timings_dclk()
[all …]
/drivers/media/i2c/
Dmt9v011.c204 unsigned height, width, hblank, vblank, speed; in calc_fps() local
212 vblank = mt9v011_read(sd, R06_MT9V011_VBLANK); in calc_fps()
216 t_time = row_time * (height + vblank + 1); in calc_fps()
234 unsigned height, width, hblank, vblank; in calc_speed() local
245 vblank = mt9v011_read(sd, R06_MT9V011_VBLANK); in calc_speed()
248 line_time = height + vblank + 1; in calc_speed()
Dmt9m032.c185 unsigned int vblank; in mt9m032_update_timing() local
193 vblank = div_u64(1000000000ULL * interval->numerator, in mt9m032_update_timing()
197 if (vblank > MT9M032_VBLANK_MAX) { in mt9m032_update_timing()
204 vblank = div_u64(1000000000ULL * interval->numerator, in mt9m032_update_timing()
210 vblank = clamp_t(unsigned int, vblank, min_vblank, MT9M032_VBLANK_MAX); in mt9m032_update_timing()
212 return mt9m032_write(client, MT9M032_VBLANK, vblank); in mt9m032_update_timing()
Dimx258.c598 struct v4l2_ctrl *vblank; member
896 imx258->vblank, vblank_min, in imx258_set_pad_format()
899 __v4l2_ctrl_s_ctrl(imx258->vblank, vblank_def); in imx258_set_pad_format()
1135 imx258->vblank = v4l2_ctrl_new_std( in imx258_init_controls()
1141 if (imx258->vblank) in imx258_init_controls()
1142 imx258->vblank->flags |= V4L2_CTRL_FLAG_READ_ONLY; in imx258_init_controls()
/drivers/video/fbdev/
Dtmiofb.c483 static int tmiofb_vblank(struct fb_info *fbi, struct fb_vblank *vblank) in tmiofb_vblank() argument
490 vblank->vcount = vcount; in tmiofb_vblank()
491 vblank->flags = FB_VBLANK_HAVE_VBLANK | FB_VBLANK_HAVE_VCOUNT in tmiofb_vblank()
495 vblank->flags |= FB_VBLANK_VSYNCING; in tmiofb_vblank()
498 vblank->flags |= FB_VBLANK_VBLANKING; in tmiofb_vblank()
509 struct fb_vblank vblank = {0}; in tmiofb_ioctl() local
512 tmiofb_vblank(fbi, &vblank); in tmiofb_ioctl()
513 if (copy_to_user(argp, &vblank, sizeof vblank)) in tmiofb_ioctl()
Dps3fb.c747 static int ps3fb_get_vblank(struct fb_vblank *vblank) in ps3fb_get_vblank() argument
749 memset(vblank, 0, sizeof(*vblank)); in ps3fb_get_vblank()
750 vblank->flags = FB_VBLANK_HAVE_VSYNC; in ps3fb_get_vblank()
784 struct fb_vblank vblank; in ps3fb_ioctl() local
786 retval = ps3fb_get_vblank(&vblank); in ps3fb_ioctl()
790 if (copy_to_user(argp, &vblank, sizeof(vblank))) in ps3fb_ioctl()
/drivers/gpu/drm/amd/amdgpu/
Damdgpu_encoders.c154 unsigned vblank = native_mode->vtotal - native_mode->vdisplay; in amdgpu_panel_mode_fixup() local
170 adjusted_mode->vtotal = native_mode->vdisplay + vblank; in amdgpu_panel_mode_fixup()
183 adjusted_mode->crtc_vtotal = adjusted_mode->crtc_vdisplay + vblank; in amdgpu_panel_mode_fixup()
/drivers/media/pci/ivtv/
Divtvfb.c452 struct fb_vblank vblank; in ivtvfb_ioctl() local
455 memset(&vblank, 0, sizeof(struct fb_vblank)); in ivtvfb_ioctl()
457 vblank.flags = FB_VBLANK_HAVE_COUNT |FB_VBLANK_HAVE_VCOUNT | in ivtvfb_ioctl()
465 vblank.flags |= FB_VBLANK_VSYNCING; in ivtvfb_ioctl()
466 vblank.count = itv->last_vsync_field; in ivtvfb_ioctl()
467 vblank.vcount = trace; in ivtvfb_ioctl()
468 vblank.hcount = 0; in ivtvfb_ioctl()
469 if (copy_to_user((void __user *)arg, &vblank, sizeof(vblank))) in ivtvfb_ioctl()
/drivers/gpu/drm/i915/
DKconfig.debug192 bool "Enable extra debug warnings for vblank evasion"
197 vblank evade mechanism. This gives a warning every time the
198 the deadline allotted for the vblank evade critical section
200 the vblank.
/drivers/gpu/drm/msm/disp/mdp5/
Dmdp5_crtc.c44 struct mdp_irq vblank; member
78 mdp_irq_register(&get_kms(crtc)->base, &mdp5_crtc->vblank); in request_pending()
743 mdp5_crtc->vblank.irqmask = mdp5_cstate->vblank_irqmask; in mdp5_crtc_atomic_flush()
1073 struct mdp5_crtc *mdp5_crtc = container_of(irq, struct mdp5_crtc, vblank); in mdp5_crtc_vblank_irq()
1078 mdp_irq_unregister(&get_kms(crtc)->base, &mdp5_crtc->vblank); in mdp5_crtc_vblank_irq()
1135 ret = wait_event_timeout(dev->vblank[drm_crtc_index(crtc)].queue, in mdp5_crtc_wait_for_flush_done()
1150 return mdp5_crtc->vblank.irqmask; in mdp5_crtc_vblank()
1226 mdp5_crtc->vblank.irq = mdp5_crtc_vblank_irq; in mdp5_crtc_init()

1234