diff options
-rw-r--r-- | sound/pci/hda/patch_ca0132.c | 150 |
1 files changed, 75 insertions, 75 deletions
diff --git a/sound/pci/hda/patch_ca0132.c b/sound/pci/hda/patch_ca0132.c index fe07664b44b6..db02c1e96b08 100644 --- a/sound/pci/hda/patch_ca0132.c +++ b/sound/pci/hda/patch_ca0132.c | |||
@@ -858,7 +858,7 @@ static int chipio_write_data_multiple(struct hda_codec *codec, | |||
858 | int status = 0; | 858 | int status = 0; |
859 | 859 | ||
860 | if (data == NULL) { | 860 | if (data == NULL) { |
861 | snd_printdd(KERN_ERR "chipio_write_data null ptr"); | 861 | snd_printdd(KERN_ERR "chipio_write_data null ptr\n"); |
862 | return -EINVAL; | 862 | return -EINVAL; |
863 | } | 863 | } |
864 | 864 | ||
@@ -1397,12 +1397,12 @@ static int dspio_scp(struct hda_codec *codec, | |||
1397 | return -EINVAL; | 1397 | return -EINVAL; |
1398 | 1398 | ||
1399 | if (dir == SCP_GET && reply == NULL) { | 1399 | if (dir == SCP_GET && reply == NULL) { |
1400 | snd_printdd(KERN_ERR "dspio_scp get but has no buffer"); | 1400 | snd_printdd(KERN_ERR "dspio_scp get but has no buffer\n"); |
1401 | return -EINVAL; | 1401 | return -EINVAL; |
1402 | } | 1402 | } |
1403 | 1403 | ||
1404 | if (reply != NULL && (reply_len == NULL || (*reply_len == 0))) { | 1404 | if (reply != NULL && (reply_len == NULL || (*reply_len == 0))) { |
1405 | snd_printdd(KERN_ERR "dspio_scp bad resp buf len parms"); | 1405 | snd_printdd(KERN_ERR "dspio_scp bad resp buf len parms\n"); |
1406 | return -EINVAL; | 1406 | return -EINVAL; |
1407 | } | 1407 | } |
1408 | 1408 | ||
@@ -1420,7 +1420,7 @@ static int dspio_scp(struct hda_codec *codec, | |||
1420 | sizeof(scp_reply), &ret_bytes); | 1420 | sizeof(scp_reply), &ret_bytes); |
1421 | 1421 | ||
1422 | if (status < 0) { | 1422 | if (status < 0) { |
1423 | snd_printdd(KERN_ERR "dspio_scp: send scp msg failed"); | 1423 | snd_printdd(KERN_ERR "dspio_scp: send scp msg failed\n"); |
1424 | return status; | 1424 | return status; |
1425 | } | 1425 | } |
1426 | 1426 | ||
@@ -1439,17 +1439,17 @@ static int dspio_scp(struct hda_codec *codec, | |||
1439 | / sizeof(unsigned int); | 1439 | / sizeof(unsigned int); |
1440 | 1440 | ||
1441 | if (*reply_len < ret_size*sizeof(unsigned int)) { | 1441 | if (*reply_len < ret_size*sizeof(unsigned int)) { |
1442 | snd_printdd(KERN_ERR "reply too long for buf"); | 1442 | snd_printdd(KERN_ERR "reply too long for buf\n"); |
1443 | return -EINVAL; | 1443 | return -EINVAL; |
1444 | } else if (ret_size != reply_data_size) { | 1444 | } else if (ret_size != reply_data_size) { |
1445 | snd_printdd(KERN_ERR "RetLen and HdrLen .NE."); | 1445 | snd_printdd(KERN_ERR "RetLen and HdrLen .NE.\n"); |
1446 | return -EINVAL; | 1446 | return -EINVAL; |
1447 | } else { | 1447 | } else { |
1448 | *reply_len = ret_size*sizeof(unsigned int); | 1448 | *reply_len = ret_size*sizeof(unsigned int); |
1449 | memcpy(reply, scp_reply.data, *reply_len); | 1449 | memcpy(reply, scp_reply.data, *reply_len); |
1450 | } | 1450 | } |
1451 | } else { | 1451 | } else { |
1452 | snd_printdd(KERN_ERR "reply ill-formed or errflag set"); | 1452 | snd_printdd(KERN_ERR "reply ill-formed or errflag set\n"); |
1453 | return -EIO; | 1453 | return -EIO; |
1454 | } | 1454 | } |
1455 | 1455 | ||
@@ -1479,22 +1479,22 @@ static int dspio_alloc_dma_chan(struct hda_codec *codec, unsigned int *dma_chan) | |||
1479 | int status = 0; | 1479 | int status = 0; |
1480 | unsigned int size = sizeof(dma_chan); | 1480 | unsigned int size = sizeof(dma_chan); |
1481 | 1481 | ||
1482 | snd_printdd(KERN_INFO " dspio_alloc_dma_chan() -- begin"); | 1482 | snd_printdd(KERN_INFO " dspio_alloc_dma_chan() -- begin\n"); |
1483 | status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN, | 1483 | status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN, |
1484 | SCP_GET, NULL, 0, dma_chan, &size); | 1484 | SCP_GET, NULL, 0, dma_chan, &size); |
1485 | 1485 | ||
1486 | if (status < 0) { | 1486 | if (status < 0) { |
1487 | snd_printdd(KERN_INFO "dspio_alloc_dma_chan: SCP Failed"); | 1487 | snd_printdd(KERN_INFO "dspio_alloc_dma_chan: SCP Failed\n"); |
1488 | return status; | 1488 | return status; |
1489 | } | 1489 | } |
1490 | 1490 | ||
1491 | if ((*dma_chan + 1) == 0) { | 1491 | if ((*dma_chan + 1) == 0) { |
1492 | snd_printdd(KERN_INFO "no free dma channels to allocate"); | 1492 | snd_printdd(KERN_INFO "no free dma channels to allocate\n"); |
1493 | return -EBUSY; | 1493 | return -EBUSY; |
1494 | } | 1494 | } |
1495 | 1495 | ||
1496 | snd_printdd("dspio_alloc_dma_chan: chan=%d\n", *dma_chan); | 1496 | snd_printdd("dspio_alloc_dma_chan: chan=%d\n", *dma_chan); |
1497 | snd_printdd(KERN_INFO " dspio_alloc_dma_chan() -- complete"); | 1497 | snd_printdd(KERN_INFO " dspio_alloc_dma_chan() -- complete\n"); |
1498 | 1498 | ||
1499 | return status; | 1499 | return status; |
1500 | } | 1500 | } |
@@ -1507,18 +1507,18 @@ static int dspio_free_dma_chan(struct hda_codec *codec, unsigned int dma_chan) | |||
1507 | int status = 0; | 1507 | int status = 0; |
1508 | unsigned int dummy = 0; | 1508 | unsigned int dummy = 0; |
1509 | 1509 | ||
1510 | snd_printdd(KERN_INFO " dspio_free_dma_chan() -- begin"); | 1510 | snd_printdd(KERN_INFO " dspio_free_dma_chan() -- begin\n"); |
1511 | snd_printdd("dspio_free_dma_chan: chan=%d\n", dma_chan); | 1511 | snd_printdd("dspio_free_dma_chan: chan=%d\n", dma_chan); |
1512 | 1512 | ||
1513 | status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN, | 1513 | status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN, |
1514 | SCP_SET, &dma_chan, sizeof(dma_chan), NULL, &dummy); | 1514 | SCP_SET, &dma_chan, sizeof(dma_chan), NULL, &dummy); |
1515 | 1515 | ||
1516 | if (status < 0) { | 1516 | if (status < 0) { |
1517 | snd_printdd(KERN_INFO "dspio_free_dma_chan: SCP Failed"); | 1517 | snd_printdd(KERN_INFO "dspio_free_dma_chan: SCP Failed\n"); |
1518 | return status; | 1518 | return status; |
1519 | } | 1519 | } |
1520 | 1520 | ||
1521 | snd_printdd(KERN_INFO " dspio_free_dma_chan() -- complete"); | 1521 | snd_printdd(KERN_INFO " dspio_free_dma_chan() -- complete\n"); |
1522 | 1522 | ||
1523 | return status; | 1523 | return status; |
1524 | } | 1524 | } |
@@ -1626,39 +1626,39 @@ static int dsp_dma_setup_common(struct hda_codec *codec, | |||
1626 | unsigned int active; | 1626 | unsigned int active; |
1627 | bool code, yram; | 1627 | bool code, yram; |
1628 | 1628 | ||
1629 | snd_printdd(KERN_INFO "-- dsp_dma_setup_common() -- Begin ---------"); | 1629 | snd_printdd(KERN_INFO "-- dsp_dma_setup_common() -- Begin ---------\n"); |
1630 | 1630 | ||
1631 | if (dma_chan >= DSPDMAC_DMA_CFG_CHANNEL_COUNT) { | 1631 | if (dma_chan >= DSPDMAC_DMA_CFG_CHANNEL_COUNT) { |
1632 | snd_printdd(KERN_ERR "dma chan num invalid"); | 1632 | snd_printdd(KERN_ERR "dma chan num invalid\n"); |
1633 | return -EINVAL; | 1633 | return -EINVAL; |
1634 | } | 1634 | } |
1635 | 1635 | ||
1636 | if (dsp_is_dma_active(codec, dma_chan)) { | 1636 | if (dsp_is_dma_active(codec, dma_chan)) { |
1637 | snd_printdd(KERN_ERR "dma already active"); | 1637 | snd_printdd(KERN_ERR "dma already active\n"); |
1638 | return -EBUSY; | 1638 | return -EBUSY; |
1639 | } | 1639 | } |
1640 | 1640 | ||
1641 | dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); | 1641 | dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); |
1642 | 1642 | ||
1643 | if (dsp_addx == INVALID_CHIP_ADDRESS) { | 1643 | if (dsp_addx == INVALID_CHIP_ADDRESS) { |
1644 | snd_printdd(KERN_ERR "invalid chip addr"); | 1644 | snd_printdd(KERN_ERR "invalid chip addr\n"); |
1645 | return -ENXIO; | 1645 | return -ENXIO; |
1646 | } | 1646 | } |
1647 | 1647 | ||
1648 | chnl_prop = DSPDMAC_CHNLPROP_AC_MASK; | 1648 | chnl_prop = DSPDMAC_CHNLPROP_AC_MASK; |
1649 | active = 0; | 1649 | active = 0; |
1650 | 1650 | ||
1651 | snd_printdd(KERN_INFO " dsp_dma_setup_common() start reg pgm"); | 1651 | snd_printdd(KERN_INFO " dsp_dma_setup_common() start reg pgm\n"); |
1652 | 1652 | ||
1653 | if (ovly) { | 1653 | if (ovly) { |
1654 | status = chipio_read(codec, DSPDMAC_CHNLPROP_INST_OFFSET, | 1654 | status = chipio_read(codec, DSPDMAC_CHNLPROP_INST_OFFSET, |
1655 | &chnl_prop); | 1655 | &chnl_prop); |
1656 | 1656 | ||
1657 | if (status < 0) { | 1657 | if (status < 0) { |
1658 | snd_printdd(KERN_ERR "read CHNLPROP Reg fail"); | 1658 | snd_printdd(KERN_ERR "read CHNLPROP Reg fail\n"); |
1659 | return status; | 1659 | return status; |
1660 | } | 1660 | } |
1661 | snd_printdd(KERN_INFO "dsp_dma_setup_common() Read CHNLPROP"); | 1661 | snd_printdd(KERN_INFO "dsp_dma_setup_common() Read CHNLPROP\n"); |
1662 | } | 1662 | } |
1663 | 1663 | ||
1664 | if (!code) | 1664 | if (!code) |
@@ -1670,20 +1670,20 @@ static int dsp_dma_setup_common(struct hda_codec *codec, | |||
1670 | 1670 | ||
1671 | status = chipio_write(codec, DSPDMAC_CHNLPROP_INST_OFFSET, chnl_prop); | 1671 | status = chipio_write(codec, DSPDMAC_CHNLPROP_INST_OFFSET, chnl_prop); |
1672 | if (status < 0) { | 1672 | if (status < 0) { |
1673 | snd_printdd(KERN_ERR "write CHNLPROP Reg fail"); | 1673 | snd_printdd(KERN_ERR "write CHNLPROP Reg fail\n"); |
1674 | return status; | 1674 | return status; |
1675 | } | 1675 | } |
1676 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write CHNLPROP"); | 1676 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write CHNLPROP\n"); |
1677 | 1677 | ||
1678 | if (ovly) { | 1678 | if (ovly) { |
1679 | status = chipio_read(codec, DSPDMAC_ACTIVE_INST_OFFSET, | 1679 | status = chipio_read(codec, DSPDMAC_ACTIVE_INST_OFFSET, |
1680 | &active); | 1680 | &active); |
1681 | 1681 | ||
1682 | if (status < 0) { | 1682 | if (status < 0) { |
1683 | snd_printdd(KERN_ERR "read ACTIVE Reg fail"); | 1683 | snd_printdd(KERN_ERR "read ACTIVE Reg fail\n"); |
1684 | return status; | 1684 | return status; |
1685 | } | 1685 | } |
1686 | snd_printdd(KERN_INFO "dsp_dma_setup_common() Read ACTIVE"); | 1686 | snd_printdd(KERN_INFO "dsp_dma_setup_common() Read ACTIVE\n"); |
1687 | } | 1687 | } |
1688 | 1688 | ||
1689 | active &= (~(1 << (DSPDMAC_ACTIVE_AAR_LOBIT + dma_chan))) & | 1689 | active &= (~(1 << (DSPDMAC_ACTIVE_AAR_LOBIT + dma_chan))) & |
@@ -1691,27 +1691,27 @@ static int dsp_dma_setup_common(struct hda_codec *codec, | |||
1691 | 1691 | ||
1692 | status = chipio_write(codec, DSPDMAC_ACTIVE_INST_OFFSET, active); | 1692 | status = chipio_write(codec, DSPDMAC_ACTIVE_INST_OFFSET, active); |
1693 | if (status < 0) { | 1693 | if (status < 0) { |
1694 | snd_printdd(KERN_ERR "write ACTIVE Reg fail"); | 1694 | snd_printdd(KERN_ERR "write ACTIVE Reg fail\n"); |
1695 | return status; | 1695 | return status; |
1696 | } | 1696 | } |
1697 | 1697 | ||
1698 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write ACTIVE"); | 1698 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write ACTIVE\n"); |
1699 | 1699 | ||
1700 | status = chipio_write(codec, DSPDMAC_AUDCHSEL_INST_OFFSET(dma_chan), | 1700 | status = chipio_write(codec, DSPDMAC_AUDCHSEL_INST_OFFSET(dma_chan), |
1701 | port_map_mask); | 1701 | port_map_mask); |
1702 | if (status < 0) { | 1702 | if (status < 0) { |
1703 | snd_printdd(KERN_ERR "write AUDCHSEL Reg fail"); | 1703 | snd_printdd(KERN_ERR "write AUDCHSEL Reg fail\n"); |
1704 | return status; | 1704 | return status; |
1705 | } | 1705 | } |
1706 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write AUDCHSEL"); | 1706 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write AUDCHSEL\n"); |
1707 | 1707 | ||
1708 | status = chipio_write(codec, DSPDMAC_IRQCNT_INST_OFFSET(dma_chan), | 1708 | status = chipio_write(codec, DSPDMAC_IRQCNT_INST_OFFSET(dma_chan), |
1709 | DSPDMAC_IRQCNT_BICNT_MASK | DSPDMAC_IRQCNT_CICNT_MASK); | 1709 | DSPDMAC_IRQCNT_BICNT_MASK | DSPDMAC_IRQCNT_CICNT_MASK); |
1710 | if (status < 0) { | 1710 | if (status < 0) { |
1711 | snd_printdd(KERN_ERR "write IRQCNT Reg fail"); | 1711 | snd_printdd(KERN_ERR "write IRQCNT Reg fail\n"); |
1712 | return status; | 1712 | return status; |
1713 | } | 1713 | } |
1714 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write IRQCNT"); | 1714 | snd_printdd(KERN_INFO " dsp_dma_setup_common() Write IRQCNT\n"); |
1715 | 1715 | ||
1716 | snd_printdd( | 1716 | snd_printdd( |
1717 | "ChipA=0x%x,DspA=0x%x,dmaCh=%u, " | 1717 | "ChipA=0x%x,DspA=0x%x,dmaCh=%u, " |
@@ -1719,7 +1719,7 @@ static int dsp_dma_setup_common(struct hda_codec *codec, | |||
1719 | chip_addx, dsp_addx, dma_chan, | 1719 | chip_addx, dsp_addx, dma_chan, |
1720 | port_map_mask, chnl_prop, active); | 1720 | port_map_mask, chnl_prop, active); |
1721 | 1721 | ||
1722 | snd_printdd(KERN_INFO "-- dsp_dma_setup_common() -- Complete ------"); | 1722 | snd_printdd(KERN_INFO "-- dsp_dma_setup_common() -- Complete ------\n"); |
1723 | 1723 | ||
1724 | return 0; | 1724 | return 0; |
1725 | } | 1725 | } |
@@ -1745,20 +1745,20 @@ static int dsp_dma_setup(struct hda_codec *codec, | |||
1745 | const unsigned int max_dma_count = 1 << (DSPDMAC_XFRCNT_BCNT_HIBIT - | 1745 | const unsigned int max_dma_count = 1 << (DSPDMAC_XFRCNT_BCNT_HIBIT - |
1746 | DSPDMAC_XFRCNT_BCNT_LOBIT + 1); | 1746 | DSPDMAC_XFRCNT_BCNT_LOBIT + 1); |
1747 | 1747 | ||
1748 | snd_printdd(KERN_INFO "-- dsp_dma_setup() -- Begin ---------"); | 1748 | snd_printdd(KERN_INFO "-- dsp_dma_setup() -- Begin ---------\n"); |
1749 | 1749 | ||
1750 | if (count > max_dma_count) { | 1750 | if (count > max_dma_count) { |
1751 | snd_printdd(KERN_ERR "count too big"); | 1751 | snd_printdd(KERN_ERR "count too big\n"); |
1752 | return -EINVAL; | 1752 | return -EINVAL; |
1753 | } | 1753 | } |
1754 | 1754 | ||
1755 | dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); | 1755 | dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); |
1756 | if (dsp_addx == INVALID_CHIP_ADDRESS) { | 1756 | if (dsp_addx == INVALID_CHIP_ADDRESS) { |
1757 | snd_printdd(KERN_ERR "invalid chip addr"); | 1757 | snd_printdd(KERN_ERR "invalid chip addr\n"); |
1758 | return -ENXIO; | 1758 | return -ENXIO; |
1759 | } | 1759 | } |
1760 | 1760 | ||
1761 | snd_printdd(KERN_INFO " dsp_dma_setup() start reg pgm"); | 1761 | snd_printdd(KERN_INFO " dsp_dma_setup() start reg pgm\n"); |
1762 | 1762 | ||
1763 | addr_field = dsp_addx << DSPDMAC_DMACFG_DBADR_LOBIT; | 1763 | addr_field = dsp_addx << DSPDMAC_DMACFG_DBADR_LOBIT; |
1764 | incr_field = 0; | 1764 | incr_field = 0; |
@@ -1775,10 +1775,10 @@ static int dsp_dma_setup(struct hda_codec *codec, | |||
1775 | status = chipio_write(codec, DSPDMAC_DMACFG_INST_OFFSET(dma_chan), | 1775 | status = chipio_write(codec, DSPDMAC_DMACFG_INST_OFFSET(dma_chan), |
1776 | dma_cfg); | 1776 | dma_cfg); |
1777 | if (status < 0) { | 1777 | if (status < 0) { |
1778 | snd_printdd(KERN_ERR "write DMACFG Reg fail"); | 1778 | snd_printdd(KERN_ERR "write DMACFG Reg fail\n"); |
1779 | return status; | 1779 | return status; |
1780 | } | 1780 | } |
1781 | snd_printdd(KERN_INFO " dsp_dma_setup() Write DMACFG"); | 1781 | snd_printdd(KERN_INFO " dsp_dma_setup() Write DMACFG\n"); |
1782 | 1782 | ||
1783 | adr_ofs = (count - 1) << (DSPDMAC_DSPADROFS_BOFS_LOBIT + | 1783 | adr_ofs = (count - 1) << (DSPDMAC_DSPADROFS_BOFS_LOBIT + |
1784 | (code ? 0 : 1)); | 1784 | (code ? 0 : 1)); |
@@ -1786,10 +1786,10 @@ static int dsp_dma_setup(struct hda_codec *codec, | |||
1786 | status = chipio_write(codec, DSPDMAC_DSPADROFS_INST_OFFSET(dma_chan), | 1786 | status = chipio_write(codec, DSPDMAC_DSPADROFS_INST_OFFSET(dma_chan), |
1787 | adr_ofs); | 1787 | adr_ofs); |
1788 | if (status < 0) { | 1788 | if (status < 0) { |
1789 | snd_printdd(KERN_ERR "write DSPADROFS Reg fail"); | 1789 | snd_printdd(KERN_ERR "write DSPADROFS Reg fail\n"); |
1790 | return status; | 1790 | return status; |
1791 | } | 1791 | } |
1792 | snd_printdd(KERN_INFO " dsp_dma_setup() Write DSPADROFS"); | 1792 | snd_printdd(KERN_INFO " dsp_dma_setup() Write DSPADROFS\n"); |
1793 | 1793 | ||
1794 | base_cnt = (count - 1) << DSPDMAC_XFRCNT_BCNT_LOBIT; | 1794 | base_cnt = (count - 1) << DSPDMAC_XFRCNT_BCNT_LOBIT; |
1795 | 1795 | ||
@@ -1800,17 +1800,17 @@ static int dsp_dma_setup(struct hda_codec *codec, | |||
1800 | status = chipio_write(codec, | 1800 | status = chipio_write(codec, |
1801 | DSPDMAC_XFRCNT_INST_OFFSET(dma_chan), xfr_cnt); | 1801 | DSPDMAC_XFRCNT_INST_OFFSET(dma_chan), xfr_cnt); |
1802 | if (status < 0) { | 1802 | if (status < 0) { |
1803 | snd_printdd(KERN_ERR "write XFRCNT Reg fail"); | 1803 | snd_printdd(KERN_ERR "write XFRCNT Reg fail\n"); |
1804 | return status; | 1804 | return status; |
1805 | } | 1805 | } |
1806 | snd_printdd(KERN_INFO " dsp_dma_setup() Write XFRCNT"); | 1806 | snd_printdd(KERN_INFO " dsp_dma_setup() Write XFRCNT\n"); |
1807 | 1807 | ||
1808 | snd_printdd( | 1808 | snd_printdd( |
1809 | "ChipA=0x%x, cnt=0x%x, DMACFG=0x%x, " | 1809 | "ChipA=0x%x, cnt=0x%x, DMACFG=0x%x, " |
1810 | "ADROFS=0x%x, XFRCNT=0x%x\n", | 1810 | "ADROFS=0x%x, XFRCNT=0x%x\n", |
1811 | chip_addx, count, dma_cfg, adr_ofs, xfr_cnt); | 1811 | chip_addx, count, dma_cfg, adr_ofs, xfr_cnt); |
1812 | 1812 | ||
1813 | snd_printdd(KERN_INFO "-- dsp_dma_setup() -- Complete ---------"); | 1813 | snd_printdd(KERN_INFO "-- dsp_dma_setup() -- Complete ---------\n"); |
1814 | 1814 | ||
1815 | return 0; | 1815 | return 0; |
1816 | } | 1816 | } |
@@ -1824,17 +1824,17 @@ static int dsp_dma_start(struct hda_codec *codec, | |||
1824 | unsigned int reg = 0; | 1824 | unsigned int reg = 0; |
1825 | int status = 0; | 1825 | int status = 0; |
1826 | 1826 | ||
1827 | snd_printdd(KERN_INFO "-- dsp_dma_start() -- Begin ---------"); | 1827 | snd_printdd(KERN_INFO "-- dsp_dma_start() -- Begin ---------\n"); |
1828 | 1828 | ||
1829 | if (ovly) { | 1829 | if (ovly) { |
1830 | status = chipio_read(codec, | 1830 | status = chipio_read(codec, |
1831 | DSPDMAC_CHNLSTART_INST_OFFSET, ®); | 1831 | DSPDMAC_CHNLSTART_INST_OFFSET, ®); |
1832 | 1832 | ||
1833 | if (status < 0) { | 1833 | if (status < 0) { |
1834 | snd_printdd(KERN_ERR "read CHNLSTART reg fail"); | 1834 | snd_printdd(KERN_ERR "read CHNLSTART reg fail\n"); |
1835 | return status; | 1835 | return status; |
1836 | } | 1836 | } |
1837 | snd_printdd(KERN_INFO "-- dsp_dma_start() Read CHNLSTART"); | 1837 | snd_printdd(KERN_INFO "-- dsp_dma_start() Read CHNLSTART\n"); |
1838 | 1838 | ||
1839 | reg &= ~(DSPDMAC_CHNLSTART_EN_MASK | | 1839 | reg &= ~(DSPDMAC_CHNLSTART_EN_MASK | |
1840 | DSPDMAC_CHNLSTART_DIS_MASK); | 1840 | DSPDMAC_CHNLSTART_DIS_MASK); |
@@ -1843,10 +1843,10 @@ static int dsp_dma_start(struct hda_codec *codec, | |||
1843 | status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, | 1843 | status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, |
1844 | reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_EN_LOBIT))); | 1844 | reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_EN_LOBIT))); |
1845 | if (status < 0) { | 1845 | if (status < 0) { |
1846 | snd_printdd(KERN_ERR "write CHNLSTART reg fail"); | 1846 | snd_printdd(KERN_ERR "write CHNLSTART reg fail\n"); |
1847 | return status; | 1847 | return status; |
1848 | } | 1848 | } |
1849 | snd_printdd(KERN_INFO "-- dsp_dma_start() -- Complete ---------"); | 1849 | snd_printdd(KERN_INFO "-- dsp_dma_start() -- Complete ---------\n"); |
1850 | 1850 | ||
1851 | return status; | 1851 | return status; |
1852 | } | 1852 | } |
@@ -1860,17 +1860,17 @@ static int dsp_dma_stop(struct hda_codec *codec, | |||
1860 | unsigned int reg = 0; | 1860 | unsigned int reg = 0; |
1861 | int status = 0; | 1861 | int status = 0; |
1862 | 1862 | ||
1863 | snd_printdd(KERN_INFO "-- dsp_dma_stop() -- Begin ---------"); | 1863 | snd_printdd(KERN_INFO "-- dsp_dma_stop() -- Begin ---------\n"); |
1864 | 1864 | ||
1865 | if (ovly) { | 1865 | if (ovly) { |
1866 | status = chipio_read(codec, | 1866 | status = chipio_read(codec, |
1867 | DSPDMAC_CHNLSTART_INST_OFFSET, ®); | 1867 | DSPDMAC_CHNLSTART_INST_OFFSET, ®); |
1868 | 1868 | ||
1869 | if (status < 0) { | 1869 | if (status < 0) { |
1870 | snd_printdd(KERN_ERR "read CHNLSTART reg fail"); | 1870 | snd_printdd(KERN_ERR "read CHNLSTART reg fail\n"); |
1871 | return status; | 1871 | return status; |
1872 | } | 1872 | } |
1873 | snd_printdd(KERN_INFO "-- dsp_dma_stop() Read CHNLSTART"); | 1873 | snd_printdd(KERN_INFO "-- dsp_dma_stop() Read CHNLSTART\n"); |
1874 | reg &= ~(DSPDMAC_CHNLSTART_EN_MASK | | 1874 | reg &= ~(DSPDMAC_CHNLSTART_EN_MASK | |
1875 | DSPDMAC_CHNLSTART_DIS_MASK); | 1875 | DSPDMAC_CHNLSTART_DIS_MASK); |
1876 | } | 1876 | } |
@@ -1878,10 +1878,10 @@ static int dsp_dma_stop(struct hda_codec *codec, | |||
1878 | status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, | 1878 | status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, |
1879 | reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_DIS_LOBIT))); | 1879 | reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_DIS_LOBIT))); |
1880 | if (status < 0) { | 1880 | if (status < 0) { |
1881 | snd_printdd(KERN_ERR "write CHNLSTART reg fail"); | 1881 | snd_printdd(KERN_ERR "write CHNLSTART reg fail\n"); |
1882 | return status; | 1882 | return status; |
1883 | } | 1883 | } |
1884 | snd_printdd(KERN_INFO "-- dsp_dma_stop() -- Complete ---------"); | 1884 | snd_printdd(KERN_INFO "-- dsp_dma_stop() -- Complete ---------\n"); |
1885 | 1885 | ||
1886 | return status; | 1886 | return status; |
1887 | } | 1887 | } |
@@ -1964,17 +1964,17 @@ static int dsp_allocate_ports(struct hda_codec *codec, | |||
1964 | { | 1964 | { |
1965 | int status; | 1965 | int status; |
1966 | 1966 | ||
1967 | snd_printdd(KERN_INFO " dsp_allocate_ports() -- begin"); | 1967 | snd_printdd(KERN_INFO " dsp_allocate_ports() -- begin\n"); |
1968 | 1968 | ||
1969 | if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) { | 1969 | if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) { |
1970 | snd_printdd(KERN_ERR "bad rate multiple"); | 1970 | snd_printdd(KERN_ERR "bad rate multiple\n"); |
1971 | return -EINVAL; | 1971 | return -EINVAL; |
1972 | } | 1972 | } |
1973 | 1973 | ||
1974 | status = dsp_allocate_router_ports(codec, num_chans, | 1974 | status = dsp_allocate_router_ports(codec, num_chans, |
1975 | rate_multi, 0, port_map); | 1975 | rate_multi, 0, port_map); |
1976 | 1976 | ||
1977 | snd_printdd(KERN_INFO " dsp_allocate_ports() -- complete"); | 1977 | snd_printdd(KERN_INFO " dsp_allocate_ports() -- complete\n"); |
1978 | 1978 | ||
1979 | return status; | 1979 | return status; |
1980 | } | 1980 | } |
@@ -1991,7 +1991,7 @@ static int dsp_allocate_ports_format(struct hda_codec *codec, | |||
1991 | unsigned int rate_multi = sample_rate_mul / sample_rate_div; | 1991 | unsigned int rate_multi = sample_rate_mul / sample_rate_div; |
1992 | 1992 | ||
1993 | if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) { | 1993 | if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) { |
1994 | snd_printdd(KERN_ERR "bad rate multiple"); | 1994 | snd_printdd(KERN_ERR "bad rate multiple\n"); |
1995 | return -EINVAL; | 1995 | return -EINVAL; |
1996 | } | 1996 | } |
1997 | 1997 | ||
@@ -2009,14 +2009,14 @@ static int dsp_free_ports(struct hda_codec *codec) | |||
2009 | { | 2009 | { |
2010 | int status; | 2010 | int status; |
2011 | 2011 | ||
2012 | snd_printdd(KERN_INFO " dsp_free_ports() -- begin"); | 2012 | snd_printdd(KERN_INFO " dsp_free_ports() -- begin\n"); |
2013 | 2013 | ||
2014 | status = dsp_free_router_ports(codec); | 2014 | status = dsp_free_router_ports(codec); |
2015 | if (status < 0) { | 2015 | if (status < 0) { |
2016 | snd_printdd(KERN_ERR "free router ports fail"); | 2016 | snd_printdd(KERN_ERR "free router ports fail\n"); |
2017 | return status; | 2017 | return status; |
2018 | } | 2018 | } |
2019 | snd_printdd(KERN_INFO " dsp_free_ports() -- complete"); | 2019 | snd_printdd(KERN_INFO " dsp_free_ports() -- complete\n"); |
2020 | 2020 | ||
2021 | return status; | 2021 | return status; |
2022 | } | 2022 | } |
@@ -2186,7 +2186,7 @@ static int dspxfr_hci_write(struct hda_codec *codec, | |||
2186 | unsigned int count; | 2186 | unsigned int count; |
2187 | 2187 | ||
2188 | if (fls == NULL || fls->chip_addr != g_chip_addr_magic_value) { | 2188 | if (fls == NULL || fls->chip_addr != g_chip_addr_magic_value) { |
2189 | snd_printdd(KERN_ERR "hci_write invalid params"); | 2189 | snd_printdd(KERN_ERR "hci_write invalid params\n"); |
2190 | return -EINVAL; | 2190 | return -EINVAL; |
2191 | } | 2191 | } |
2192 | 2192 | ||
@@ -2195,7 +2195,7 @@ static int dspxfr_hci_write(struct hda_codec *codec, | |||
2195 | while (count >= 2) { | 2195 | while (count >= 2) { |
2196 | status = chipio_write(codec, data[0], data[1]); | 2196 | status = chipio_write(codec, data[0], data[1]); |
2197 | if (status < 0) { | 2197 | if (status < 0) { |
2198 | snd_printdd(KERN_ERR "hci_write chipio failed"); | 2198 | snd_printdd(KERN_ERR "hci_write chipio failed\n"); |
2199 | return status; | 2199 | return status; |
2200 | } | 2200 | } |
2201 | count -= 2; | 2201 | count -= 2; |
@@ -2346,7 +2346,7 @@ static int dspxfr_one_seg(struct hda_codec *codec, | |||
2346 | if (status < 0) | 2346 | if (status < 0) |
2347 | return status; | 2347 | return status; |
2348 | if (!dsp_is_dma_active(codec, dma_chan)) { | 2348 | if (!dsp_is_dma_active(codec, dma_chan)) { |
2349 | snd_printdd(KERN_ERR "dspxfr:DMA did not start"); | 2349 | snd_printdd(KERN_ERR "dspxfr:DMA did not start\n"); |
2350 | return -EIO; | 2350 | return -EIO; |
2351 | } | 2351 | } |
2352 | status = dma_set_state(dma_engine, DMA_STATE_RUN); | 2352 | status = dma_set_state(dma_engine, DMA_STATE_RUN); |
@@ -2378,7 +2378,7 @@ static int dspxfr_one_seg(struct hda_codec *codec, | |||
2378 | if (dma_active) | 2378 | if (dma_active) |
2379 | break; | 2379 | break; |
2380 | 2380 | ||
2381 | snd_printdd(KERN_INFO "+++++ DMA complete"); | 2381 | snd_printdd(KERN_INFO "+++++ DMA complete\n"); |
2382 | dma_set_state(dma_engine, DMA_STATE_STOP); | 2382 | dma_set_state(dma_engine, DMA_STATE_STOP); |
2383 | status = dma_reset(dma_engine); | 2383 | status = dma_reset(dma_engine); |
2384 | 2384 | ||
@@ -2452,7 +2452,7 @@ static int dspxfr_image(struct hda_codec *codec, | |||
2452 | hda_format, &response); | 2452 | hda_format, &response); |
2453 | 2453 | ||
2454 | if (status < 0) { | 2454 | if (status < 0) { |
2455 | snd_printdd(KERN_ERR "set converter format fail"); | 2455 | snd_printdd(KERN_ERR "set converter format fail\n"); |
2456 | goto exit; | 2456 | goto exit; |
2457 | } | 2457 | } |
2458 | 2458 | ||
@@ -2467,7 +2467,7 @@ static int dspxfr_image(struct hda_codec *codec, | |||
2467 | if (ovly) { | 2467 | if (ovly) { |
2468 | status = dspio_alloc_dma_chan(codec, &dma_chan); | 2468 | status = dspio_alloc_dma_chan(codec, &dma_chan); |
2469 | if (status < 0) { | 2469 | if (status < 0) { |
2470 | snd_printdd(KERN_ERR "alloc dmachan fail"); | 2470 | snd_printdd(KERN_ERR "alloc dmachan fail\n"); |
2471 | dma_chan = INVALID_DMA_CHANNEL; | 2471 | dma_chan = INVALID_DMA_CHANNEL; |
2472 | goto exit; | 2472 | goto exit; |
2473 | } | 2473 | } |
@@ -2477,7 +2477,7 @@ static int dspxfr_image(struct hda_codec *codec, | |||
2477 | status = dsp_allocate_ports_format(codec, hda_format, | 2477 | status = dsp_allocate_ports_format(codec, hda_format, |
2478 | &port_map_mask); | 2478 | &port_map_mask); |
2479 | if (status < 0) { | 2479 | if (status < 0) { |
2480 | snd_printdd(KERN_ERR "alloc ports fail"); | 2480 | snd_printdd(KERN_ERR "alloc ports fail\n"); |
2481 | goto exit; | 2481 | goto exit; |
2482 | } | 2482 | } |
2483 | 2483 | ||
@@ -2485,13 +2485,13 @@ static int dspxfr_image(struct hda_codec *codec, | |||
2485 | status = codec_set_converter_stream_channel(codec, | 2485 | status = codec_set_converter_stream_channel(codec, |
2486 | WIDGET_CHIP_CTRL, stream_id, 0, &response); | 2486 | WIDGET_CHIP_CTRL, stream_id, 0, &response); |
2487 | if (status < 0) { | 2487 | if (status < 0) { |
2488 | snd_printdd(KERN_ERR "set stream chan fail"); | 2488 | snd_printdd(KERN_ERR "set stream chan fail\n"); |
2489 | goto exit; | 2489 | goto exit; |
2490 | } | 2490 | } |
2491 | 2491 | ||
2492 | while ((fls_data != NULL) && !is_last(fls_data)) { | 2492 | while ((fls_data != NULL) && !is_last(fls_data)) { |
2493 | if (!is_valid(fls_data)) { | 2493 | if (!is_valid(fls_data)) { |
2494 | snd_printdd(KERN_ERR "FLS check fail"); | 2494 | snd_printdd(KERN_ERR "FLS check fail\n"); |
2495 | status = -EINVAL; | 2495 | status = -EINVAL; |
2496 | goto exit; | 2496 | goto exit; |
2497 | } | 2497 | } |
@@ -2534,7 +2534,7 @@ exit: | |||
2534 | */ | 2534 | */ |
2535 | static void dspload_post_setup(struct hda_codec *codec) | 2535 | static void dspload_post_setup(struct hda_codec *codec) |
2536 | { | 2536 | { |
2537 | snd_printdd(KERN_INFO "---- dspload_post_setup ------"); | 2537 | snd_printdd(KERN_INFO "---- dspload_post_setup ------\n"); |
2538 | 2538 | ||
2539 | /*set DSP speaker to 2.0 configuration*/ | 2539 | /*set DSP speaker to 2.0 configuration*/ |
2540 | chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x18), 0x08080080); | 2540 | chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x18), 0x08080080); |
@@ -2572,7 +2572,7 @@ static int dspload_image(struct hda_codec *codec, | |||
2572 | unsigned int sample_rate; | 2572 | unsigned int sample_rate; |
2573 | unsigned short channels; | 2573 | unsigned short channels; |
2574 | 2574 | ||
2575 | snd_printdd(KERN_INFO "---- dspload_image begin ------"); | 2575 | snd_printdd(KERN_INFO "---- dspload_image begin ------\n"); |
2576 | if (router_chans == 0) { | 2576 | if (router_chans == 0) { |
2577 | if (!ovly) | 2577 | if (!ovly) |
2578 | router_chans = DMA_TRANSFER_FRAME_SIZE_NWORDS; | 2578 | router_chans = DMA_TRANSFER_FRAME_SIZE_NWORDS; |
@@ -2589,27 +2589,27 @@ static int dspload_image(struct hda_codec *codec, | |||
2589 | } | 2589 | } |
2590 | 2590 | ||
2591 | do { | 2591 | do { |
2592 | snd_printdd(KERN_INFO "Ready to program DMA"); | 2592 | snd_printdd(KERN_INFO "Ready to program DMA\n"); |
2593 | if (!ovly) | 2593 | if (!ovly) |
2594 | status = dsp_reset(codec); | 2594 | status = dsp_reset(codec); |
2595 | 2595 | ||
2596 | if (status < 0) | 2596 | if (status < 0) |
2597 | break; | 2597 | break; |
2598 | 2598 | ||
2599 | snd_printdd(KERN_INFO "dsp_reset() complete"); | 2599 | snd_printdd(KERN_INFO "dsp_reset() complete\n"); |
2600 | status = dspxfr_image(codec, fls, reloc, sample_rate, channels, | 2600 | status = dspxfr_image(codec, fls, reloc, sample_rate, channels, |
2601 | ovly); | 2601 | ovly); |
2602 | 2602 | ||
2603 | if (status < 0) | 2603 | if (status < 0) |
2604 | break; | 2604 | break; |
2605 | 2605 | ||
2606 | snd_printdd(KERN_INFO "dspxfr_image() complete"); | 2606 | snd_printdd(KERN_INFO "dspxfr_image() complete\n"); |
2607 | if (autostart && !ovly) { | 2607 | if (autostart && !ovly) { |
2608 | dspload_post_setup(codec); | 2608 | dspload_post_setup(codec); |
2609 | status = dsp_set_run_state(codec); | 2609 | status = dsp_set_run_state(codec); |
2610 | } | 2610 | } |
2611 | 2611 | ||
2612 | snd_printdd(KERN_INFO "LOAD FINISHED"); | 2612 | snd_printdd(KERN_INFO "LOAD FINISHED\n"); |
2613 | } while (0); | 2613 | } while (0); |
2614 | 2614 | ||
2615 | return status; | 2615 | return status; |