aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pinctrl/spear
diff options
context:
space:
mode:
authorVipul Kumar Samar <vipulkumar.samar@st.com>2012-10-27 05:17:51 -0400
committerLinus Walleij <linus.walleij@linaro.org>2012-11-05 06:34:20 -0500
commitf7c5b3d574a036e401b8ccf7ee93b873561c09e4 (patch)
tree69b1f9b41e67013afb696f0fc299720018b9361e /drivers/pinctrl/spear
parent82a2deb93cb2237e3a91db6d0317571ecbd6e531 (diff)
pinctrl: SPEAr1310: Separate out pci pins from pcie_sata pin group
SPEAr1310 has separate PCI and PCIe implementations which are not muxed with each other. Presently they have been implemented as muxed together with SATA and are represented wrongly in the software. In reality only PCIe and SATA implementations are muxed with each other. This patch separates out pci pins creating a new pingroup and function for pci. Signed-off-by: Vipul Kumar Samar <vipulkumar.samar@st.com> Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> Reviewed-by: Shiraz Hashim <shiraz.hashim@st.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/pinctrl/spear')
-rw-r--r--drivers/pinctrl/spear/pinctrl-spear1310.c93
1 files changed, 51 insertions, 42 deletions
diff --git a/drivers/pinctrl/spear/pinctrl-spear1310.c b/drivers/pinctrl/spear/pinctrl-spear1310.c
index baf98ae0b1c7..a25ab73a1615 100644
--- a/drivers/pinctrl/spear/pinctrl-spear1310.c
+++ b/drivers/pinctrl/spear/pinctrl-spear1310.c
@@ -1763,29 +1763,52 @@ static struct spear_function can1_function = {
1763 .ngroups = ARRAY_SIZE(can1_grps), 1763 .ngroups = ARRAY_SIZE(can1_grps),
1764}; 1764};
1765 1765
1766/* Pad multiplexing for pci device */ 1766/* Pad multiplexing for (ras-ip) pci device */
1767static const unsigned pci_sata_pins[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 18, 1767static const unsigned pci_pins[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 18,
1768 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 1768 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36,
1769 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 1769 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54,
1770 55, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99 }; 1770 55, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99 };
1771#define PCI_SATA_MUXREG \
1772 { \
1773 .reg = PAD_FUNCTION_EN_0, \
1774 .mask = PMX_MCI_DATA8_15_MASK, \
1775 .val = 0, \
1776 }, { \
1777 .reg = PAD_FUNCTION_EN_1, \
1778 .mask = PMX_PCI_REG1_MASK, \
1779 .val = 0, \
1780 }, { \
1781 .reg = PAD_FUNCTION_EN_2, \
1782 .mask = PMX_PCI_REG2_MASK, \
1783 .val = 0, \
1784 }
1785 1771
1786/* pad multiplexing for pcie0 device */ 1772static struct spear_muxreg pci_muxreg[] = {
1773 {
1774 .reg = PAD_FUNCTION_EN_0,
1775 .mask = PMX_MCI_DATA8_15_MASK,
1776 .val = 0,
1777 }, {
1778 .reg = PAD_FUNCTION_EN_1,
1779 .mask = PMX_PCI_REG1_MASK,
1780 .val = 0,
1781 }, {
1782 .reg = PAD_FUNCTION_EN_2,
1783 .mask = PMX_PCI_REG2_MASK,
1784 .val = 0,
1785 },
1786};
1787
1788static struct spear_modemux pci_modemux[] = {
1789 {
1790 .muxregs = pci_muxreg,
1791 .nmuxregs = ARRAY_SIZE(pci_muxreg),
1792 },
1793};
1794
1795static struct spear_pingroup pci_pingroup = {
1796 .name = "pci_grp",
1797 .pins = pci_pins,
1798 .npins = ARRAY_SIZE(pci_pins),
1799 .modemuxs = pci_modemux,
1800 .nmodemuxs = ARRAY_SIZE(pci_modemux),
1801};
1802
1803static const char *const pci_grps[] = { "pci_grp" };
1804static struct spear_function pci_function = {
1805 .name = "pci",
1806 .groups = pci_grps,
1807 .ngroups = ARRAY_SIZE(pci_grps),
1808};
1809
1810/* pad multiplexing for (fix-part) pcie0 device */
1787static struct spear_muxreg pcie0_muxreg[] = { 1811static struct spear_muxreg pcie0_muxreg[] = {
1788 PCI_SATA_MUXREG,
1789 { 1812 {
1790 .reg = PCIE_SATA_CFG, 1813 .reg = PCIE_SATA_CFG,
1791 .mask = PCIE_CFG_VAL(0), 1814 .mask = PCIE_CFG_VAL(0),
@@ -1802,15 +1825,12 @@ static struct spear_modemux pcie0_modemux[] = {
1802 1825
1803static struct spear_pingroup pcie0_pingroup = { 1826static struct spear_pingroup pcie0_pingroup = {
1804 .name = "pcie0_grp", 1827 .name = "pcie0_grp",
1805 .pins = pci_sata_pins,
1806 .npins = ARRAY_SIZE(pci_sata_pins),
1807 .modemuxs = pcie0_modemux, 1828 .modemuxs = pcie0_modemux,
1808 .nmodemuxs = ARRAY_SIZE(pcie0_modemux), 1829 .nmodemuxs = ARRAY_SIZE(pcie0_modemux),
1809}; 1830};
1810 1831
1811/* pad multiplexing for pcie1 device */ 1832/* pad multiplexing for (fix-part) pcie1 device */
1812static struct spear_muxreg pcie1_muxreg[] = { 1833static struct spear_muxreg pcie1_muxreg[] = {
1813 PCI_SATA_MUXREG,
1814 { 1834 {
1815 .reg = PCIE_SATA_CFG, 1835 .reg = PCIE_SATA_CFG,
1816 .mask = PCIE_CFG_VAL(1), 1836 .mask = PCIE_CFG_VAL(1),
@@ -1827,15 +1847,12 @@ static struct spear_modemux pcie1_modemux[] = {
1827 1847
1828static struct spear_pingroup pcie1_pingroup = { 1848static struct spear_pingroup pcie1_pingroup = {
1829 .name = "pcie1_grp", 1849 .name = "pcie1_grp",
1830 .pins = pci_sata_pins,
1831 .npins = ARRAY_SIZE(pci_sata_pins),
1832 .modemuxs = pcie1_modemux, 1850 .modemuxs = pcie1_modemux,
1833 .nmodemuxs = ARRAY_SIZE(pcie1_modemux), 1851 .nmodemuxs = ARRAY_SIZE(pcie1_modemux),
1834}; 1852};
1835 1853
1836/* pad multiplexing for pcie2 device */ 1854/* pad multiplexing for (fix-part) pcie2 device */
1837static struct spear_muxreg pcie2_muxreg[] = { 1855static struct spear_muxreg pcie2_muxreg[] = {
1838 PCI_SATA_MUXREG,
1839 { 1856 {
1840 .reg = PCIE_SATA_CFG, 1857 .reg = PCIE_SATA_CFG,
1841 .mask = PCIE_CFG_VAL(2), 1858 .mask = PCIE_CFG_VAL(2),
@@ -1852,22 +1869,20 @@ static struct spear_modemux pcie2_modemux[] = {
1852 1869
1853static struct spear_pingroup pcie2_pingroup = { 1870static struct spear_pingroup pcie2_pingroup = {
1854 .name = "pcie2_grp", 1871 .name = "pcie2_grp",
1855 .pins = pci_sata_pins,
1856 .npins = ARRAY_SIZE(pci_sata_pins),
1857 .modemuxs = pcie2_modemux, 1872 .modemuxs = pcie2_modemux,
1858 .nmodemuxs = ARRAY_SIZE(pcie2_modemux), 1873 .nmodemuxs = ARRAY_SIZE(pcie2_modemux),
1859}; 1874};
1860 1875
1861static const char *const pci_grps[] = { "pcie0_grp", "pcie1_grp", "pcie2_grp" }; 1876static const char *const pcie_grps[] = { "pcie0_grp", "pcie1_grp", "pcie2_grp"
1862static struct spear_function pci_function = { 1877};
1863 .name = "pci", 1878static struct spear_function pcie_function = {
1864 .groups = pci_grps, 1879 .name = "pci_express",
1865 .ngroups = ARRAY_SIZE(pci_grps), 1880 .groups = pcie_grps,
1881 .ngroups = ARRAY_SIZE(pcie_grps),
1866}; 1882};
1867 1883
1868/* pad multiplexing for sata0 device */ 1884/* pad multiplexing for sata0 device */
1869static struct spear_muxreg sata0_muxreg[] = { 1885static struct spear_muxreg sata0_muxreg[] = {
1870 PCI_SATA_MUXREG,
1871 { 1886 {
1872 .reg = PCIE_SATA_CFG, 1887 .reg = PCIE_SATA_CFG,
1873 .mask = SATA_CFG_VAL(0), 1888 .mask = SATA_CFG_VAL(0),
@@ -1884,15 +1899,12 @@ static struct spear_modemux sata0_modemux[] = {
1884 1899
1885static struct spear_pingroup sata0_pingroup = { 1900static struct spear_pingroup sata0_pingroup = {
1886 .name = "sata0_grp", 1901 .name = "sata0_grp",
1887 .pins = pci_sata_pins,
1888 .npins = ARRAY_SIZE(pci_sata_pins),
1889 .modemuxs = sata0_modemux, 1902 .modemuxs = sata0_modemux,
1890 .nmodemuxs = ARRAY_SIZE(sata0_modemux), 1903 .nmodemuxs = ARRAY_SIZE(sata0_modemux),
1891}; 1904};
1892 1905
1893/* pad multiplexing for sata1 device */ 1906/* pad multiplexing for sata1 device */
1894static struct spear_muxreg sata1_muxreg[] = { 1907static struct spear_muxreg sata1_muxreg[] = {
1895 PCI_SATA_MUXREG,
1896 { 1908 {
1897 .reg = PCIE_SATA_CFG, 1909 .reg = PCIE_SATA_CFG,
1898 .mask = SATA_CFG_VAL(1), 1910 .mask = SATA_CFG_VAL(1),
@@ -1909,15 +1921,12 @@ static struct spear_modemux sata1_modemux[] = {
1909 1921
1910static struct spear_pingroup sata1_pingroup = { 1922static struct spear_pingroup sata1_pingroup = {
1911 .name = "sata1_grp", 1923 .name = "sata1_grp",
1912 .pins = pci_sata_pins,
1913 .npins = ARRAY_SIZE(pci_sata_pins),
1914 .modemuxs = sata1_modemux, 1924 .modemuxs = sata1_modemux,
1915 .nmodemuxs = ARRAY_SIZE(sata1_modemux), 1925 .nmodemuxs = ARRAY_SIZE(sata1_modemux),
1916}; 1926};
1917 1927
1918/* pad multiplexing for sata2 device */ 1928/* pad multiplexing for sata2 device */
1919static struct spear_muxreg sata2_muxreg[] = { 1929static struct spear_muxreg sata2_muxreg[] = {
1920 PCI_SATA_MUXREG,
1921 { 1930 {
1922 .reg = PCIE_SATA_CFG, 1931 .reg = PCIE_SATA_CFG,
1923 .mask = SATA_CFG_VAL(2), 1932 .mask = SATA_CFG_VAL(2),
@@ -1934,8 +1943,6 @@ static struct spear_modemux sata2_modemux[] = {
1934 1943
1935static struct spear_pingroup sata2_pingroup = { 1944static struct spear_pingroup sata2_pingroup = {
1936 .name = "sata2_grp", 1945 .name = "sata2_grp",
1937 .pins = pci_sata_pins,
1938 .npins = ARRAY_SIZE(pci_sata_pins),
1939 .modemuxs = sata2_modemux, 1946 .modemuxs = sata2_modemux,
1940 .nmodemuxs = ARRAY_SIZE(sata2_modemux), 1947 .nmodemuxs = ARRAY_SIZE(sata2_modemux),
1941}; 1948};
@@ -2093,6 +2100,7 @@ static struct spear_pingroup *spear1310_pingroups[] = {
2093 &can0_dis_sd_pingroup, 2100 &can0_dis_sd_pingroup,
2094 &can1_dis_sd_pingroup, 2101 &can1_dis_sd_pingroup,
2095 &can1_dis_kbd_pingroup, 2102 &can1_dis_kbd_pingroup,
2103 &pci_pingroup,
2096 &pcie0_pingroup, 2104 &pcie0_pingroup,
2097 &pcie1_pingroup, 2105 &pcie1_pingroup,
2098 &pcie2_pingroup, 2106 &pcie2_pingroup,
@@ -2138,6 +2146,7 @@ static struct spear_function *spear1310_functions[] = {
2138 &can0_function, 2146 &can0_function,
2139 &can1_function, 2147 &can1_function,
2140 &pci_function, 2148 &pci_function,
2149 &pcie_function,
2141 &sata_function, 2150 &sata_function,
2142 &ssp1_function, 2151 &ssp1_function,
2143 &gpt64_function, 2152 &gpt64_function,