/**
  * drm_fb_helper_deferred_io() - fbdev deferred_io callback function
  * @info: fb_info struct pointer
- * @pagelist: list of mmap framebuffer pages that have to be flushed
+ * @pagereflist: list of mmap framebuffer pages that have to be flushed
  *
  * This function is used as the &fb_deferred_io.deferred_io
  * callback function for flushing the fbdev mmap writes.
  */
-void drm_fb_helper_deferred_io(struct fb_info *info,
-                              struct list_head *pagelist)
+void drm_fb_helper_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        unsigned long start, end, min, max;
        struct fb_deferred_io_pageref *pageref;
 
        min = ULONG_MAX;
        max = 0;
-       list_for_each_entry(pageref, pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                start = pageref->offset;
                end = start + PAGE_SIZE;
                min = min(min, start);
 
        return 0;
 }
 
-static void vmw_deferred_io(struct fb_info *info,
-                           struct list_head *pagelist)
+static void vmw_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        struct vmw_fb_par *par = info->par;
        unsigned long start, end, min, max;
 
        min = ULONG_MAX;
        max = 0;
-       list_for_each_entry(pageref, pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *page = pageref->page;
                start = page->index << PAGE_SHIFT;
                end = start + PAGE_SIZE - 1;
 
 
 
 /* Callback from deferred IO workqueue */
-static void picolcd_fb_deferred_io(struct fb_info *info, struct list_head *pagelist)
+static void picolcd_fb_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        picolcd_fb_update(info);
 }
 
        schedule_delayed_work(&info->deferred_work, fbdefio->delay);
 }
 
-static void fbtft_deferred_io(struct fb_info *info, struct list_head *pagelist)
+static void fbtft_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        struct fbtft_par *par = info->par;
        unsigned int dirty_lines_start, dirty_lines_end;
        spin_unlock(&par->dirty_lock);
 
        /* Mark display lines as dirty */
-       list_for_each_entry(pageref, pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *page = pageref->page;
                count++;
                index = page->index << PAGE_SHIFT;
        fbops->fb_blank     =      fbtft_fb_blank;
        fbops->fb_mmap      =      fb_deferred_io_mmap;
 
-       fbdefio->delay =           HZ / fps;
-       fbdefio->sort_pagelist =   true;
-       fbdefio->deferred_io =     fbtft_deferred_io;
+       fbdefio->delay =            HZ / fps;
+       fbdefio->sort_pagereflist = true;
+       fbdefio->deferred_io =      fbtft_deferred_io;
        fb_deferred_io_init(info);
 
        snprintf(info->fix.id, sizeof(info->fix.id), "%s", dev->driver->name);
 
 }
 
 /* this is called back from the deferred io workqueue */
-static void broadsheetfb_dpy_deferred_io(struct fb_info *info,
-                               struct list_head *pagelist)
+static void broadsheetfb_dpy_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        u16 y1 = 0, h = 0;
        int prev_index = -1;
        struct fb_deferred_io_pageref *pageref;
-       struct fb_deferred_io *fbdefio = info->fbdefio;
        int h_inc;
        u16 yres = info->var.yres;
        u16 xres = info->var.xres;
        h_inc = DIV_ROUND_UP(PAGE_SIZE , xres);
 
        /* walk the written page list and swizzle the data */
