usb: sisusb_con, convert addr macros to functions
Convert SISUSB_VADDR and SISUSB_HADDR to inline functions. Now, there are no more hidden accesses to local variables (vc_data and sisusb_usb_data). sisusb_haddr returns unsigned long from now on, not u16 *, as ulong is what every caller expects -- we can remove some casts. Call sites were aligned to be readable too. Use sisusb_haddr on 4 more places in sisusbcon_blank and sisusbcon_scroll. It was open coded there with [x, y] being [0, 0]. Signed-off-by: Jiri Slaby <jslaby@suse.cz> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
04389af74d
commit
3af5d01c29
@ -356,15 +356,22 @@ sisusbcon_invert_region(struct vc_data *vc, u16 *p, int count)
|
||||
}
|
||||
}
|
||||
|
||||
#define SISUSB_VADDR(x,y) \
|
||||
((u16 *)c->vc_origin + \
|
||||
(y) * sisusb->sisusb_num_columns + \
|
||||
(x))
|
||||
static inline void *sisusb_vaddr(const struct sisusb_usb_data *sisusb,
|
||||
const struct vc_data *c, unsigned int x, unsigned int y)
|
||||
{
|
||||
return (u16 *)c->vc_origin + y * sisusb->sisusb_num_columns + x;
|
||||
}
|
||||
|
||||
#define SISUSB_HADDR(x,y) \
|
||||
((u16 *)(sisusb->vrambase + (c->vc_origin - sisusb->scrbuf)) + \
|
||||
(y) * sisusb->sisusb_num_columns + \
|
||||
(x))
|
||||
static inline unsigned long sisusb_haddr(const struct sisusb_usb_data *sisusb,
|
||||
const struct vc_data *c, unsigned int x, unsigned int y)
|
||||
{
|
||||
unsigned long offset = c->vc_origin - sisusb->scrbuf;
|
||||
|
||||
/* 2 bytes per each character */
|
||||
offset += 2 * (y * sisusb->sisusb_num_columns + x);
|
||||
|
||||
return sisusb->vrambase + offset;
|
||||
}
|
||||
|
||||
/* Interface routine */
|
||||
static void
|
||||
@ -382,9 +389,8 @@ sisusbcon_putc(struct vc_data *c, int ch, int y, int x)
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
sisusb_copy_memory(sisusb, (char *)SISUSB_VADDR(x, y),
|
||||
(long)SISUSB_HADDR(x, y), 2);
|
||||
sisusb_copy_memory(sisusb, sisusb_vaddr(sisusb, c, x, y),
|
||||
sisusb_haddr(sisusb, c, x, y), 2);
|
||||
|
||||
mutex_unlock(&sisusb->lock);
|
||||
}
|
||||
@ -408,7 +414,7 @@ sisusbcon_putcs(struct vc_data *c, const unsigned short *s,
|
||||
* because the vt does this AFTER calling us.
|
||||
*/
|
||||
|
||||
dest = SISUSB_VADDR(x, y);
|
||||
dest = sisusb_vaddr(sisusb, c, x, y);
|
||||
|
||||
for (i = count; i > 0; i--)
|
||||
sisusbcon_writew(sisusbcon_readw(s++), dest++);
|
||||
@ -418,8 +424,8 @@ sisusbcon_putcs(struct vc_data *c, const unsigned short *s,
|
||||
return;
|
||||
}
|
||||
|
||||
sisusb_copy_memory(sisusb, (char *)SISUSB_VADDR(x, y),
|
||||
(long)SISUSB_HADDR(x, y), count * 2);
|
||||
sisusb_copy_memory(sisusb, sisusb_vaddr(sisusb, c, x, y),
|
||||
sisusb_haddr(sisusb, c, x, y), count * 2);
|
||||
|
||||
mutex_unlock(&sisusb->lock);
|
||||
}
|
||||
@ -446,7 +452,7 @@ sisusbcon_clear(struct vc_data *c, int y, int x, int height, int width)
|
||||
* this AFTER calling us.
|
||||
*/
|
||||
|
||||
dest = SISUSB_VADDR(x, y);
|
||||
dest = sisusb_vaddr(sisusb, c, x, y);
|
||||
|
||||
cols = sisusb->sisusb_num_columns;
|
||||
|
||||
@ -472,8 +478,8 @@ sisusbcon_clear(struct vc_data *c, int y, int x, int height, int width)
|
||||
length = ((height * cols) - x - (cols - width - x)) * 2;
|
||||
|
||||
|
||||
sisusb_copy_memory(sisusb, (unsigned char *)SISUSB_VADDR(x, y),
|
||||
(long)SISUSB_HADDR(x, y), length);
|
||||
sisusb_copy_memory(sisusb, sisusb_vaddr(sisusb, c, x, y),
|
||||
sisusb_haddr(sisusb, c, x, y), length);
|
||||
|
||||
mutex_unlock(&sisusb->lock);
|
||||
}
|
||||
@ -520,9 +526,8 @@ sisusbcon_switch(struct vc_data *c)
|
||||
sisusbcon_memcpyw((u16 *)c->vc_origin, (u16 *)c->vc_screenbuf,
|
||||
length);
|
||||
|
||||
sisusb_copy_memory(sisusb, (unsigned char *)c->vc_origin,
|
||||
(long)SISUSB_HADDR(0, 0),
|
||||
length);
|
||||
sisusb_copy_memory(sisusb, (char *)c->vc_origin,
|
||||
sisusb_haddr(sisusb, c, 0, 0), length);
|
||||
|
||||
mutex_unlock(&sisusb->lock);
|
||||
|
||||
@ -628,10 +633,8 @@ sisusbcon_blank(struct vc_data *c, int blank, int mode_switch)
|
||||
sisusbcon_memsetw((u16 *)c->vc_origin,
|
||||
c->vc_video_erase_char,
|
||||
c->vc_screenbuf_size);
|
||||
sisusb_copy_memory(sisusb,
|
||||
(unsigned char *)c->vc_origin,
|
||||
(u32)(sisusb->vrambase +
|
||||
(c->vc_origin - sisusb->scrbuf)),
|
||||
sisusb_copy_memory(sisusb, (char *)c->vc_origin,
|
||||
sisusb_haddr(sisusb, c, 0, 0),
|
||||
c->vc_screenbuf_size);
|
||||
sisusb->con_blanked = 1;
|
||||
ret = 1;
|
||||
@ -796,24 +799,24 @@ sisusbcon_scroll_area(struct vc_data *c, struct sisusb_usb_data *sisusb,
|
||||
switch (dir) {
|
||||
|
||||
case SM_UP:
|
||||
sisusbcon_memmovew(SISUSB_VADDR(0, t),
|
||||
SISUSB_VADDR(0, t + lines),
|
||||
sisusbcon_memmovew(sisusb_vaddr(sisusb, c, 0, t),
|
||||
sisusb_vaddr(sisusb, c, 0, t + lines),
|
||||
(b - t - lines) * cols * 2);
|
||||
sisusbcon_memsetw(SISUSB_VADDR(0, b - lines), eattr,
|
||||
lines * cols * 2);
|
||||
sisusbcon_memsetw(sisusb_vaddr(sisusb, c, 0, b - lines),
|
||||
eattr, lines * cols * 2);
|
||||
break;
|
||||
|
||||
case SM_DOWN:
|
||||
sisusbcon_memmovew(SISUSB_VADDR(0, t + lines),
|
||||
SISUSB_VADDR(0, t),
|
||||
sisusbcon_memmovew(sisusb_vaddr(sisusb, c, 0, t + lines),
|
||||
sisusb_vaddr(sisusb, c, 0, t),
|
||||
(b - t - lines) * cols * 2);
|
||||
sisusbcon_memsetw(SISUSB_VADDR(0, t), eattr,
|
||||
sisusbcon_memsetw(sisusb_vaddr(sisusb, c, 0, t), eattr,
|
||||
lines * cols * 2);
|
||||
break;
|
||||
}
|
||||
|
||||
sisusb_copy_memory(sisusb, (char *)SISUSB_VADDR(0, t),
|
||||
(long)SISUSB_HADDR(0, t), length);
|
||||
sisusb_copy_memory(sisusb, sisusb_vaddr(sisusb, c, 0, t),
|
||||
sisusb_haddr(sisusb, c, 0, t), length);
|
||||
|
||||
mutex_unlock(&sisusb->lock);
|
||||
|
||||
@ -830,7 +833,6 @@ sisusbcon_scroll(struct vc_data *c, unsigned int t, unsigned int b,
|
||||
int copyall = 0;
|
||||
unsigned long oldorigin;
|
||||
unsigned int delta = lines * c->vc_size_row;
|
||||
u32 originoffset;
|
||||
|
||||
/* Returning != 0 means we have done the scrolling successfully.
|
||||
* Returning 0 makes vt do the scrolling on its own.
|
||||
@ -913,23 +915,21 @@ sisusbcon_scroll(struct vc_data *c, unsigned int t, unsigned int b,
|
||||
break;
|
||||
}
|
||||
|
||||
originoffset = (u32)(c->vc_origin - sisusb->scrbuf);
|
||||
|
||||
if (copyall)
|
||||
sisusb_copy_memory(sisusb,
|
||||
(char *)c->vc_origin,
|
||||
(u32)(sisusb->vrambase + originoffset),
|
||||
sisusb_haddr(sisusb, c, 0, 0),
|
||||
c->vc_screenbuf_size);
|
||||
else if (dir == SM_UP)
|
||||
sisusb_copy_memory(sisusb,
|
||||
(char *)c->vc_origin + c->vc_screenbuf_size - delta,
|
||||
(u32)sisusb->vrambase + originoffset +
|
||||
sisusb_haddr(sisusb, c, 0, 0) +
|
||||
c->vc_screenbuf_size - delta,
|
||||
delta);
|
||||
else
|
||||
sisusb_copy_memory(sisusb,
|
||||
(char *)c->vc_origin,
|
||||
(u32)(sisusb->vrambase + originoffset),
|
||||
sisusb_haddr(sisusb, c, 0, 0),
|
||||
delta);
|
||||
|
||||
c->vc_scr_end = c->vc_origin + c->vc_screenbuf_size;
|
||||
|
Loading…
Reference in New Issue
Block a user