diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/video/via/viafbdev.c | 179 |
1 files changed, 110 insertions, 69 deletions
diff --git a/drivers/video/via/viafbdev.c b/drivers/video/via/viafbdev.c index 66921de373fe..7626325ed7f8 100644 --- a/drivers/video/via/viafbdev.c +++ b/drivers/video/via/viafbdev.c | |||
@@ -20,6 +20,7 @@ | |||
20 | */ | 20 | */ |
21 | 21 | ||
22 | #include <linux/module.h> | 22 | #include <linux/module.h> |
23 | #include <linux/seq_file.h> | ||
23 | #define _MASTER_FILE | 24 | #define _MASTER_FILE |
24 | 25 | ||
25 | #include "global.h" | 26 | #include "global.h" |
@@ -1485,10 +1486,8 @@ static void parse_dvi_port(void) | |||
1485 | * DVP1Driving, DFPHigh, DFPLow CR96, SR2A[5], SR1B[1], SR2A[4], SR1E[2], | 1486 | * DVP1Driving, DFPHigh, DFPLow CR96, SR2A[5], SR1B[1], SR2A[4], SR1E[2], |
1486 | * CR9B, SR65, CR97, CR99 | 1487 | * CR9B, SR65, CR97, CR99 |
1487 | */ | 1488 | */ |
1488 | static int viafb_dvp0_proc_read(char *buf, char **start, off_t offset, | 1489 | static int viafb_dvp0_proc_show(struct seq_file *m, void *v) |
1489 | int count, int *eof, void *data) | ||
1490 | { | 1490 | { |
1491 | int len = 0; | ||
1492 | u8 dvp0_data_dri = 0, dvp0_clk_dri = 0, dvp0 = 0; | 1491 | u8 dvp0_data_dri = 0, dvp0_clk_dri = 0, dvp0 = 0; |
1493 | dvp0_data_dri = | 1492 | dvp0_data_dri = |
1494 | (viafb_read_reg(VIASR, SR2A) & BIT5) >> 4 | | 1493 | (viafb_read_reg(VIASR, SR2A) & BIT5) >> 4 | |
@@ -1497,13 +1496,17 @@ int count, int *eof, void *data) | |||
1497 | (viafb_read_reg(VIASR, SR2A) & BIT4) >> 3 | | 1496 | (viafb_read_reg(VIASR, SR2A) & BIT4) >> 3 | |
1498 | (viafb_read_reg(VIASR, SR1E) & BIT2) >> 2; | 1497 | (viafb_read_reg(VIASR, SR1E) & BIT2) >> 2; |
1499 | dvp0 = viafb_read_reg(VIACR, CR96) & 0x0f; | 1498 | dvp0 = viafb_read_reg(VIACR, CR96) & 0x0f; |
1500 | len += | 1499 | seq_printf(m, "%x %x %x\n", dvp0, dvp0_data_dri, dvp0_clk_dri); |
1501 | sprintf(buf + len, "%x %x %x\n", dvp0, dvp0_data_dri, dvp0_clk_dri); | 1500 | return 0; |
1502 | *eof = 1; /*Inform kernel end of data */ | 1501 | } |
1503 | return len; | 1502 | |
1503 | static int viafb_dvp0_proc_open(struct inode *inode, struct file *file) | ||
1504 | { | ||
1505 | return single_open(file, viafb_dvp0_proc_show, NULL); | ||
1504 | } | 1506 | } |
1505 | static int viafb_dvp0_proc_write(struct file *file, | 1507 | |
1506 | const char __user *buffer, unsigned long count, void *data) | 1508 | static ssize_t viafb_dvp0_proc_write(struct file *file, |
1509 | const char __user *buffer, size_t count, loff_t *pos) | ||
1507 | { | 1510 | { |
1508 | char buf[20], *value, *pbuf; | 1511 | char buf[20], *value, *pbuf; |
1509 | u8 reg_val = 0; | 1512 | u8 reg_val = 0; |
@@ -1547,21 +1550,33 @@ static int viafb_dvp0_proc_write(struct file *file, | |||
1547 | } | 1550 | } |
1548 | return count; | 1551 | return count; |
1549 | } | 1552 | } |
1550 | static int viafb_dvp1_proc_read(char *buf, char **start, off_t offset, | 1553 | |
1551 | int count, int *eof, void *data) | 1554 | static const struct file_operations viafb_dvp0_proc_fops = { |
1555 | .owner = THIS_MODULE, | ||
1556 | .open = viafb_dvp0_proc_open, | ||
1557 | .read = seq_read, | ||
1558 | .llseek = seq_lseek, | ||
1559 | .release = single_release, | ||
1560 | .write = viafb_dvp0_proc_write, | ||
1561 | }; | ||
1562 | |||
1563 | static int viafb_dvp1_proc_show(struct seq_file *m, void *v) | ||
1552 | { | 1564 | { |
1553 | int len = 0; | ||
1554 | u8 dvp1 = 0, dvp1_data_dri = 0, dvp1_clk_dri = 0; | 1565 | u8 dvp1 = 0, dvp1_data_dri = 0, dvp1_clk_dri = 0; |
1555 | dvp1 = viafb_read_reg(VIACR, CR9B) & 0x0f; | 1566 | dvp1 = viafb_read_reg(VIACR, CR9B) & 0x0f; |
1556 | dvp1_data_dri = (viafb_read_reg(VIASR, SR65) & 0x0c) >> 2; | 1567 | dvp1_data_dri = (viafb_read_reg(VIASR, SR65) & 0x0c) >> 2; |
1557 | dvp1_clk_dri = viafb_read_reg(VIASR, SR65) & 0x03; | 1568 | dvp1_clk_dri = viafb_read_reg(VIASR, SR65) & 0x03; |
1558 | len += | 1569 | seq_printf(m, "%x %x %x\n", dvp1, dvp1_data_dri, dvp1_clk_dri); |
1559 | sprintf(buf + len, "%x %x %x\n", dvp1, dvp1_data_dri, dvp1_clk_dri); | 1570 | return 0; |
1560 | *eof = 1; /*Inform kernel end of data */ | 1571 | } |
1561 | return len; | 1572 | |
1573 | static int viafb_dvp1_proc_open(struct inode *inode, struct file *file) | ||
1574 | { | ||
1575 | return single_open(file, viafb_dvp1_proc_show, NULL); | ||
1562 | } | 1576 | } |
1563 | static int viafb_dvp1_proc_write(struct file *file, | 1577 | |
1564 | const char __user *buffer, unsigned long count, void *data) | 1578 | static ssize_t viafb_dvp1_proc_write(struct file *file, |
1579 | const char __user *buffer, size_t count, loff_t *pos) | ||
1565 | { | 1580 | { |
1566 | char buf[20], *value, *pbuf; | 1581 | char buf[20], *value, *pbuf; |
1567 | u8 reg_val = 0; | 1582 | u8 reg_val = 0; |
@@ -1600,18 +1615,30 @@ static int viafb_dvp1_proc_write(struct file *file, | |||
1600 | return count; | 1615 | return count; |
1601 | } | 1616 | } |
1602 | 1617 | ||
1603 | static int viafb_dfph_proc_read(char *buf, char **start, off_t offset, | 1618 | static const struct file_operations viafb_dvp1_proc_fops = { |
1604 | int count, int *eof, void *data) | 1619 | .owner = THIS_MODULE, |
1620 | .open = viafb_dvp1_proc_open, | ||
1621 | .read = seq_read, | ||
1622 | .llseek = seq_lseek, | ||
1623 | .release = single_release, | ||
1624 | .write = viafb_dvp1_proc_write, | ||
1625 | }; | ||
1626 | |||
1627 | static int viafb_dfph_proc_show(struct seq_file *m, void *v) | ||
1605 | { | 1628 | { |
1606 | int len = 0; | ||
1607 | u8 dfp_high = 0; | 1629 | u8 dfp_high = 0; |
1608 | dfp_high = viafb_read_reg(VIACR, CR97) & 0x0f; | 1630 | dfp_high = viafb_read_reg(VIACR, CR97) & 0x0f; |
1609 | len += sprintf(buf + len, "%x\n", dfp_high); | 1631 | seq_printf(m, "%x\n", dfp_high); |
1610 | *eof = 1; /*Inform kernel end of data */ | 1632 | return 0; |
1611 | return len; | ||
1612 | } | 1633 | } |
1613 | static int viafb_dfph_proc_write(struct file *file, | 1634 | |
1614 | const char __user *buffer, unsigned long count, void *data) | 1635 | static int viafb_dfph_proc_open(struct inode *inode, struct file *file) |
1636 | { | ||
1637 | return single_open(file, viafb_dfph_proc_show, NULL); | ||
1638 | } | ||
1639 | |||
1640 | static ssize_t viafb_dfph_proc_write(struct file *file, | ||
1641 | const char __user *buffer, size_t count, loff_t *pos) | ||
1615 | { | 1642 | { |
1616 | char buf[20]; | 1643 | char buf[20]; |
1617 | u8 reg_val = 0; | 1644 | u8 reg_val = 0; |
@@ -1626,18 +1653,31 @@ static int viafb_dfph_proc_write(struct file *file, | |||
1626 | viafb_write_reg_mask(CR97, VIACR, reg_val, 0x0f); | 1653 | viafb_write_reg_mask(CR97, VIACR, reg_val, 0x0f); |
1627 | return count; | 1654 | return count; |
1628 | } | 1655 | } |
1629 | static int viafb_dfpl_proc_read(char *buf, char **start, off_t offset, | 1656 | |
1630 | int count, int *eof, void *data) | 1657 | static const struct file_operations viafb_dfph_proc_fops = { |
1658 | .owner = THIS_MODULE, | ||
1659 | .open = viafb_dfph_proc_open, | ||
1660 | .read = seq_read, | ||
1661 | .llseek = seq_lseek, | ||
1662 | .release = single_release, | ||
1663 | .write = viafb_dfph_proc_write, | ||
1664 | }; | ||
1665 | |||
1666 | static int viafb_dfpl_proc_show(struct seq_file *m, void *v) | ||
1631 | { | 1667 | { |
1632 | int len = 0; | ||
1633 | u8 dfp_low = 0; | 1668 | u8 dfp_low = 0; |
1634 | dfp_low = viafb_read_reg(VIACR, CR99) & 0x0f; | 1669 | dfp_low = viafb_read_reg(VIACR, CR99) & 0x0f; |
1635 | len += sprintf(buf + len, "%x\n", dfp_low); | 1670 | seq_printf(m, "%x\n", dfp_low); |
1636 | *eof = 1; /*Inform kernel end of data */ | 1671 | return 0; |
1637 | return len; | 1672 | } |
1673 | |||
1674 | static int viafb_dfpl_proc_open(struct inode *inode, struct file *file) | ||
1675 | { | ||
1676 | return single_open(file, viafb_dfpl_proc_show, NULL); | ||
1638 | } | 1677 | } |
1639 | static int viafb_dfpl_proc_write(struct file *file, | 1678 | |
1640 | const char __user *buffer, unsigned long count, void *data) | 1679 | static ssize_t viafb_dfpl_proc_write(struct file *file, |
1680 | const char __user *buffer, size_t count, loff_t *pos) | ||
1641 | { | 1681 | { |
1642 | char buf[20]; | 1682 | char buf[20]; |
1643 | u8 reg_val = 0; | 1683 | u8 reg_val = 0; |
@@ -1652,10 +1692,18 @@ static int viafb_dfpl_proc_write(struct file *file, | |||
1652 | viafb_write_reg_mask(CR99, VIACR, reg_val, 0x0f); | 1692 | viafb_write_reg_mask(CR99, VIACR, reg_val, 0x0f); |
1653 | return count; | 1693 | return count; |
1654 | } | 1694 | } |
1655 | static int viafb_vt1636_proc_read(char *buf, char **start, | 1695 | |
1656 | off_t offset, int count, int *eof, void *data) | 1696 | static const struct file_operations viafb_dfpl_proc_fops = { |
1697 | .owner = THIS_MODULE, | ||
1698 | .open = viafb_dfpl_proc_open, | ||
1699 | .read = seq_read, | ||
1700 | .llseek = seq_lseek, | ||
1701 | .release = single_release, | ||
1702 | .write = viafb_dfpl_proc_write, | ||
1703 | }; | ||
1704 | |||
1705 | static int viafb_vt1636_proc_show(struct seq_file *m, void *v) | ||
1657 | { | 1706 | { |
1658 | int len = 0; | ||
1659 | u8 vt1636_08 = 0, vt1636_09 = 0; | 1707 | u8 vt1636_08 = 0, vt1636_09 = 0; |
1660 | switch (viaparinfo->chip_info->lvds_chip_info.lvds_chip_name) { | 1708 | switch (viaparinfo->chip_info->lvds_chip_info.lvds_chip_name) { |
1661 | case VT1636_LVDS: | 1709 | case VT1636_LVDS: |
@@ -1665,7 +1713,7 @@ static int viafb_vt1636_proc_read(char *buf, char **start, | |||
1665 | vt1636_09 = | 1713 | vt1636_09 = |
1666 | viafb_gpio_i2c_read_lvds(viaparinfo->lvds_setting_info, | 1714 | viafb_gpio_i2c_read_lvds(viaparinfo->lvds_setting_info, |
1667 | &viaparinfo->chip_info->lvds_chip_info, 0x09) & 0x1f; | 1715 | &viaparinfo->chip_info->lvds_chip_info, 0x09) & 0x1f; |
1668 | len += sprintf(buf + len, "%x %x\n", vt1636_08, vt1636_09); | 1716 | seq_printf(m, "%x %x\n", vt1636_08, vt1636_09); |
1669 | break; | 1717 | break; |
1670 | default: | 1718 | default: |
1671 | break; | 1719 | break; |
@@ -1678,16 +1726,21 @@ static int viafb_vt1636_proc_read(char *buf, char **start, | |||
1678 | vt1636_09 = | 1726 | vt1636_09 = |
1679 | viafb_gpio_i2c_read_lvds(viaparinfo->lvds_setting_info2, | 1727 | viafb_gpio_i2c_read_lvds(viaparinfo->lvds_setting_info2, |
1680 | &viaparinfo->chip_info->lvds_chip_info2, 0x09) & 0x1f; | 1728 | &viaparinfo->chip_info->lvds_chip_info2, 0x09) & 0x1f; |
1681 | len += sprintf(buf + len, " %x %x\n", vt1636_08, vt1636_09); | 1729 | seq_printf(m, " %x %x\n", vt1636_08, vt1636_09); |
1682 | break; | 1730 | break; |
1683 | default: | 1731 | default: |
1684 | break; | 1732 | break; |
1685 | } | 1733 | } |
1686 | *eof = 1; /*Inform kernel end of data */ | 1734 | return 0; |
1687 | return len; | ||
1688 | } | 1735 | } |
1689 | static int viafb_vt1636_proc_write(struct file *file, | 1736 | |
1690 | const char __user *buffer, unsigned long count, void *data) | 1737 | static int viafb_vt1636_proc_open(struct inode *inode, struct file *file) |
1738 | { | ||
1739 | return single_open(file, viafb_vt1636_proc_show, NULL); | ||
1740 | } | ||
1741 | |||
1742 | static ssize_t viafb_vt1636_proc_write(struct file *file, | ||
1743 | const char __user *buffer, size_t count, loff_t *pos) | ||
1691 | { | 1744 | { |
1692 | char buf[30], *value, *pbuf; | 1745 | char buf[30], *value, *pbuf; |
1693 | struct IODATA reg_val; | 1746 | struct IODATA reg_val; |
@@ -1776,39 +1829,27 @@ static int viafb_vt1636_proc_write(struct file *file, | |||
1776 | return count; | 1829 | return count; |
1777 | } | 1830 | } |
1778 | 1831 | ||
1832 | static const struct file_operations viafb_vt1636_proc_fops = { | ||
1833 | .owner = THIS_MODULE, | ||
1834 | .open = viafb_vt1636_proc_open, | ||
1835 | .read = seq_read, | ||
1836 | .llseek = seq_lseek, | ||
1837 | .release = single_release, | ||
1838 | .write = viafb_vt1636_proc_write, | ||
1839 | }; | ||
1840 | |||
1779 | static void viafb_init_proc(struct proc_dir_entry **viafb_entry) | 1841 | static void viafb_init_proc(struct proc_dir_entry **viafb_entry) |
1780 | { | 1842 | { |
1781 | struct proc_dir_entry *entry; | ||
1782 | *viafb_entry = proc_mkdir("viafb", NULL); | 1843 | *viafb_entry = proc_mkdir("viafb", NULL); |
1783 | if (viafb_entry) { | 1844 | if (viafb_entry) { |
1784 | entry = create_proc_entry("dvp0", 0, *viafb_entry); | 1845 | proc_create("dvp0", 0, *viafb_entry, &viafb_dvp0_proc_fops); |
1785 | if (entry) { | 1846 | proc_create("dvp1", 0, *viafb_entry, &viafb_dvp1_proc_fops); |
1786 | entry->read_proc = viafb_dvp0_proc_read; | 1847 | proc_create("dfph", 0, *viafb_entry, &viafb_dfph_proc_fops); |
1787 | entry->write_proc = viafb_dvp0_proc_write; | 1848 | proc_create("dfpl", 0, *viafb_entry, &viafb_dfpl_proc_fops); |
1788 | } | ||
1789 | entry = create_proc_entry("dvp1", 0, *viafb_entry); | ||
1790 | if (entry) { | ||
1791 | entry->read_proc = viafb_dvp1_proc_read; | ||
1792 | entry->write_proc = viafb_dvp1_proc_write; | ||
1793 | } | ||
1794 | entry = create_proc_entry("dfph", 0, *viafb_entry); | ||
1795 | if (entry) { | ||
1796 | entry->read_proc = viafb_dfph_proc_read; | ||
1797 | entry->write_proc = viafb_dfph_proc_write; | ||
1798 | } | ||
1799 | entry = create_proc_entry("dfpl", 0, *viafb_entry); | ||
1800 | if (entry) { | ||
1801 | entry->read_proc = viafb_dfpl_proc_read; | ||
1802 | entry->write_proc = viafb_dfpl_proc_write; | ||
1803 | } | ||
1804 | if (VT1636_LVDS == viaparinfo->chip_info->lvds_chip_info. | 1849 | if (VT1636_LVDS == viaparinfo->chip_info->lvds_chip_info. |
1805 | lvds_chip_name || VT1636_LVDS == | 1850 | lvds_chip_name || VT1636_LVDS == |
1806 | viaparinfo->chip_info->lvds_chip_info2.lvds_chip_name) { | 1851 | viaparinfo->chip_info->lvds_chip_info2.lvds_chip_name) { |
1807 | entry = create_proc_entry("vt1636", 0, *viafb_entry); | 1852 | proc_create("vt1636", 0, *viafb_entry, &viafb_vt1636_proc_fops); |
1808 | if (entry) { | ||
1809 | entry->read_proc = viafb_vt1636_proc_read; | ||
1810 | entry->write_proc = viafb_vt1636_proc_write; | ||
1811 | } | ||
1812 | } | 1853 | } |
1813 | 1854 | ||
1814 | } | 1855 | } |