Lines Matching defs:ps3fb

2  *  linux/drivers/video/ps3fb.c -- PS3 GPU frame buffer device
38 #include <asm/ps3fb.h>
43 #define DEVICE_NAME "ps3fb"
121 static struct ps3fb_priv ps3fb;
456 status = lv1_gpu_fb_blit(ps3fb.context_handle, dst_offset,
467 status = lv1_gpu_display_flip(ps3fb.context_handle, 0, frame_offset);
473 status = lv1_gpu_display_flip(ps3fb.context_handle, 1, frame_offset);
507 atomic_inc(&ps3fb.f_count);
513 if (atomic_dec_and_test(&ps3fb.f_count)) {
514 if (atomic_read(&ps3fb.ext_flip)) {
515 atomic_set(&ps3fb.ext_flip, 0);
713 dev_dbg(info->device, "ps3fb: mmap framebuffer P(%lx)->V(%lx)\n",
736 ps3fb.is_blanked = 1;
742 ps3fb.is_blanked = 0;
760 count = ps3fb.vblank_count;
761 ret = wait_event_interruptible_timeout(ps3fb.wait_vsync,
762 count != ps3fb.vblank_count,
863 atomic_inc(&ps3fb.ext_flip);
869 atomic_dec_if_positive(&ps3fb.ext_flip);
898 if (ps3fb.is_kicked) {
899 ps3fb.is_kicked = 0;
914 struct display_head *head = &ps3fb.dinfo->display_head[1];
916 status = lv1_gpu_context_intr(ps3fb.context_handle, &v1);
925 ps3fb.vblank_count = head->vblank_count;
926 if (ps3fb.task && !ps3fb.is_blanked &&
927 !atomic_read(&ps3fb.ext_flip)) {
928 ps3fb.is_kicked = 1;
929 wake_up_process(ps3fb.task);
931 wake_up_interruptible(&ps3fb.wait_vsync);
997 atomic_set(&ps3fb.f_count, -1); /* fbcon opens ps3fb */
998 atomic_set(&ps3fb.ext_flip, 0); /* for flip with vsync */
999 init_waitqueue_head(&ps3fb.wait_vsync);
1022 dev_info(&dev->core, "Limiting ps3fb mem size to %lu bytes\n",
1029 &ps3fb.memory_handle, &ddr_lpar);
1038 status = lv1_gpu_context_allocate(ps3fb.memory_handle, 0,
1039 &ps3fb.context_handle,
1058 ps3fb.dinfo = dinfo;
1075 &ps3fb.irq_no);
1082 retval = request_irq(ps3fb.irq_no, ps3fb_vsync_interrupt,
1098 status = lv1_gpu_context_iomap(ps3fb.context_handle, GPU_IOIF,
1113 status = lv1_gpu_fb_setup(ps3fb.context_handle, xdr_lpar,
1179 ps3fb.task = task;
1190 lv1_gpu_fb_close(ps3fb.context_handle);
1192 lv1_gpu_context_iomap(ps3fb.context_handle, GPU_IOIF, xdr_lpar,
1195 free_irq(ps3fb.irq_no, &dev->core);
1197 ps3_irq_plug_destroy(ps3fb.irq_no);
1199 iounmap((u8 __force __iomem *)ps3fb.dinfo);
1201 lv1_gpu_context_free(ps3fb.context_handle);
1203 lv1_gpu_memory_free(ps3fb.memory_handle);
1217 atomic_inc(&ps3fb.ext_flip); /* flip off */
1218 ps3fb.dinfo->irq.mask = 0;
1220 if (ps3fb.task) {
1221 struct task_struct *task = ps3fb.task;
1222 ps3fb.task = NULL;
1225 if (ps3fb.irq_no) {
1226 free_irq(ps3fb.irq_no, &dev->core);
1227 ps3_irq_plug_destroy(ps3fb.irq_no);
1235 iounmap((u8 __force __iomem *)ps3fb.dinfo);
1236 lv1_gpu_fb_close(ps3fb.context_handle);
1237 lv1_gpu_context_iomap(ps3fb.context_handle, GPU_IOIF, xdr_lpar,
1239 lv1_gpu_context_free(ps3fb.context_handle);
1240 lv1_gpu_memory_free(ps3fb.memory_handle);