Lines Matching refs:info
73 static void xenfb_send_event(struct xenfb_info *info, in xenfb_send_event() argument
78 prod = info->page->out_prod; in xenfb_send_event()
81 XENFB_OUT_RING_REF(info->page, prod) = *event; in xenfb_send_event()
83 info->page->out_prod = prod + 1; in xenfb_send_event()
85 notify_remote_via_irq(info->irq); in xenfb_send_event()
88 static void xenfb_do_update(struct xenfb_info *info, in xenfb_do_update() argument
101 xenfb_send_event(info, &event); in xenfb_do_update()
104 static void xenfb_do_resize(struct xenfb_info *info) in xenfb_do_resize() argument
109 event.resize = info->resize; in xenfb_do_resize()
112 xenfb_send_event(info, &event); in xenfb_do_resize()
115 static int xenfb_queue_full(struct xenfb_info *info) in xenfb_queue_full() argument
119 prod = info->page->out_prod; in xenfb_queue_full()
120 cons = info->page->out_cons; in xenfb_queue_full()
124 static void xenfb_handle_resize_dpy(struct xenfb_info *info) in xenfb_handle_resize_dpy() argument
128 spin_lock_irqsave(&info->resize_lock, flags); in xenfb_handle_resize_dpy()
129 if (info->resize_dpy) { in xenfb_handle_resize_dpy()
130 if (!xenfb_queue_full(info)) { in xenfb_handle_resize_dpy()
131 info->resize_dpy = 0; in xenfb_handle_resize_dpy()
132 xenfb_do_resize(info); in xenfb_handle_resize_dpy()
135 spin_unlock_irqrestore(&info->resize_lock, flags); in xenfb_handle_resize_dpy()
138 static void xenfb_refresh(struct xenfb_info *info, in xenfb_refresh() argument
145 xenfb_handle_resize_dpy(info); in xenfb_refresh()
147 if (!info->update_wanted) in xenfb_refresh()
150 spin_lock_irqsave(&info->dirty_lock, flags); in xenfb_refresh()
153 if (info->y1 < y1) in xenfb_refresh()
154 y1 = info->y1; in xenfb_refresh()
155 if (info->y2 > y2) in xenfb_refresh()
156 y2 = info->y2; in xenfb_refresh()
157 if (info->x1 < x1) in xenfb_refresh()
158 x1 = info->x1; in xenfb_refresh()
159 if (info->x2 > x2) in xenfb_refresh()
160 x2 = info->x2; in xenfb_refresh()
162 if (xenfb_queue_full(info)) { in xenfb_refresh()
164 info->x1 = x1; in xenfb_refresh()
165 info->x2 = x2; in xenfb_refresh()
166 info->y1 = y1; in xenfb_refresh()
167 info->y2 = y2; in xenfb_refresh()
168 spin_unlock_irqrestore(&info->dirty_lock, flags); in xenfb_refresh()
173 info->x1 = info->y1 = INT_MAX; in xenfb_refresh()
174 info->x2 = info->y2 = 0; in xenfb_refresh()
176 spin_unlock_irqrestore(&info->dirty_lock, flags); in xenfb_refresh()
179 xenfb_do_update(info, x1, y1, x2 - x1 + 1, y2 - y1 + 1); in xenfb_refresh()
185 struct xenfb_info *info = fb_info->par; in xenfb_deferred_io() local
204 xenfb_refresh(info, 0, miny, fb_info->var.xres, maxy - miny + 1); in xenfb_deferred_io()
214 struct fb_info *info) in xenfb_setcolreg() argument
218 if (regno > info->cmap.len) in xenfb_setcolreg()
222 red = CNVT_TOHW(red, info->var.red.length); in xenfb_setcolreg()
223 green = CNVT_TOHW(green, info->var.green.length); in xenfb_setcolreg()
224 blue = CNVT_TOHW(blue, info->var.blue.length); in xenfb_setcolreg()
225 transp = CNVT_TOHW(transp, info->var.transp.length); in xenfb_setcolreg()
228 v = (red << info->var.red.offset) | in xenfb_setcolreg()
229 (green << info->var.green.offset) | in xenfb_setcolreg()
230 (blue << info->var.blue.offset); in xenfb_setcolreg()
232 switch (info->var.bits_per_pixel) { in xenfb_setcolreg()
236 ((u32 *)info->pseudo_palette)[regno] = v; in xenfb_setcolreg()
245 struct xenfb_info *info = p->par; in xenfb_fillrect() local
248 xenfb_refresh(info, rect->dx, rect->dy, rect->width, rect->height); in xenfb_fillrect()
253 struct xenfb_info *info = p->par; in xenfb_imageblit() local
256 xenfb_refresh(info, image->dx, image->dy, image->width, image->height); in xenfb_imageblit()
261 struct xenfb_info *info = p->par; in xenfb_copyarea() local
264 xenfb_refresh(info, area->dx, area->dy, area->width, area->height); in xenfb_copyarea()
270 struct xenfb_info *info = p->par; in xenfb_write() local
274 xenfb_refresh(info, 0, 0, info->page->width, info->page->height); in xenfb_write()
279 xenfb_check_var(struct fb_var_screeninfo *var, struct fb_info *info) in xenfb_check_var() argument
284 xenfb_info = info->par; in xenfb_check_var()
301 var->xres <= info->fix.line_length / (XENFB_DEPTH / 8) && in xenfb_check_var()
302 required_mem_len <= info->fix.smem_len) { in xenfb_check_var()
310 static int xenfb_set_par(struct fb_info *info) in xenfb_set_par() argument
315 xenfb_info = info->par; in xenfb_set_par()
319 xenfb_info->resize.width = info->var.xres; in xenfb_set_par()
320 xenfb_info->resize.height = info->var.yres; in xenfb_set_par()
321 xenfb_info->resize.stride = info->fix.line_length; in xenfb_set_par()
322 xenfb_info->resize.depth = info->var.bits_per_pixel; in xenfb_set_par()
348 struct xenfb_info *info = dev_id; in xenfb_event_handler() local
349 struct xenfb_page *page = info->page; in xenfb_event_handler()
352 info->page->in_cons = info->page->in_prod; in xenfb_event_handler()
353 notify_remote_via_irq(info->irq); in xenfb_event_handler()
357 xenfb_refresh(info, INT_MAX, INT_MAX, -INT_MAX, -INT_MAX); in xenfb_event_handler()
365 struct xenfb_info *info; in xenfb_probe() local
371 info = kzalloc(sizeof(*info), GFP_KERNEL); in xenfb_probe()
372 if (info == NULL) { in xenfb_probe()
392 dev_set_drvdata(&dev->dev, info); in xenfb_probe()
393 info->xbdev = dev; in xenfb_probe()
394 info->irq = -1; in xenfb_probe()
395 info->x1 = info->y1 = INT_MAX; in xenfb_probe()
396 spin_lock_init(&info->dirty_lock); in xenfb_probe()
397 spin_lock_init(&info->resize_lock); in xenfb_probe()
399 info->fb = vzalloc(fb_size); in xenfb_probe()
400 if (info->fb == NULL) in xenfb_probe()
403 info->nr_pages = (fb_size + PAGE_SIZE - 1) >> PAGE_SHIFT; in xenfb_probe()
405 info->gfns = vmalloc(sizeof(unsigned long) * info->nr_pages); in xenfb_probe()
406 if (!info->gfns) in xenfb_probe()
410 info->page = (void *)__get_free_page(GFP_KERNEL | __GFP_ZERO); in xenfb_probe()
411 if (!info->page) in xenfb_probe()
421 fb_info->par = info; in xenfb_probe()
423 fb_info->screen_base = info->fb; in xenfb_probe()
459 xenfb_init_shared_page(info, fb_info); in xenfb_probe()
461 ret = xenfb_connect_backend(dev, info); in xenfb_probe()
472 info->fb_info = fb_info; in xenfb_probe()
514 struct xenfb_info *info = dev_get_drvdata(&dev->dev); in xenfb_resume() local
516 xenfb_disconnect_backend(info); in xenfb_resume()
517 xenfb_init_shared_page(info, info->fb_info); in xenfb_resume()
518 return xenfb_connect_backend(dev, info); in xenfb_resume()
523 struct xenfb_info *info = dev_get_drvdata(&dev->dev); in xenfb_remove() local
525 xenfb_disconnect_backend(info); in xenfb_remove()
526 if (info->fb_info) { in xenfb_remove()
527 fb_deferred_io_cleanup(info->fb_info); in xenfb_remove()
528 unregister_framebuffer(info->fb_info); in xenfb_remove()
529 fb_dealloc_cmap(&info->fb_info->cmap); in xenfb_remove()
530 framebuffer_release(info->fb_info); in xenfb_remove()
532 free_page((unsigned long)info->page); in xenfb_remove()
533 vfree(info->gfns); in xenfb_remove()
534 vfree(info->fb); in xenfb_remove()
535 kfree(info); in xenfb_remove()
545 static void xenfb_init_shared_page(struct xenfb_info *info, in xenfb_init_shared_page() argument
549 int epd = PAGE_SIZE / sizeof(info->gfns[0]); in xenfb_init_shared_page()
551 for (i = 0; i < info->nr_pages; i++) in xenfb_init_shared_page()
552 info->gfns[i] = vmalloc_to_gfn(info->fb + i * PAGE_SIZE); in xenfb_init_shared_page()
554 for (i = 0; i * epd < info->nr_pages; i++) in xenfb_init_shared_page()
555 info->page->pd[i] = vmalloc_to_gfn(&info->gfns[i * epd]); in xenfb_init_shared_page()
557 info->page->width = fb_info->var.xres; in xenfb_init_shared_page()
558 info->page->height = fb_info->var.yres; in xenfb_init_shared_page()
559 info->page->depth = fb_info->var.bits_per_pixel; in xenfb_init_shared_page()
560 info->page->line_length = fb_info->fix.line_length; in xenfb_init_shared_page()
561 info->page->mem_length = fb_info->fix.smem_len; in xenfb_init_shared_page()
562 info->page->in_cons = info->page->in_prod = 0; in xenfb_init_shared_page()
563 info->page->out_cons = info->page->out_prod = 0; in xenfb_init_shared_page()
567 struct xenfb_info *info) in xenfb_connect_backend() argument
576 0, dev->devicetype, info); in xenfb_connect_backend()
589 virt_to_gfn(info->page)); in xenfb_connect_backend()
612 info->irq = irq; in xenfb_connect_backend()
619 unbind_from_irqhandler(irq, info); in xenfb_connect_backend()
623 static void xenfb_disconnect_backend(struct xenfb_info *info) in xenfb_disconnect_backend() argument
626 info->update_wanted = 0; in xenfb_disconnect_backend()
627 if (info->irq >= 0) in xenfb_disconnect_backend()
628 unbind_from_irqhandler(info->irq, info); in xenfb_disconnect_backend()
629 info->irq = -1; in xenfb_disconnect_backend()
635 struct xenfb_info *info = dev_get_drvdata(&dev->dev); in xenfb_backend_changed() local
660 if (xenbus_scanf(XBT_NIL, info->xbdev->otherend, in xenfb_backend_changed()
664 info->update_wanted = 1; in xenfb_backend_changed()
669 info->feature_resize = val; in xenfb_backend_changed()