-       list_for_each_entry(pageref, &fbdefio->pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *cur = pageref->page;
                if (prev_index < 0) {
                        /* just starting so assign first page */
 };
 
 static struct fb_deferred_io broadsheetfb_defio = {
-       .delay          = HZ/4,
-       .sort_pagelist  = true,
-       .deferred_io    = broadsheetfb_dpy_deferred_io,
+       .delay                  = HZ/4,
+       .sort_pagereflist       = true,
+       .deferred_io            = broadsheetfb_dpy_deferred_io,
 };
 
 static int broadsheetfb_probe(struct platform_device *dev)
 
                                                                 struct page *page)
 {
        struct fb_deferred_io *fbdefio = info->fbdefio;
-       struct list_head *pos = &fbdefio->pagelist;
+       struct list_head *pos = &fbdefio->pagereflist;
        unsigned long pgoff = offset >> PAGE_SHIFT;
        struct fb_deferred_io_pageref *pageref, *cur;
 
        pageref->page = page;
        pageref->offset = pgoff << PAGE_SHIFT;
 
-       if (unlikely(fbdefio->sort_pagelist)) {
+       if (unlikely(fbdefio->sort_pagereflist)) {
                /*
                 * We loop through the list of pagerefs before adding in
                 * order to keep the pagerefs sorted. This has significant
                 * pages. If possible, drivers should try to work with
                 * unsorted page lists instead.
                 */
-               list_for_each_entry(cur, &info->fbdefio->pagelist, list) {
+               list_for_each_entry(cur, &fbdefio->pagereflist, list) {
                        if (cur->offset > pageref->offset)
                                break;
                }
        mutex_lock(&fbdefio->lock);
 
        /* first write in this cycle, notify the driver */
-       if (fbdefio->first_io && list_empty(&fbdefio->pagelist))
+       if (fbdefio->first_io && list_empty(&fbdefio->pagereflist))
                fbdefio->first_io(info);
 
        pageref = fb_deferred_io_pageref_get(info, offset, page);
 
        /* here we mkclean the pages, then do all deferred IO */
        mutex_lock(&fbdefio->lock);
-       list_for_each_entry(pageref, &fbdefio->pagelist, list) {
+       list_for_each_entry(pageref, &fbdefio->pagereflist, list) {
                struct page *cur = pageref->page;
                lock_page(cur);
                page_mkclean(cur);
                unlock_page(cur);
        }
 
-       /* driver's callback with pagelist */
-       fbdefio->deferred_io(info, &fbdefio->pagelist);
+       /* driver's callback with pagereflist */
+       fbdefio->deferred_io(info, &fbdefio->pagereflist);
 
        /* clear the list */
-       list_for_each_entry_safe(pageref, next, &fbdefio->pagelist, list)
+       list_for_each_entry_safe(pageref, next, &fbdefio->pagereflist, list)
                fb_deferred_io_pageref_put(pageref, info);
 
        mutex_unlock(&fbdefio->lock);
 
        mutex_init(&fbdefio->lock);
        INIT_DELAYED_WORK(&info->deferred_work, fb_deferred_io_work);
-       INIT_LIST_HEAD(&fbdefio->pagelist);
+       INIT_LIST_HEAD(&fbdefio->pagereflist);
        if (fbdefio->delay == 0) /* set a default of 1 s */
                fbdefio->delay = HZ;
 
 
 }
 
 /* this is called back from the deferred io workqueue */
-static void hecubafb_dpy_deferred_io(struct fb_info *info,
-                               struct list_head *pagelist)
+static void hecubafb_dpy_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        hecubafb_dpy_update(info->par);
 }
 
 }
 
 /* Deferred IO callback */
-static void synthvid_deferred_io(struct fb_info *p,
-                                struct list_head *pagelist)
+static void synthvid_deferred_io(struct fb_info *p, struct list_head *pagereflist)
 {
        struct hvfb_par *par = p->par;
        struct fb_deferred_io_pageref *pageref;
         * in synthvid_update function by clamping the y2
         * value to yres.
         */
-       list_for_each_entry(pageref, pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *page = pageref->page;
                start = page->index << PAGE_SHIFT;
                end = start + PAGE_SIZE - 1;
 
 }
 
 /* this is called back from the deferred io workqueue */
-static void metronomefb_dpy_deferred_io(struct fb_info *info,
-                               struct list_head *pagelist)
+static void metronomefb_dpy_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        u16 cksum;
        struct fb_deferred_io_pageref *pageref;
-       struct fb_deferred_io *fbdefio = info->fbdefio;
        struct metronomefb_par *par = info->par;
 
        /* walk the written page list and swizzle the data */
-       list_for_each_entry(pageref, &fbdefio->pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *cur = pageref->page;
                cksum = metronomefb_dpy_update_page(par,
                                        (cur->index << PAGE_SHIFT));
 };
 
 static struct fb_deferred_io metronomefb_defio = {
-       .delay          = HZ,
-       .sort_pagelist  = true,
-       .deferred_io    = metronomefb_dpy_deferred_io,
+       .delay                  = HZ,
+       .sort_pagereflist       = true,
+       .deferred_io            = metronomefb_dpy_deferred_io,
 };
 
 static int metronomefb_probe(struct platform_device *dev)
 
        .read_data      = lcdc_sys_read_data,
 };
 
-static int sh_mobile_lcdc_sginit(struct fb_info *info,
-                                 struct list_head *pagelist)
+static int sh_mobile_lcdc_sginit(struct fb_info *info, struct list_head *pagereflist)
 {
        struct sh_mobile_lcdc_chan *ch = info->par;
        unsigned int nr_pages_max = ch->fb_size >> PAGE_SHIFT;
 
        sg_init_table(ch->sglist, nr_pages_max);
 
-       list_for_each_entry(pageref, pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *page = pageref->page;
                sg_set_page(&ch->sglist[nr_pages++], page, PAGE_SIZE, 0);
        }
        return nr_pages;
 }
 
-static void sh_mobile_lcdc_deferred_io(struct fb_info *info,
-                                      struct list_head *pagelist)
+static void sh_mobile_lcdc_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        struct sh_mobile_lcdc_chan *ch = info->par;
        const struct sh_mobile_lcdc_panel_cfg *panel = &ch->cfg->panel_cfg;
        sh_mobile_lcdc_clk_on(ch->lcdc);
 
        /*
-        * It's possible to get here without anything on the pagelist via
+        * It's possible to get here without anything on the pagereflist via
         * sh_mobile_lcdc_deferred_io_touch() or via a userspace fsync()
         * invocation. In the former case, the acceleration routines are
         * stepped in to when using the framebuffer console causing the
         * acceleration routines have their own methods for writing in
         * that still need to be updated.
         *
-        * The fsync() and empty pagelist case could be optimized for,
+        * The fsync() and empty pagereflist case could be optimized for,
         * but we don't bother, as any application exhibiting such
         * behaviour is fundamentally broken anyways.
         */
-       if (!list_empty(pagelist)) {
-               unsigned int nr_pages = sh_mobile_lcdc_sginit(info, pagelist);
+       if (!list_empty(pagereflist)) {
+               unsigned int nr_pages = sh_mobile_lcdc_sginit(info, pagereflist);
 
                /* trigger panel update */
                dma_map_sg(ch->lcdc->dev, ch->sglist, nr_pages, DMA_TO_DEVICE);
 
  *   Touching ANY framebuffer memory that triggers a page fault
  *   in fb_defio will cause a deadlock, when it also tries to
  *   grab the same mutex. */
-static void ufx_dpy_deferred_io(struct fb_info *info,
-                               struct list_head *pagelist)
+static void ufx_dpy_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
-       struct fb_deferred_io_pageref *pageref;
-       struct fb_deferred_io *fbdefio = info->fbdefio;
        struct ufx_data *dev = info->par;
+       struct fb_deferred_io_pageref *pageref;
 
        if (!fb_defio)
                return;
                return;
 
        /* walk the written page list and render each to device */
-       list_for_each_entry(pageref, &fbdefio->pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                /* create a rectangle of full screen width that encloses the
                 * entire dirty framebuffer page */
                struct page *cur = pageref->page;
 
        .fb_mmap        = fb_deferred_io_mmap,
 };
 
-static void ssd1307fb_deferred_io(struct fb_info *info,
-                               struct list_head *pagelist)
+static void ssd1307fb_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        ssd1307fb_update_display(info->par);
 }
 
  *   in fb_defio will cause a deadlock, when it also tries to
  *   grab the same mutex.
  */
-static void dlfb_dpy_deferred_io(struct fb_info *info,
-                               struct list_head *pagelist)
+static void dlfb_dpy_deferred_io(struct fb_info *info, struct list_head *pagereflist)
 {
        struct fb_deferred_io_pageref *pageref;
-       struct fb_deferred_io *fbdefio = info->fbdefio;
        struct dlfb_data *dlfb = info->par;
        struct urb *urb;
        char *cmd;
        cmd = urb->transfer_buffer;
 
        /* walk the written page list and render each to device */
-       list_for_each_entry(pageref, &fbdefio->pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *cur = pageref->page;
 
                if (dlfb_render_hline(dlfb, &urb, (char *) info->fix.smem_start,
 
                if (fbdefio) {
                        fbdefio->delay = DL_DEFIO_WRITE_DELAY;
-                       fbdefio->sort_pagelist = true;
+                       fbdefio->sort_pagereflist = true;
                        fbdefio->deferred_io = dlfb_dpy_deferred_io;
                }
 
 
                xenfb_do_update(info, x1, y1, x2 - x1 + 1, y2 - y1 + 1);
 }
 
-static void xenfb_deferred_io(struct fb_info *fb_info,
-                             struct list_head *pagelist)
+static void xenfb_deferred_io(struct fb_info *fb_info, struct list_head *pagereflist)
 {
        struct xenfb_info *info = fb_info->par;
        struct fb_deferred_io_pageref *pageref;
 
        miny = INT_MAX;
        maxy = 0;
-       list_for_each_entry(pageref, pagelist, list) {
+       list_for_each_entry(pageref, pagereflist, list) {
                struct page *page = pageref->page;
                beg = page->index << PAGE_SHIFT;
                end = beg + PAGE_SIZE - 1;
 
                             struct drm_fb_helper *fb_helper,
                             struct drm_fb_helper_surface_size *sizes);
 
-void drm_fb_helper_deferred_io(struct fb_info *info,
-                              struct list_head *pagelist);
+void drm_fb_helper_deferred_io(struct fb_info *info, struct list_head *pagereflist);
 
 ssize_t drm_fb_helper_sys_read(struct fb_info *info, char __user *buf,
                               size_t count, loff_t *ppos);
 
 struct fb_deferred_io {
        /* delay between mkwrite and deferred handler */
        unsigned long delay;
-       bool sort_pagelist; /* sort pagelist by offset */
-       struct mutex lock; /* mutex that protects the page list */
-       struct list_head pagelist; /* list of touched pages */
+       bool sort_pagereflist; /* sort pagelist by offset */
+       struct mutex lock; /* mutex that protects the pageref list */
+       struct list_head pagereflist; /* list of pagerefs for touched pages */
        /* callback */
        void (*first_io)(struct fb_info *info);
        void (*deferred_io)(struct fb_info *info, struct list_head *pagelist);