diff options
author | Takashi Iwai <tiwai@suse.de> | 2009-06-05 03:29:22 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2009-06-05 03:29:22 -0400 |
commit | 42a0b31827e4c555efebda7d347cf4ea6b82913a (patch) | |
tree | c4e747955f716fa7cae83278ccde17c9d74c1415 /sound/pci/ctxfi/cthw20k1.c | |
parent | 6d74b86d3c0f9cfa949566a862aaad840e393249 (diff) |
ALSA: ctxfi - Fix endian-dependent codes
The UAA-mode check in hwct20k1.c is implemented with the endian-dependent
codes. Fix to be more portable (and readable).
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci/ctxfi/cthw20k1.c')
-rw-r--r-- | sound/pci/ctxfi/cthw20k1.c | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/sound/pci/ctxfi/cthw20k1.c b/sound/pci/ctxfi/cthw20k1.c index 1da1f82fe812..fd5f454c4040 100644 --- a/sound/pci/ctxfi/cthw20k1.c +++ b/sound/pci/ctxfi/cthw20k1.c | |||
@@ -1785,6 +1785,8 @@ static int hw_have_digit_io_switch(struct hw *hw) | |||
1785 | || ((subsys_id & 0xf000) == 0x6000)); | 1785 | || ((subsys_id & 0xf000) == 0x6000)); |
1786 | } | 1786 | } |
1787 | 1787 | ||
1788 | #define CTLBITS(a, b, c, d) (((a) << 24) | ((b) << 16) | ((c) << 8) | (d)) | ||
1789 | |||
1788 | #define UAA_CFG_PWRSTATUS 0x44 | 1790 | #define UAA_CFG_PWRSTATUS 0x44 |
1789 | #define UAA_CFG_SPACE_FLAG 0xA0 | 1791 | #define UAA_CFG_SPACE_FLAG 0xA0 |
1790 | #define UAA_CORE_CHANGE 0x3FFC | 1792 | #define UAA_CORE_CHANGE 0x3FFC |
@@ -1792,12 +1794,18 @@ static int uaa_to_xfi(struct pci_dev *pci) | |||
1792 | { | 1794 | { |
1793 | unsigned int bar0, bar1, bar2, bar3, bar4, bar5; | 1795 | unsigned int bar0, bar1, bar2, bar3, bar4, bar5; |
1794 | unsigned int cmd, irq, cl_size, l_timer, pwr; | 1796 | unsigned int cmd, irq, cl_size, l_timer, pwr; |
1795 | unsigned int CTLA, CTLZ, CTLL, CTLX, CTL_, CTLF, CTLi; | ||
1796 | unsigned int is_uaa = 0; | 1797 | unsigned int is_uaa = 0; |
1797 | unsigned int data[4] = {0}; | 1798 | unsigned int data[4] = {0}; |
1798 | unsigned int io_base; | 1799 | unsigned int io_base; |
1799 | void *mem_base; | 1800 | void *mem_base; |
1800 | int i = 0; | 1801 | int i = 0; |
1802 | const u32 CTLX = CTLBITS('C', 'T', 'L', 'X'); | ||
1803 | const u32 CTL_ = CTLBITS('C', 'T', 'L', '-'); | ||
1804 | const u32 CTLF = CTLBITS('C', 'T', 'L', 'F'); | ||
1805 | const u32 CTLi = CTLBITS('C', 'T', 'L', 'i'); | ||
1806 | const u32 CTLA = CTLBITS('C', 'T', 'L', 'A'); | ||
1807 | const u32 CTLZ = CTLBITS('C', 'T', 'L', 'Z'); | ||
1808 | const u32 CTLL = CTLBITS('C', 'T', 'L', 'L'); | ||
1801 | 1809 | ||
1802 | /* By default, Hendrix card UAA Bar0 should be using memory... */ | 1810 | /* By default, Hendrix card UAA Bar0 should be using memory... */ |
1803 | io_base = pci_resource_start(pci, 0); | 1811 | io_base = pci_resource_start(pci, 0); |
@@ -1805,14 +1813,6 @@ static int uaa_to_xfi(struct pci_dev *pci) | |||
1805 | if (NULL == mem_base) | 1813 | if (NULL == mem_base) |
1806 | return -ENOENT; | 1814 | return -ENOENT; |
1807 | 1815 | ||
1808 | CTLX = ___constant_swab32(*((unsigned int *)"CTLX")); | ||
1809 | CTL_ = ___constant_swab32(*((unsigned int *)"CTL-")); | ||
1810 | CTLF = ___constant_swab32(*((unsigned int *)"CTLF")); | ||
1811 | CTLi = ___constant_swab32(*((unsigned int *)"CTLi")); | ||
1812 | CTLA = ___constant_swab32(*((unsigned int *)"CTLA")); | ||
1813 | CTLZ = ___constant_swab32(*((unsigned int *)"CTLZ")); | ||
1814 | CTLL = ___constant_swab32(*((unsigned int *)"CTLL")); | ||
1815 | |||
1816 | /* Read current mode from Mode Change Register */ | 1816 | /* Read current mode from Mode Change Register */ |
1817 | for (i = 0; i < 4; i++) | 1817 | for (i = 0; i < 4; i++) |
1818 | data[i] = readl(mem_base + UAA_CORE_CHANGE); | 1818 | data[i] = readl(mem_base + UAA_CORE_CHANGE); |