Commit 87bf7929 authored by Sudip Mukherjee's avatar Sudip Mukherjee Committed by Greg Kroah-Hartman

staging: sm7xxfb: define new macros

Define and use some new macros to work with different situations
based on little-endian and big-endian.
Signed-off-by: default avatarSudip Mukherjee <sudip@vectorindia.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 9431fda3
...@@ -95,3 +95,22 @@ struct modeinit { ...@@ -95,3 +95,22 @@ struct modeinit {
unsigned char init_cr30_cr4d[SIZE_CR30_CR4D]; unsigned char init_cr30_cr4d[SIZE_CR30_CR4D];
unsigned char init_cr90_cra7[SIZE_CR90_CRA7]; unsigned char init_cr90_cra7[SIZE_CR90_CRA7];
}; };
#ifdef __BIG_ENDIAN
#define pal_rgb(r, g, b, val) (((r & 0xf800) >> 8) | \
((g & 0xe000) >> 13) | \
((g & 0x1c00) << 3) | \
((b & 0xf800) >> 3))
#define big_addr 0x800000
#define mmio_addr 0x00800000
#define seqw17() smtc_seqw(0x17, 0x30)
#define big_pixel_depth(p, d) {if (p == 24) {p = 32; d = 32; } }
#define big_swap(p) ((p & 0xff00ff00 >> 8) | (p & 0x00ff00ff << 8))
#else
#define pal_rgb(r, g, b, val) val
#define big_addr 0
#define mmio_addr 0x00c00000
#define seqw17() do { } while (0)
#define big_pixel_depth(p, d) do { } while (0)
#define big_swap(p) p
#endif
...@@ -923,25 +923,14 @@ static int smtc_setcolreg(unsigned regno, unsigned red, unsigned green, ...@@ -923,25 +923,14 @@ static int smtc_setcolreg(unsigned regno, unsigned red, unsigned green,
val = chan_to_field(red, &sfb->fb->var.red); val = chan_to_field(red, &sfb->fb->var.red);
val |= chan_to_field(green, &sfb->fb->var.green); val |= chan_to_field(green, &sfb->fb->var.green);
val |= chan_to_field(blue, &sfb->fb->var.blue); val |= chan_to_field(blue, &sfb->fb->var.blue);
#ifdef __BIG_ENDIAN pal[regno] = pal_rgb(red, green, blue, val);
pal[regno] = ((red & 0xf800) >> 8) |
((green & 0xe000) >> 13) |
((green & 0x1c00) << 3) |
((blue & 0xf800) >> 3);
#else
pal[regno] = val;
#endif
} else { } else {
u32 *pal = sfb->fb->pseudo_palette; u32 *pal = sfb->fb->pseudo_palette;
val = chan_to_field(red, &sfb->fb->var.red); val = chan_to_field(red, &sfb->fb->var.red);
val |= chan_to_field(green, &sfb->fb->var.green); val |= chan_to_field(green, &sfb->fb->var.green);
val |= chan_to_field(blue, &sfb->fb->var.blue); val |= chan_to_field(blue, &sfb->fb->var.blue);
#ifdef __BIG_ENDIAN pal[regno] = big_swap(val);
val = (val & 0xff00ff00 >> 8) |
(val & 0x00ff00ff << 8);
#endif
pal[regno] = val;
} }
break; break;
...@@ -1002,8 +991,7 @@ static ssize_t smtcfb_read(struct fb_info *info, char __user *buf, ...@@ -1002,8 +991,7 @@ static ssize_t smtcfb_read(struct fb_info *info, char __user *buf,
dst = buffer; dst = buffer;
for (i = c >> 2; i--;) { for (i = c >> 2; i--;) {
*dst = fb_readl(src++); *dst = fb_readl(src++);
*dst = (*dst & 0xff00ff00 >> 8) | *dst = big_swap(*dst);
(*dst & 0x00ff00ff << 8);
dst++; dst++;
} }
if (c & 3) { if (c & 3) {
...@@ -1091,8 +1079,7 @@ static ssize_t smtcfb_write(struct fb_info *info, const char __user *buf, ...@@ -1091,8 +1079,7 @@ static ssize_t smtcfb_write(struct fb_info *info, const char __user *buf,
} }
for (i = c >> 2; i--;) { for (i = c >> 2; i--;) {
fb_writel((*src & 0xff00ff00 >> 8) | fb_writel(big_swap(*src), dst++);
(*src & 0x00ff00ff << 8), dst++);
src++; src++;
} }
if (c & 3) { if (c & 3) {
...@@ -1341,10 +1328,8 @@ static int smtc_map_smem(struct smtcfb_info *sfb, ...@@ -1341,10 +1328,8 @@ static int smtc_map_smem(struct smtcfb_info *sfb,
{ {
sfb->fb->fix.smem_start = pci_resource_start(pdev, 0); sfb->fb->fix.smem_start = pci_resource_start(pdev, 0);
#ifdef __BIG_ENDIAN
if (sfb->fb->var.bits_per_pixel == 32) if (sfb->fb->var.bits_per_pixel == 32)
sfb->fb->fix.smem_start += 0x800000; sfb->fb->fix.smem_start += big_addr;
#endif
sfb->fb->fix.smem_len = smem_len; sfb->fb->fix.smem_len = smem_len;
...@@ -1437,10 +1422,7 @@ static int smtcfb_pci_probe(struct pci_dev *pdev, ...@@ -1437,10 +1422,7 @@ static int smtcfb_pci_probe(struct pci_dev *pdev,
sfb->fb->var.bits_per_pixel = SCREEN_BPP; sfb->fb->var.bits_per_pixel = SCREEN_BPP;
} }
#ifdef __BIG_ENDIAN big_pixel_depth(sfb->fb->var.bits_per_pixel, smtc_scr_info.lfb_depth);
if (sfb->fb->var.bits_per_pixel == 24)
sfb->fb->var.bits_per_pixel = (smtc_scr_info.lfb_depth = 32);
#endif
/* Map address and memory detection */ /* Map address and memory detection */
mmio_base = pci_resource_start(pdev, 0); mmio_base = pci_resource_start(pdev, 0);
pci_read_config_byte(pdev, PCI_REVISION_ID, &sfb->chip_rev_id); pci_read_config_byte(pdev, PCI_REVISION_ID, &sfb->chip_rev_id);
...@@ -1451,11 +1433,7 @@ static int smtcfb_pci_probe(struct pci_dev *pdev, ...@@ -1451,11 +1433,7 @@ static int smtcfb_pci_probe(struct pci_dev *pdev,
sfb->fb->fix.mmio_start = mmio_base + 0x00400000; sfb->fb->fix.mmio_start = mmio_base + 0x00400000;
sfb->fb->fix.mmio_len = 0x00400000; sfb->fb->fix.mmio_len = 0x00400000;
smem_size = SM712_VIDEOMEMORYSIZE; smem_size = SM712_VIDEOMEMORYSIZE;
#ifdef __BIG_ENDIAN sfb->lfb = ioremap(mmio_base, mmio_addr);
sfb->lfb = ioremap(mmio_base, 0x00c00000);
#else
sfb->lfb = ioremap(mmio_base, 0x00800000);
#endif
if (!sfb->lfb) { if (!sfb->lfb) {
dev_err(&pdev->dev, dev_err(&pdev->dev,
"%s: unable to map memory mapped IO!\n", "%s: unable to map memory mapped IO!\n",
...@@ -1468,12 +1446,10 @@ static int smtcfb_pci_probe(struct pci_dev *pdev, ...@@ -1468,12 +1446,10 @@ static int smtcfb_pci_probe(struct pci_dev *pdev,
sfb->lfb + 0x00700000); sfb->lfb + 0x00700000);
sfb->dp_regs = sfb->lfb + 0x00408000; sfb->dp_regs = sfb->lfb + 0x00408000;
sfb->vp_regs = sfb->lfb + 0x0040c000; sfb->vp_regs = sfb->lfb + 0x0040c000;
#ifdef __BIG_ENDIAN
if (sfb->fb->var.bits_per_pixel == 32) { if (sfb->fb->var.bits_per_pixel == 32) {
sfb->lfb += 0x800000; sfb->lfb += big_addr;
dev_info(&pdev->dev, "sfb->lfb=%p\n", sfb->lfb); dev_info(&pdev->dev, "sfb->lfb=%p\n", sfb->lfb);
} }
#endif
/* set MCLK = 14.31818 * (0x16 / 0x2) */ /* set MCLK = 14.31818 * (0x16 / 0x2) */
smtc_seqw(0x6a, 0x16); smtc_seqw(0x6a, 0x16);
...@@ -1482,10 +1458,8 @@ static int smtcfb_pci_probe(struct pci_dev *pdev, ...@@ -1482,10 +1458,8 @@ static int smtcfb_pci_probe(struct pci_dev *pdev,
/* enable PCI burst */ /* enable PCI burst */
smtc_seqw(0x17, 0x20); smtc_seqw(0x17, 0x20);
/* enable word swap */ /* enable word swap */
#ifdef __BIG_ENDIAN
if (sfb->fb->var.bits_per_pixel == 32) if (sfb->fb->var.bits_per_pixel == 32)
smtc_seqw(0x17, 0x30); seqw17();
#endif
break; break;
case 0x720: case 0x720:
sfb->fb->fix.mmio_start = mmio_base; sfb->fb->fix.mmio_start = mmio_base;
...@@ -1617,10 +1591,8 @@ static int smtcfb_pci_resume(struct device *device) ...@@ -1617,10 +1591,8 @@ static int smtcfb_pci_resume(struct device *device)
smtc_seqw(0x62, 0x3e); smtc_seqw(0x62, 0x3e);
/* enable PCI burst */ /* enable PCI burst */
smtc_seqw(0x17, 0x20); smtc_seqw(0x17, 0x20);
#ifdef __BIG_ENDIAN
if (sfb->fb->var.bits_per_pixel == 32) if (sfb->fb->var.bits_per_pixel == 32)
smtc_seqw(0x17, 0x30); seqw17();
#endif
break; break;
case 0x720: case 0x720:
smtc_seqw(0x62, 0xff); smtc_seqw(0x62, 0xff);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment