Lines Matching full:codec

1135 	struct hda_codec *codec;  member
1181 #define ca0132_quirk(spec) ((spec)->codec->fixup_id)
1525 * CA0132 codec access
1527 static unsigned int codec_send_command(struct hda_codec *codec, hda_nid_t nid, in codec_send_command() argument
1531 response = snd_hda_codec_read(codec, nid, 0, verb, parm); in codec_send_command()
1537 static int codec_set_converter_format(struct hda_codec *codec, hda_nid_t nid, in codec_set_converter_format() argument
1540 return codec_send_command(codec, nid, VENDOR_CHIPIO_STREAM_FORMAT, in codec_set_converter_format()
1544 static int codec_set_converter_stream_channel(struct hda_codec *codec, in codec_set_converter_stream_channel() argument
1551 return codec_send_command(codec, nid, AC_VERB_SET_CHANNEL_STREAMID, in codec_set_converter_stream_channel()
1556 static int chipio_send(struct hda_codec *codec, in chipio_send() argument
1565 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_send()
1578 static int chipio_write_address(struct hda_codec *codec, in chipio_write_address() argument
1581 struct ca0132_spec *spec = codec->spec; in chipio_write_address()
1588 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_LOW, in chipio_write_address()
1593 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_HIGH, in chipio_write_address()
1605 static int chipio_write_data(struct hda_codec *codec, unsigned int data) in chipio_write_data() argument
1607 struct ca0132_spec *spec = codec->spec; in chipio_write_data()
1611 res = chipio_send(codec, VENDOR_CHIPIO_DATA_LOW, data & 0xffff); in chipio_write_data()
1615 res = chipio_send(codec, VENDOR_CHIPIO_DATA_HIGH, in chipio_write_data()
1629 static int chipio_write_data_multiple(struct hda_codec *codec, in chipio_write_data_multiple() argument
1636 codec_dbg(codec, "chipio_write_data null ptr\n"); in chipio_write_data_multiple()
1641 status = chipio_write_data(codec, *data++); in chipio_write_data_multiple()
1650 static int chipio_read_data(struct hda_codec *codec, unsigned int *data) in chipio_read_data() argument
1652 struct ca0132_spec *spec = codec->spec; in chipio_read_data()
1656 res = chipio_send(codec, VENDOR_CHIPIO_HIC_POST_READ, 0); in chipio_read_data()
1660 res = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in chipio_read_data()
1665 *data = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_read_data()
1681 static int chipio_write(struct hda_codec *codec, in chipio_write() argument
1684 struct ca0132_spec *spec = codec->spec; in chipio_write()
1690 err = chipio_write_address(codec, chip_addx); in chipio_write()
1694 err = chipio_write_data(codec, data); in chipio_write()
1707 static int chipio_write_no_mutex(struct hda_codec *codec, in chipio_write_no_mutex() argument
1714 err = chipio_write_address(codec, chip_addx); in chipio_write_no_mutex()
1718 err = chipio_write_data(codec, data); in chipio_write_no_mutex()
1730 static int chipio_write_multiple(struct hda_codec *codec, in chipio_write_multiple() argument
1735 struct ca0132_spec *spec = codec->spec; in chipio_write_multiple()
1739 status = chipio_write_address(codec, chip_addx); in chipio_write_multiple()
1743 status = chipio_write_data_multiple(codec, data, count); in chipio_write_multiple()
1754 static int chipio_read(struct hda_codec *codec, in chipio_read() argument
1757 struct ca0132_spec *spec = codec->spec; in chipio_read()
1763 err = chipio_write_address(codec, chip_addx); in chipio_read()
1767 err = chipio_read_data(codec, data); in chipio_read()
1779 static void chipio_set_control_flag(struct hda_codec *codec, in chipio_set_control_flag() argument
1788 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_flag()
1795 static void chipio_set_control_param(struct hda_codec *codec, in chipio_set_control_param() argument
1798 struct ca0132_spec *spec = codec->spec; in chipio_set_control_param()
1803 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param()
1807 if (chipio_send(codec, VENDOR_CHIPIO_STATUS, 0) == 0) { in chipio_set_control_param()
1808 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param()
1811 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param()
1822 static void chipio_set_control_param_no_mutex(struct hda_codec *codec, in chipio_set_control_param_no_mutex() argument
1829 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param_no_mutex()
1832 if (chipio_send(codec, VENDOR_CHIPIO_STATUS, 0) == 0) { in chipio_set_control_param_no_mutex()
1833 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param_no_mutex()
1836 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_set_control_param_no_mutex()
1846 static void chipio_set_stream_source_dest(struct hda_codec *codec, in chipio_set_stream_source_dest() argument
1849 chipio_set_control_param_no_mutex(codec, in chipio_set_stream_source_dest()
1851 chipio_set_control_param_no_mutex(codec, in chipio_set_stream_source_dest()
1853 chipio_set_control_param_no_mutex(codec, in chipio_set_stream_source_dest()
1860 static void chipio_set_stream_channels(struct hda_codec *codec, in chipio_set_stream_channels() argument
1863 chipio_set_control_param_no_mutex(codec, in chipio_set_stream_channels()
1865 chipio_set_control_param_no_mutex(codec, in chipio_set_stream_channels()
1872 static void chipio_set_stream_control(struct hda_codec *codec, in chipio_set_stream_control() argument
1875 chipio_set_control_param_no_mutex(codec, in chipio_set_stream_control()
1877 chipio_set_control_param_no_mutex(codec, in chipio_set_stream_control()
1884 static void chipio_get_stream_control(struct hda_codec *codec, in chipio_get_stream_control() argument
1887 chipio_set_control_param_no_mutex(codec, in chipio_get_stream_control()
1889 *enable = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_get_stream_control()
1897 static void chipio_set_conn_rate_no_mutex(struct hda_codec *codec, in chipio_set_conn_rate_no_mutex() argument
1900 chipio_set_control_param_no_mutex(codec, in chipio_set_conn_rate_no_mutex()
1902 chipio_set_control_param_no_mutex(codec, in chipio_set_conn_rate_no_mutex()
1909 static void chipio_set_conn_rate(struct hda_codec *codec, in chipio_set_conn_rate() argument
1912 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_ID, connid); in chipio_set_conn_rate()
1913 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_SAMPLE_RATE, in chipio_set_conn_rate()
1922 static void chipio_8051_write_direct(struct hda_codec *codec, in chipio_8051_write_direct() argument
1928 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, verb, addr); in chipio_8051_write_direct()
1939 static void chipio_8051_set_address(struct hda_codec *codec, unsigned int addr) in chipio_8051_set_address() argument
1945 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_address()
1950 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_address()
1954 static void chipio_8051_set_data(struct hda_codec *codec, unsigned int data) in chipio_8051_set_data() argument
1957 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_data()
1961 static unsigned int chipio_8051_get_data(struct hda_codec *codec) in chipio_8051_get_data() argument
1963 return snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_get_data()
1968 static void chipio_8051_set_data_pll(struct hda_codec *codec, unsigned int data) in chipio_8051_set_data_pll() argument
1971 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in chipio_8051_set_data_pll()
1975 static void chipio_8051_write_exram(struct hda_codec *codec, in chipio_8051_write_exram() argument
1978 struct ca0132_spec *spec = codec->spec; in chipio_8051_write_exram()
1982 chipio_8051_set_address(codec, addr); in chipio_8051_write_exram()
1983 chipio_8051_set_data(codec, data); in chipio_8051_write_exram()
1988 static void chipio_8051_write_exram_no_mutex(struct hda_codec *codec, in chipio_8051_write_exram_no_mutex() argument
1991 chipio_8051_set_address(codec, addr); in chipio_8051_write_exram_no_mutex()
1992 chipio_8051_set_data(codec, data); in chipio_8051_write_exram_no_mutex()
1996 static void chipio_8051_read_exram(struct hda_codec *codec, in chipio_8051_read_exram() argument
1999 chipio_8051_set_address(codec, addr); in chipio_8051_read_exram()
2000 *data = chipio_8051_get_data(codec); in chipio_8051_read_exram()
2003 static void chipio_8051_write_pll_pmu(struct hda_codec *codec, in chipio_8051_write_pll_pmu() argument
2006 struct ca0132_spec *spec = codec->spec; in chipio_8051_write_pll_pmu()
2010 chipio_8051_set_address(codec, addr & 0xff); in chipio_8051_write_pll_pmu()
2011 chipio_8051_set_data_pll(codec, data); in chipio_8051_write_pll_pmu()
2016 static void chipio_8051_write_pll_pmu_no_mutex(struct hda_codec *codec, in chipio_8051_write_pll_pmu_no_mutex() argument
2019 chipio_8051_set_address(codec, addr & 0xff); in chipio_8051_write_pll_pmu_no_mutex()
2020 chipio_8051_set_data_pll(codec, data); in chipio_8051_write_pll_pmu_no_mutex()
2026 static void chipio_enable_clocks(struct hda_codec *codec) in chipio_enable_clocks() argument
2028 struct ca0132_spec *spec = codec->spec; in chipio_enable_clocks()
2032 chipio_8051_write_pll_pmu_no_mutex(codec, 0x00, 0xff); in chipio_enable_clocks()
2033 chipio_8051_write_pll_pmu_no_mutex(codec, 0x05, 0x0b); in chipio_enable_clocks()
2034 chipio_8051_write_pll_pmu_no_mutex(codec, 0x06, 0xff); in chipio_enable_clocks()
2042 static int dspio_send(struct hda_codec *codec, unsigned int reg, in dspio_send() argument
2050 res = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, reg, data); in dspio_send()
2062 static void dspio_write_wait(struct hda_codec *codec) in dspio_write_wait() argument
2068 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, in dspio_write_wait()
2080 static int dspio_write(struct hda_codec *codec, unsigned int scp_data) in dspio_write() argument
2082 struct ca0132_spec *spec = codec->spec; in dspio_write()
2085 dspio_write_wait(codec); in dspio_write()
2088 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_LOW, in dspio_write()
2093 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_HIGH, in dspio_write()
2099 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, in dspio_write()
2111 static int dspio_write_multiple(struct hda_codec *codec, in dspio_write_multiple() argument
2122 status = dspio_write(codec, *buffer++); in dspio_write_multiple()
2131 static int dspio_read(struct hda_codec *codec, unsigned int *data) in dspio_read() argument
2135 status = dspio_send(codec, VENDOR_DSPIO_SCP_POST_READ_DATA, 0); in dspio_read()
2139 status = dspio_send(codec, VENDOR_DSPIO_STATUS, 0); in dspio_read()
2144 *data = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, in dspio_read()
2150 static int dspio_read_multiple(struct hda_codec *codec, unsigned int *buffer, in dspio_read_multiple() argument
2164 status = dspio_read(codec, buffer++); in dspio_read_multiple()
2173 status = dspio_read(codec, &dummy); in dspio_read_multiple()
2243 static void dspio_clear_response_queue(struct hda_codec *codec) in dspio_clear_response_queue() argument
2251 status = dspio_read(codec, &dummy); in dspio_clear_response_queue()
2255 static int dspio_get_response_data(struct hda_codec *codec) in dspio_get_response_data() argument
2257 struct ca0132_spec *spec = codec->spec; in dspio_get_response_data()
2261 if (dspio_read(codec, &data) < 0) in dspio_get_response_data()
2268 dspio_read_multiple(codec, spec->scp_resp_data, in dspio_get_response_data()
2279 static int dspio_send_scp_message(struct hda_codec *codec, in dspio_send_scp_message() argument
2286 struct ca0132_spec *spec = codec->spec; in dspio_send_scp_message()
2325 status = dspio_write_multiple(codec, (unsigned int *)send_buf, in dspio_send_scp_message()
2357 * @codec: the HDA codec
2369 static int dspio_scp(struct hda_codec *codec, in dspio_scp() argument
2386 codec_dbg(codec, "dspio_scp get but has no buffer\n"); in dspio_scp()
2391 codec_dbg(codec, "dspio_scp bad resp buf len parms\n"); in dspio_scp()
2404 status = dspio_send_scp_message(codec, (unsigned char *)&scp_send, in dspio_scp()
2409 codec_dbg(codec, "dspio_scp: send scp msg failed\n"); in dspio_scp()
2428 codec_dbg(codec, "reply too long for buf\n"); in dspio_scp()
2431 codec_dbg(codec, "RetLen and HdrLen .NE.\n"); in dspio_scp()
2434 codec_dbg(codec, "NULL reply\n"); in dspio_scp()
2441 codec_dbg(codec, "reply ill-formed or errflag set\n"); in dspio_scp()
2451 static int dspio_set_param(struct hda_codec *codec, int mod_id, in dspio_set_param() argument
2454 return dspio_scp(codec, mod_id, src_id, req, SCP_SET, data, len, NULL, in dspio_set_param()
2458 static int dspio_set_uint_param(struct hda_codec *codec, int mod_id, in dspio_set_uint_param() argument
2461 return dspio_set_param(codec, mod_id, 0x20, req, &data, in dspio_set_uint_param()
2468 static int dspio_alloc_dma_chan(struct hda_codec *codec, unsigned int *dma_chan) in dspio_alloc_dma_chan() argument
2473 codec_dbg(codec, " dspio_alloc_dma_chan() -- begin\n"); in dspio_alloc_dma_chan()
2474 status = dspio_scp(codec, MASTERCONTROL, 0x20, in dspio_alloc_dma_chan()
2479 codec_dbg(codec, "dspio_alloc_dma_chan: SCP Failed\n"); in dspio_alloc_dma_chan()
2484 codec_dbg(codec, "no free dma channels to allocate\n"); in dspio_alloc_dma_chan()
2488 codec_dbg(codec, "dspio_alloc_dma_chan: chan=%d\n", *dma_chan); in dspio_alloc_dma_chan()
2489 codec_dbg(codec, " dspio_alloc_dma_chan() -- complete\n"); in dspio_alloc_dma_chan()
2497 static int dspio_free_dma_chan(struct hda_codec *codec, unsigned int dma_chan) in dspio_free_dma_chan() argument
2502 codec_dbg(codec, " dspio_free_dma_chan() -- begin\n"); in dspio_free_dma_chan()
2503 codec_dbg(codec, "dspio_free_dma_chan: chan=%d\n", dma_chan); in dspio_free_dma_chan()
2505 status = dspio_scp(codec, MASTERCONTROL, 0x20, in dspio_free_dma_chan()
2510 codec_dbg(codec, "dspio_free_dma_chan: SCP Failed\n"); in dspio_free_dma_chan()
2514 codec_dbg(codec, " dspio_free_dma_chan() -- complete\n"); in dspio_free_dma_chan()
2522 static int dsp_set_run_state(struct hda_codec *codec) in dsp_set_run_state() argument
2528 err = chipio_read(codec, DSP_DBGCNTL_INST_OFFSET, &dbg_ctrl_reg); in dsp_set_run_state()
2538 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET, in dsp_set_run_state()
2545 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET, in dsp_set_run_state()
2557 static int dsp_reset(struct hda_codec *codec) in dsp_reset() argument
2562 codec_dbg(codec, "dsp_reset\n"); in dsp_reset()
2564 res = dspio_send(codec, VENDOR_DSPIO_DSP_INIT, 0); in dsp_reset()
2569 codec_dbg(codec, "dsp_reset timeout\n"); in dsp_reset()
2600 static bool dsp_is_dma_active(struct hda_codec *codec, unsigned int dma_chan) in dsp_is_dma_active() argument
2604 chipio_read(codec, DSPDMAC_CHNLSTART_INST_OFFSET, &dma_chnlstart_reg); in dsp_is_dma_active()
2610 static int dsp_dma_setup_common(struct hda_codec *codec, in dsp_dma_setup_common() argument
2622 codec_dbg(codec, "-- dsp_dma_setup_common() -- Begin ---------\n"); in dsp_dma_setup_common()
2625 codec_dbg(codec, "dma chan num invalid\n"); in dsp_dma_setup_common()
2629 if (dsp_is_dma_active(codec, dma_chan)) { in dsp_dma_setup_common()
2630 codec_dbg(codec, "dma already active\n"); in dsp_dma_setup_common()
2637 codec_dbg(codec, "invalid chip addr\n"); in dsp_dma_setup_common()
2644 codec_dbg(codec, " dsp_dma_setup_common() start reg pgm\n"); in dsp_dma_setup_common()
2647 status = chipio_read(codec, DSPDMAC_CHNLPROP_INST_OFFSET, in dsp_dma_setup_common()
2651 codec_dbg(codec, "read CHNLPROP Reg fail\n"); in dsp_dma_setup_common()
2654 codec_dbg(codec, "dsp_dma_setup_common() Read CHNLPROP\n"); in dsp_dma_setup_common()
2664 status = chipio_write(codec, DSPDMAC_CHNLPROP_INST_OFFSET, chnl_prop); in dsp_dma_setup_common()
2666 codec_dbg(codec, "write CHNLPROP Reg fail\n"); in dsp_dma_setup_common()
2669 codec_dbg(codec, " dsp_dma_setup_common() Write CHNLPROP\n"); in dsp_dma_setup_common()
2672 status = chipio_read(codec, DSPDMAC_ACTIVE_INST_OFFSET, in dsp_dma_setup_common()
2676 codec_dbg(codec, "read ACTIVE Reg fail\n"); in dsp_dma_setup_common()
2679 codec_dbg(codec, "dsp_dma_setup_common() Read ACTIVE\n"); in dsp_dma_setup_common()
2685 status = chipio_write(codec, DSPDMAC_ACTIVE_INST_OFFSET, active); in dsp_dma_setup_common()
2687 codec_dbg(codec, "write ACTIVE Reg fail\n"); in dsp_dma_setup_common()
2691 codec_dbg(codec, " dsp_dma_setup_common() Write ACTIVE\n"); in dsp_dma_setup_common()
2693 status = chipio_write(codec, DSPDMAC_AUDCHSEL_INST_OFFSET(dma_chan), in dsp_dma_setup_common()
2696 codec_dbg(codec, "write AUDCHSEL Reg fail\n"); in dsp_dma_setup_common()
2699 codec_dbg(codec, " dsp_dma_setup_common() Write AUDCHSEL\n"); in dsp_dma_setup_common()
2701 status = chipio_write(codec, DSPDMAC_IRQCNT_INST_OFFSET(dma_chan), in dsp_dma_setup_common()
2704 codec_dbg(codec, "write IRQCNT Reg fail\n"); in dsp_dma_setup_common()
2707 codec_dbg(codec, " dsp_dma_setup_common() Write IRQCNT\n"); in dsp_dma_setup_common()
2709 codec_dbg(codec, in dsp_dma_setup_common()
2715 codec_dbg(codec, "-- dsp_dma_setup_common() -- Complete ------\n"); in dsp_dma_setup_common()
2723 static int dsp_dma_setup(struct hda_codec *codec, in dsp_dma_setup() argument
2741 codec_dbg(codec, "-- dsp_dma_setup() -- Begin ---------\n"); in dsp_dma_setup()
2744 codec_dbg(codec, "count too big\n"); in dsp_dma_setup()
2750 codec_dbg(codec, "invalid chip addr\n"); in dsp_dma_setup()
2754 codec_dbg(codec, " dsp_dma_setup() start reg pgm\n"); in dsp_dma_setup()
2768 status = chipio_write(codec, DSPDMAC_DMACFG_INST_OFFSET(dma_chan), in dsp_dma_setup()
2771 codec_dbg(codec, "write DMACFG Reg fail\n"); in dsp_dma_setup()
2774 codec_dbg(codec, " dsp_dma_setup() Write DMACFG\n"); in dsp_dma_setup()
2779 status = chipio_write(codec, DSPDMAC_DSPADROFS_INST_OFFSET(dma_chan), in dsp_dma_setup()
2782 codec_dbg(codec, "write DSPADROFS Reg fail\n"); in dsp_dma_setup()
2785 codec_dbg(codec, " dsp_dma_setup() Write DSPADROFS\n"); in dsp_dma_setup()
2793 status = chipio_write(codec, in dsp_dma_setup()
2796 codec_dbg(codec, "write XFRCNT Reg fail\n"); in dsp_dma_setup()
2799 codec_dbg(codec, " dsp_dma_setup() Write XFRCNT\n"); in dsp_dma_setup()
2801 codec_dbg(codec, in dsp_dma_setup()
2806 codec_dbg(codec, "-- dsp_dma_setup() -- Complete ---------\n"); in dsp_dma_setup()
2814 static int dsp_dma_start(struct hda_codec *codec, in dsp_dma_start() argument
2820 codec_dbg(codec, "-- dsp_dma_start() -- Begin ---------\n"); in dsp_dma_start()
2823 status = chipio_read(codec, in dsp_dma_start()
2827 codec_dbg(codec, "read CHNLSTART reg fail\n"); in dsp_dma_start()
2830 codec_dbg(codec, "-- dsp_dma_start() Read CHNLSTART\n"); in dsp_dma_start()
2836 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, in dsp_dma_start()
2839 codec_dbg(codec, "write CHNLSTART reg fail\n"); in dsp_dma_start()
2842 codec_dbg(codec, "-- dsp_dma_start() -- Complete ---------\n"); in dsp_dma_start()
2850 static int dsp_dma_stop(struct hda_codec *codec, in dsp_dma_stop() argument
2856 codec_dbg(codec, "-- dsp_dma_stop() -- Begin ---------\n"); in dsp_dma_stop()
2859 status = chipio_read(codec, in dsp_dma_stop()
2863 codec_dbg(codec, "read CHNLSTART reg fail\n"); in dsp_dma_stop()
2866 codec_dbg(codec, "-- dsp_dma_stop() Read CHNLSTART\n"); in dsp_dma_stop()
2871 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, in dsp_dma_stop()
2874 codec_dbg(codec, "write CHNLSTART reg fail\n"); in dsp_dma_stop()
2877 codec_dbg(codec, "-- dsp_dma_stop() -- Complete ---------\n"); in dsp_dma_stop()
2885 * @codec: the HDA codec
2893 static int dsp_allocate_router_ports(struct hda_codec *codec, in dsp_allocate_router_ports() argument
2903 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_allocate_router_ports()
2911 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in dsp_allocate_router_ports()
2915 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in dsp_allocate_router_ports()
2919 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_allocate_router_ports()
2923 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, in dsp_allocate_router_ports()
2934 static int dsp_free_router_ports(struct hda_codec *codec) in dsp_free_router_ports() argument
2938 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_free_router_ports()
2942 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in dsp_free_router_ports()
2946 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); in dsp_free_router_ports()
2954 static int dsp_allocate_ports(struct hda_codec *codec, in dsp_allocate_ports() argument
2960 codec_dbg(codec, " dsp_allocate_ports() -- begin\n"); in dsp_allocate_ports()
2963 codec_dbg(codec, "bad rate multiple\n"); in dsp_allocate_ports()
2967 status = dsp_allocate_router_ports(codec, num_chans, in dsp_allocate_ports()
2970 codec_dbg(codec, " dsp_allocate_ports() -- complete\n"); in dsp_allocate_ports()
2975 static int dsp_allocate_ports_format(struct hda_codec *codec, in dsp_allocate_ports_format() argument
2986 codec_dbg(codec, "bad rate multiple\n"); in dsp_allocate_ports_format()
2992 return dsp_allocate_ports(codec, num_chans, rate_multi, port_map); in dsp_allocate_ports_format()
2998 static int dsp_free_ports(struct hda_codec *codec) in dsp_free_ports() argument
3002 codec_dbg(codec, " dsp_free_ports() -- begin\n"); in dsp_free_ports()
3004 status = dsp_free_router_ports(codec); in dsp_free_ports()
3006 codec_dbg(codec, "free router ports fail\n"); in dsp_free_ports()
3009 codec_dbg(codec, " dsp_free_ports() -- complete\n"); in dsp_free_ports()
3018 struct hda_codec *codec; member
3030 static int dma_convert_to_hda_format(struct hda_codec *codec, in dma_convert_to_hda_format() argument
3050 struct hda_codec *codec = dma->codec; in dma_reset() local
3051 struct ca0132_spec *spec = codec->spec; in dma_reset()
3055 snd_hda_codec_load_dsp_cleanup(codec, dma->dmab); in dma_reset()
3057 status = snd_hda_codec_load_dsp_prepare(codec, in dma_reset()
3082 snd_hda_codec_load_dsp_trigger(dma->codec, cmd); in dma_set_state()
3114 struct ca0132_spec *spec = dma->codec->spec; in dma_get_stream_id()
3165 static int dspxfr_hci_write(struct hda_codec *codec, in dspxfr_hci_write() argument
3173 codec_dbg(codec, "hci_write invalid params\n"); in dspxfr_hci_write()
3180 status = chipio_write(codec, data[0], data[1]); in dspxfr_hci_write()
3182 codec_dbg(codec, "hci_write chipio failed\n"); in dspxfr_hci_write()
3194 * @codec: the HDA codec
3205 static int dspxfr_one_seg(struct hda_codec *codec, in dspxfr_one_seg() argument
3241 codec_dbg(codec, "hci_write\n"); in dspxfr_one_seg()
3242 return dspxfr_hci_write(codec, hci_write); in dspxfr_one_seg()
3246 codec_dbg(codec, "Invalid Params\n"); in dspxfr_one_seg()
3255 return hci_write ? dspxfr_hci_write(codec, hci_write) : 0; in dspxfr_one_seg()
3262 codec_dbg(codec, "Invalid chip_addx Params\n"); in dspxfr_one_seg()
3272 codec_dbg(codec, "dma_engine buffer NULL\n"); in dspxfr_one_seg()
3285 codec_dbg(codec, "frmsz zero\n"); in dspxfr_one_seg()
3293 codec_dbg(codec, in dspxfr_one_seg()
3300 codec_dbg(codec, "dspxfr_one_seg:failed\n"); in dspxfr_one_seg()
3314 codec_dbg(codec, "dspxfr (seg loop)cnt=%u rs=%u remainder=%u\n", in dspxfr_one_seg()
3318 status = dsp_dma_stop(codec, dma_chan, ovly); in dspxfr_one_seg()
3321 status = dsp_dma_setup_common(codec, chip_addx, in dspxfr_one_seg()
3328 status = dsp_dma_setup(codec, chip_addx, in dspxfr_one_seg()
3332 status = dsp_dma_start(codec, dma_chan, ovly); in dspxfr_one_seg()
3335 if (!dsp_is_dma_active(codec, dma_chan)) { in dspxfr_one_seg()
3336 codec_dbg(codec, "dspxfr:DMA did not start\n"); in dspxfr_one_seg()
3343 status = chipio_write_multiple(codec, in dspxfr_one_seg()
3352 status = dspxfr_hci_write(codec, hci_write); in dspxfr_one_seg()
3360 dma_active = dsp_is_dma_active(codec, dma_chan); in dspxfr_one_seg()
3368 codec_dbg(codec, "+++++ DMA complete\n"); in dspxfr_one_seg()
3381 status = chipio_write_multiple(codec, chip_addx_remainder, in dspxfr_one_seg()
3391 * @codec: the HDA codec
3401 static int dspxfr_image(struct hda_codec *codec, in dspxfr_image() argument
3408 struct ca0132_spec *spec = codec->spec; in dspxfr_image()
3430 dma_engine->codec = codec; in dspxfr_image()
3431 dma_convert_to_hda_format(codec, sample_rate, channels, &hda_format); in dspxfr_image()
3438 status = codec_set_converter_format(codec, WIDGET_CHIP_CTRL, in dspxfr_image()
3442 codec_dbg(codec, "set converter format fail\n"); in dspxfr_image()
3446 status = snd_hda_codec_load_dsp_prepare(codec, in dspxfr_image()
3455 status = dspio_alloc_dma_chan(codec, &dma_chan); in dspxfr_image()
3457 codec_dbg(codec, "alloc dmachan fail\n"); in dspxfr_image()
3464 status = dsp_allocate_ports_format(codec, hda_format, in dspxfr_image()
3467 codec_dbg(codec, "alloc ports fail\n"); in dspxfr_image()
3472 status = codec_set_converter_stream_channel(codec, in dspxfr_image()
3475 codec_dbg(codec, "set stream chan fail\n"); in dspxfr_image()
3481 codec_dbg(codec, "FLS check fail\n"); in dspxfr_image()
3485 status = dspxfr_one_seg(codec, fls_data, reloc, in dspxfr_image()
3499 status = dsp_free_ports(codec); in dspxfr_image()
3504 status = codec_set_converter_stream_channel(codec, in dspxfr_image()
3509 dspio_free_dma_chan(codec, dma_chan); in dspxfr_image()
3512 snd_hda_codec_load_dsp_cleanup(codec, dma_engine->dmab); in dspxfr_image()
3522 static void dspload_post_setup(struct hda_codec *codec) in dspload_post_setup() argument
3524 struct ca0132_spec *spec = codec->spec; in dspload_post_setup()
3525 codec_dbg(codec, "---- dspload_post_setup ------\n"); in dspload_post_setup()
3528 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x18), 0x08080080); in dspload_post_setup()
3529 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x19), 0x3f800000); in dspload_post_setup()
3532 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x29), 0x00000002); in dspload_post_setup()
3539 * @codec: the HDA codec
3554 static int dspload_image(struct hda_codec *codec, in dspload_image() argument
3565 codec_dbg(codec, "---- dspload_image begin ------\n"); in dspload_image()
3582 codec_dbg(codec, "Ready to program DMA\n"); in dspload_image()
3584 status = dsp_reset(codec); in dspload_image()
3589 codec_dbg(codec, "dsp_reset() complete\n"); in dspload_image()
3590 status = dspxfr_image(codec, fls, reloc, sample_rate, channels, in dspload_image()
3596 codec_dbg(codec, "dspxfr_image() complete\n"); in dspload_image()
3598 dspload_post_setup(codec); in dspload_image()
3599 status = dsp_set_run_state(codec); in dspload_image()
3602 codec_dbg(codec, "LOAD FINISHED\n"); in dspload_image()
3609 static bool dspload_is_loaded(struct hda_codec *codec) in dspload_is_loaded() argument
3614 status = chipio_read(codec, 0x40004, &data); in dspload_is_loaded()
3621 #define dspload_is_loaded(codec) false argument
3624 static bool dspload_wait_loaded(struct hda_codec *codec) in dspload_wait_loaded() argument
3629 if (dspload_is_loaded(codec)) { in dspload_wait_loaded()
3630 codec_info(codec, "ca0132 DSP downloaded and running\n"); in dspload_wait_loaded()
3636 codec_err(codec, "ca0132 failed to download DSP\n"); in dspload_wait_loaded()
3655 static void ca0113_mmio_gpio_set(struct hda_codec *codec, unsigned int gpio_pin, in ca0113_mmio_gpio_set() argument
3658 struct ca0132_spec *spec = codec->spec; in ca0113_mmio_gpio_set()
3675 static void ca0113_mmio_command_set(struct hda_codec *codec, unsigned int group, in ca0113_mmio_command_set() argument
3678 struct ca0132_spec *spec = codec->spec; in ca0113_mmio_command_set()
3714 static void ca0113_mmio_command_set_type2(struct hda_codec *codec, in ca0113_mmio_command_set_type2() argument
3717 struct ca0132_spec *spec = codec->spec; in ca0113_mmio_command_set_type2()
3754 static void ca0132_gpio_init(struct hda_codec *codec) in ca0132_gpio_init() argument
3756 struct ca0132_spec *spec = codec->spec; in ca0132_gpio_init()
3762 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ca0132_gpio_init()
3763 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in ca0132_gpio_init()
3764 snd_hda_codec_write(codec, 0x01, 0, 0x790, 0x23); in ca0132_gpio_init()
3767 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ca0132_gpio_init()
3768 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x5B); in ca0132_gpio_init()
3777 static void ca0132_gpio_setup(struct hda_codec *codec) in ca0132_gpio_setup() argument
3779 struct ca0132_spec *spec = codec->spec; in ca0132_gpio_setup()
3783 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3785 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3787 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3789 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3793 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3795 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3797 snd_hda_codec_write(codec, 0x01, 0, in ca0132_gpio_setup()
3847 static void r3di_gpio_mic_set(struct hda_codec *codec, in r3di_gpio_mic_set() argument
3853 cur_gpio = snd_hda_codec_read(codec, 0x01, 0, AC_VERB_GET_GPIO_DATA, 0); in r3di_gpio_mic_set()
3863 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_mic_set()
3867 static void r3di_gpio_dsp_status_set(struct hda_codec *codec, in r3di_gpio_dsp_status_set() argument
3873 cur_gpio = snd_hda_codec_read(codec, 0x01, 0, AC_VERB_GET_GPIO_DATA, 0); in r3di_gpio_dsp_status_set()
3878 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_dsp_status_set()
3885 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_dsp_status_set()
3892 snd_hda_codec_write(codec, codec->core.afg, 0, in r3di_gpio_dsp_status_set()
3900 struct hda_codec *codec, in ca0132_playback_pcm_prepare() argument
3905 struct ca0132_spec *spec = codec->spec; in ca0132_playback_pcm_prepare()
3907 snd_hda_codec_setup_stream(codec, spec->dacs[0], stream_tag, 0, format); in ca0132_playback_pcm_prepare()
3913 struct hda_codec *codec, in ca0132_playback_pcm_cleanup() argument
3916 struct ca0132_spec *spec = codec->spec; in ca0132_playback_pcm_cleanup()
3926 snd_hda_codec_cleanup_stream(codec, spec->dacs[0]); in ca0132_playback_pcm_cleanup()
3932 struct hda_codec *codec, in ca0132_playback_pcm_delay() argument
3935 struct ca0132_spec *spec = codec->spec; in ca0132_playback_pcm_delay()
3960 struct hda_codec *codec, in ca0132_dig_playback_pcm_open() argument
3963 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_open()
3964 return snd_hda_multi_out_dig_open(codec, &spec->multiout); in ca0132_dig_playback_pcm_open()
3968 struct hda_codec *codec, in ca0132_dig_playback_pcm_prepare() argument
3973 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_prepare()
3974 return snd_hda_multi_out_dig_prepare(codec, &spec->multiout, in ca0132_dig_playback_pcm_prepare()
3979 struct hda_codec *codec, in ca0132_dig_playback_pcm_cleanup() argument
3982 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_cleanup()
3983 return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout); in ca0132_dig_playback_pcm_cleanup()
3987 struct hda_codec *codec, in ca0132_dig_playback_pcm_close() argument
3990 struct ca0132_spec *spec = codec->spec; in ca0132_dig_playback_pcm_close()
3991 return snd_hda_multi_out_dig_close(codec, &spec->multiout); in ca0132_dig_playback_pcm_close()
3998 struct hda_codec *codec, in ca0132_capture_pcm_prepare() argument
4003 snd_hda_codec_setup_stream(codec, hinfo->nid, in ca0132_capture_pcm_prepare()
4010 struct hda_codec *codec, in ca0132_capture_pcm_cleanup() argument
4013 struct ca0132_spec *spec = codec->spec; in ca0132_capture_pcm_cleanup()
4018 snd_hda_codec_cleanup_stream(codec, hinfo->nid); in ca0132_capture_pcm_cleanup()
4023 struct hda_codec *codec, in ca0132_capture_pcm_delay() argument
4026 struct ca0132_spec *spec = codec->spec; in ca0132_capture_pcm_delay()
4236 static int tuning_ctl_set(struct hda_codec *codec, hda_nid_t nid, in tuning_ctl_set() argument
4247 snd_hda_power_up(codec); in tuning_ctl_set()
4248 dspio_set_param(codec, ca0132_tuning_ctls[i].mid, 0x20, in tuning_ctl_set()
4251 snd_hda_power_down(codec); in tuning_ctl_set()
4259 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in tuning_ctl_get() local
4260 struct ca0132_spec *spec = codec->spec; in tuning_ctl_get()
4285 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in voice_focus_ctl_put() local
4286 struct ca0132_spec *spec = codec->spec; in voice_focus_ctl_put()
4299 tuning_ctl_set(codec, nid, voice_focus_vals_lookup, idx); in voice_focus_ctl_put()
4320 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in mic_svm_ctl_put() local
4321 struct ca0132_spec *spec = codec->spec; in mic_svm_ctl_put()
4334 tuning_ctl_set(codec, nid, mic_svm_vals_lookup, idx); in mic_svm_ctl_put()
4355 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in equalizer_ctl_put() local
4356 struct ca0132_spec *spec = codec->spec; in equalizer_ctl_put()
4369 tuning_ctl_set(codec, nid, equalizer_vals_lookup, idx); in equalizer_ctl_put()
4377 static int add_tuning_control(struct hda_codec *codec, in add_tuning_control() argument
4414 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec)); in add_tuning_control()
4417 static int add_tuning_ctls(struct hda_codec *codec) in add_tuning_ctls() argument
4423 err = add_tuning_control(codec, in add_tuning_ctls()
4435 static void ca0132_init_tuning_defaults(struct hda_codec *codec) in ca0132_init_tuning_defaults() argument
4437 struct ca0132_spec *spec = codec->spec; in ca0132_init_tuning_defaults()
4457 static int ca0132_select_out(struct hda_codec *codec) in ca0132_select_out() argument
4459 struct ca0132_spec *spec = codec->spec; in ca0132_select_out()
4466 codec_dbg(codec, "ca0132_select_out\n"); in ca0132_select_out()
4468 snd_hda_power_up_pm(codec); in ca0132_select_out()
4473 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_hp); in ca0132_select_out()
4484 codec_dbg(codec, "ca0132_select_out speaker\n"); in ca0132_select_out()
4487 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); in ca0132_select_out()
4492 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp); in ca0132_select_out()
4497 snd_hda_codec_write(codec, spec->out_pins[1], 0, in ca0132_select_out()
4499 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4501 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4503 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4507 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, in ca0132_select_out()
4509 snd_hda_set_pin_ctl(codec, spec->out_pins[1], in ca0132_select_out()
4512 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, in ca0132_select_out()
4514 snd_hda_set_pin_ctl(codec, spec->out_pins[0], in ca0132_select_out()
4517 codec_dbg(codec, "ca0132_select_out hp\n"); in ca0132_select_out()
4520 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); in ca0132_select_out()
4525 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp); in ca0132_select_out()
4530 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4532 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4534 snd_hda_codec_write(codec, spec->out_pins[1], 0, in ca0132_select_out()
4536 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_select_out()
4540 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, in ca0132_select_out()
4542 snd_hda_set_pin_ctl(codec, spec->out_pins[0], in ca0132_select_out()
4545 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, in ca0132_select_out()
4547 snd_hda_set_pin_ctl(codec, spec->out_pins[1], in ca0132_select_out()
4552 snd_hda_power_down_pm(codec); in ca0132_select_out()
4557 static int ae5_headphone_gain_set(struct hda_codec *codec, long val);
4558 static int zxr_headphone_gain_set(struct hda_codec *codec, long val);
4559 static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val);
4561 static void ae5_mmio_select_out(struct hda_codec *codec) in ae5_mmio_select_out() argument
4563 struct ca0132_spec *spec = codec->spec; in ae5_mmio_select_out()
4573 ca0113_mmio_command_set(codec, out_cmds->group[i], in ae5_mmio_select_out()
4578 static int ca0132_alt_set_full_range_speaker(struct hda_codec *codec) in ca0132_alt_set_full_range_speaker() argument
4580 struct ca0132_spec *spec = codec->spec; in ca0132_alt_set_full_range_speaker()
4592 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4599 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4604 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4614 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_set_full_range_speaker()
4623 static int ca0132_alt_surround_set_bass_redirection(struct hda_codec *codec, in ca0132_alt_surround_set_bass_redirection() argument
4626 struct ca0132_spec *spec = codec->spec; in ca0132_alt_surround_set_bass_redirection()
4636 err = dspio_set_uint_param(codec, 0x96, SPEAKER_BASS_REDIRECT, tmp); in ca0132_alt_surround_set_bass_redirection()
4643 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_surround_set_bass_redirection()
4656 static void ca0132_alt_select_out_get_quirk_data(struct hda_codec *codec, in ca0132_alt_select_out_get_quirk_data() argument
4659 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_out_get_quirk_data()
4672 static int ca0132_alt_select_out_quirk_set(struct hda_codec *codec) in ca0132_alt_select_out_quirk_set() argument
4676 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_out_quirk_set()
4680 ca0132_alt_select_out_get_quirk_data(codec, &quirk_data); in ca0132_alt_select_out_quirk_set()
4686 ae5_mmio_select_out(codec); in ca0132_alt_select_out_quirk_set()
4689 gpio_data = snd_hda_codec_read(codec, codec->core.afg, 0, in ca0132_alt_select_out_quirk_set()
4697 snd_hda_codec_write(codec, codec->core.afg, 0, in ca0132_alt_select_out_quirk_set()
4703 ca0113_mmio_gpio_set(codec, out_info->mmio_gpio_pin[i], in ca0132_alt_select_out_quirk_set()
4710 err = dspio_set_uint_param(codec, in ca0132_alt_select_out_quirk_set()
4719 chipio_set_control_param(codec, 0x0d, out_info->dac2port); in ca0132_alt_select_out_quirk_set()
4722 chipio_write(codec, out_info->chipio_write_addr, in ca0132_alt_select_out_quirk_set()
4729 ae5_headphone_gain_set(codec, 2); in ca0132_alt_select_out_quirk_set()
4731 zxr_headphone_gain_set(codec, 0); in ca0132_alt_select_out_quirk_set()
4734 ae5_headphone_gain_set(codec, in ca0132_alt_select_out_quirk_set()
4737 zxr_headphone_gain_set(codec, in ca0132_alt_select_out_quirk_set()
4745 static void ca0132_set_out_node_pincfg(struct hda_codec *codec, hda_nid_t nid, in ca0132_set_out_node_pincfg() argument
4750 pin_ctl = snd_hda_codec_read(codec, nid, 0, in ca0132_set_out_node_pincfg()
4755 snd_hda_set_pin_ctl(codec, nid, pin_ctl); in ca0132_set_out_node_pincfg()
4766 static int ca0132_alt_select_out(struct hda_codec *codec) in ca0132_alt_select_out() argument
4768 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_out()
4776 codec_dbg(codec, "%s\n", __func__); in ca0132_alt_select_out()
4778 snd_hda_power_up_pm(codec); in ca0132_alt_select_out()
4788 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_hp) || in ca0132_alt_select_out()
4789 snd_hda_jack_detect(codec, spec->unsol_tag_front_hp); in ca0132_alt_select_out()
4801 err = dspio_set_uint_param(codec, 0x96, SPEAKER_TUNING_MUTE, FLOAT_ONE); in ca0132_alt_select_out()
4805 if (ca0132_alt_select_out_quirk_set(codec) < 0) in ca0132_alt_select_out()
4810 codec_dbg(codec, "%s speaker\n", __func__); in ca0132_alt_select_out()
4813 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_alt_select_out()
4817 ca0132_set_out_node_pincfg(codec, spec->out_pins[1], 0, 0); in ca0132_alt_select_out()
4819 ca0132_set_out_node_pincfg(codec, spec->out_pins[0], 1, 0); in ca0132_alt_select_out()
4821 ca0132_set_out_node_pincfg(codec, spec->out_pins[2], 1, 0); in ca0132_alt_select_out()
4823 ca0132_set_out_node_pincfg(codec, spec->out_pins[3], 1, 0); in ca0132_alt_select_out()
4835 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); in ca0132_alt_select_out()
4841 codec_dbg(codec, "%s hp\n", __func__); in ca0132_alt_select_out()
4842 snd_hda_codec_write(codec, spec->out_pins[0], 0, in ca0132_alt_select_out()
4846 ca0132_set_out_node_pincfg(codec, spec->out_pins[0], 0, 0); in ca0132_alt_select_out()
4847 ca0132_set_out_node_pincfg(codec, spec->out_pins[2], 0, 0); in ca0132_alt_select_out()
4848 ca0132_set_out_node_pincfg(codec, spec->out_pins[3], 0, 0); in ca0132_alt_select_out()
4851 if (snd_hda_jack_detect(codec, spec->unsol_tag_front_hp)) in ca0132_alt_select_out()
4853 else if (snd_hda_jack_detect(codec, spec->unsol_tag_hp)) in ca0132_alt_select_out()
4856 ca0132_set_out_node_pincfg(codec, headphone_nid, 1, 1); in ca0132_alt_select_out()
4859 err = dspio_set_uint_param(codec, 0x80, 0x04, FLOAT_ONE); in ca0132_alt_select_out()
4861 err = dspio_set_uint_param(codec, 0x80, 0x04, FLOAT_ZERO); in ca0132_alt_select_out()
4873 ca0132_effects_set(codec, X_BASS, in ca0132_alt_select_out()
4877 err = dspio_set_uint_param(codec, 0x8f, 0x01, FLOAT_ZERO); in ca0132_alt_select_out()
4885 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_select_out()
4891 err = ca0132_alt_surround_set_bass_redirection(codec, in ca0132_alt_select_out()
4894 err = ca0132_alt_surround_set_bass_redirection(codec, 0); in ca0132_alt_select_out()
4897 err = dspio_set_uint_param(codec, 0x96, in ca0132_alt_select_out()
4903 err = ca0132_alt_set_full_range_speaker(codec); in ca0132_alt_select_out()
4909 snd_hda_power_down_pm(codec); in ca0132_alt_select_out()
4921 ca0132_alt_select_out(spec->codec); in ca0132_unsol_hp_delayed()
4923 ca0132_select_out(spec->codec); in ca0132_unsol_hp_delayed()
4925 jack = snd_hda_jack_tbl_get(spec->codec, spec->unsol_tag_hp); in ca0132_unsol_hp_delayed()
4928 snd_hda_jack_report_sync(spec->codec); in ca0132_unsol_hp_delayed()
4932 static void ca0132_set_dmic(struct hda_codec *codec, int enable);
4933 static int ca0132_mic_boost_set(struct hda_codec *codec, long val);
4934 static void resume_mic1(struct hda_codec *codec, unsigned int oldval);
4935 static int stop_mic1(struct hda_codec *codec);
4936 static int ca0132_cvoice_switch_set(struct hda_codec *codec);
4937 static int ca0132_alt_mic_boost_set(struct hda_codec *codec, long val);
4942 static int ca0132_set_vipsource(struct hda_codec *codec, int val) in ca0132_set_vipsource() argument
4944 struct ca0132_spec *spec = codec->spec; in ca0132_set_vipsource()
4953 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0); in ca0132_set_vipsource()
4954 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_set_vipsource()
4955 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_set_vipsource()
4960 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_vipsource()
4962 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_set_vipsource()
4964 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_16_000); in ca0132_set_vipsource()
4965 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_16_000); in ca0132_set_vipsource()
4970 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_vipsource()
4972 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_set_vipsource()
4974 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, val); in ca0132_set_vipsource()
4980 static int ca0132_alt_set_vipsource(struct hda_codec *codec, int val) in ca0132_alt_set_vipsource() argument
4982 struct ca0132_spec *spec = codec->spec; in ca0132_alt_set_vipsource()
4988 codec_dbg(codec, "%s\n", __func__); in ca0132_alt_set_vipsource()
4990 chipio_set_stream_control(codec, 0x03, 0); in ca0132_alt_set_vipsource()
4991 chipio_set_stream_control(codec, 0x04, 0); in ca0132_alt_set_vipsource()
4996 codec_dbg(codec, "%s: off.", __func__); in ca0132_alt_set_vipsource()
4997 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0); in ca0132_alt_set_vipsource()
5000 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_alt_set_vipsource()
5002 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_alt_set_vipsource()
5003 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_alt_set_vipsource()
5005 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_set_vipsource()
5017 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_set_vipsource()
5020 codec_dbg(codec, "%s: on.", __func__); in ca0132_alt_set_vipsource()
5021 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_16_000); in ca0132_alt_set_vipsource()
5022 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_16_000); in ca0132_alt_set_vipsource()
5024 chipio_set_conn_rate(codec, 0x0F, SR_16_000); in ca0132_alt_set_vipsource()
5030 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_set_vipsource()
5033 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_alt_set_vipsource()
5036 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, val); in ca0132_alt_set_vipsource()
5039 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_set_vipsource()
5040 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_set_vipsource()
5051 static int ca0132_select_mic(struct hda_codec *codec) in ca0132_select_mic() argument
5053 struct ca0132_spec *spec = codec->spec; in ca0132_select_mic()
5057 codec_dbg(codec, "ca0132_select_mic\n"); in ca0132_select_mic()
5059 snd_hda_power_up_pm(codec); in ca0132_select_mic()
5064 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_amic1); in ca0132_select_mic()
5076 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_32_000); in ca0132_select_mic()
5077 ca0132_set_dmic(codec, 1); in ca0132_select_mic()
5078 ca0132_mic_boost_set(codec, 0); in ca0132_select_mic()
5080 ca0132_effects_set(codec, VOICE_FOCUS, in ca0132_select_mic()
5085 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_96_000); in ca0132_select_mic()
5086 ca0132_set_dmic(codec, 0); in ca0132_select_mic()
5087 ca0132_mic_boost_set(codec, spec->cur_mic_boost); in ca0132_select_mic()
5089 ca0132_effects_set(codec, VOICE_FOCUS, 0); in ca0132_select_mic()
5092 snd_hda_power_down_pm(codec); in ca0132_select_mic()
5103 static int ca0132_alt_select_in(struct hda_codec *codec) in ca0132_alt_select_in() argument
5105 struct ca0132_spec *spec = codec->spec; in ca0132_alt_select_in()
5108 codec_dbg(codec, "%s\n", __func__); in ca0132_alt_select_in()
5110 snd_hda_power_up_pm(codec); in ca0132_alt_select_in()
5112 chipio_set_stream_control(codec, 0x03, 0); in ca0132_alt_select_in()
5113 chipio_set_stream_control(codec, 0x04, 0); in ca0132_alt_select_in()
5122 ca0113_mmio_gpio_set(codec, 0, false); in ca0132_alt_select_in()
5129 r3di_gpio_mic_set(codec, R3DI_REAR_MIC); in ca0132_alt_select_in()
5133 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ca0132_alt_select_in()
5137 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ca0132_alt_select_in()
5139 chipio_set_conn_rate(codec, MEM_CONNID_MICIN2, in ca0132_alt_select_in()
5141 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT2, in ca0132_alt_select_in()
5143 dspio_set_uint_param(codec, 0x80, 0x01, FLOAT_ZERO); in ca0132_alt_select_in()
5150 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_alt_select_in()
5151 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_alt_select_in()
5153 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_select_in()
5155 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_select_in()
5157 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_select_in()
5158 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_select_in()
5161 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5162 chipio_write(codec, 0x18B09C, 0x0000000C); in ca0132_alt_select_in()
5165 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5166 chipio_write(codec, 0x18B09C, 0x000000CC); in ca0132_alt_select_in()
5169 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5170 chipio_write(codec, 0x18B09C, 0x0000004C); in ca0132_alt_select_in()
5175 ca0132_alt_mic_boost_set(codec, spec->mic_boost_enum_val); in ca0132_alt_select_in()
5178 ca0132_mic_boost_set(codec, 0); in ca0132_alt_select_in()
5182 ca0113_mmio_gpio_set(codec, 0, false); in ca0132_alt_select_in()
5185 r3di_gpio_mic_set(codec, R3DI_REAR_MIC); in ca0132_alt_select_in()
5188 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ca0132_alt_select_in()
5191 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x3f); in ca0132_alt_select_in()
5192 chipio_set_conn_rate(codec, MEM_CONNID_MICIN2, in ca0132_alt_select_in()
5194 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT2, in ca0132_alt_select_in()
5196 dspio_set_uint_param(codec, 0x80, 0x01, FLOAT_ZERO); in ca0132_alt_select_in()
5202 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_alt_select_in()
5203 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_alt_select_in()
5205 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_select_in()
5211 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_select_in()
5216 chipio_write(codec, 0x18B098, 0x00000000); in ca0132_alt_select_in()
5217 chipio_write(codec, 0x18B09C, 0x00000000); in ca0132_alt_select_in()
5222 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_select_in()
5223 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_select_in()
5229 ca0113_mmio_gpio_set(codec, 0, true); in ca0132_alt_select_in()
5230 ca0113_mmio_gpio_set(codec, 5, false); in ca0132_alt_select_in()
5234 r3di_gpio_mic_set(codec, R3DI_FRONT_MIC); in ca0132_alt_select_in()
5238 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x3f); in ca0132_alt_select_in()
5246 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_alt_select_in()
5247 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_alt_select_in()
5249 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_select_in()
5251 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_select_in()
5253 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_select_in()
5254 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_select_in()
5258 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5259 chipio_write(codec, 0x18B09C, 0x000000CC); in ca0132_alt_select_in()
5262 chipio_write(codec, 0x18B098, 0x0000000C); in ca0132_alt_select_in()
5263 chipio_write(codec, 0x18B09C, 0x0000004C); in ca0132_alt_select_in()
5268 ca0132_alt_mic_boost_set(codec, spec->mic_boost_enum_val); in ca0132_alt_select_in()
5271 ca0132_cvoice_switch_set(codec); in ca0132_alt_select_in()
5273 snd_hda_power_down_pm(codec); in ca0132_alt_select_in()
5280 static bool ca0132_is_vnode_effective(struct hda_codec *codec, in ca0132_is_vnode_effective() argument
5284 struct ca0132_spec *spec = codec->spec; in ca0132_is_vnode_effective()
5308 static int ca0132_voicefx_set(struct hda_codec *codec, int enable) in ca0132_voicefx_set() argument
5310 struct ca0132_spec *spec = codec->spec; in ca0132_voicefx_set()
5321 dspio_set_uint_param(codec, ca0132_voicefx.mid, in ca0132_voicefx_set()
5330 static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val) in ca0132_effects_set() argument
5332 struct ca0132_spec *spec = codec->spec; in ca0132_effects_set()
5377 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_effects_set()
5396 dspio_set_uint_param(codec, 0x47, 0x00, tmp); in ca0132_effects_set()
5405 codec_dbg(codec, "ca0132_effect_set: nid=0x%x, val=%ld\n", in ca0132_effects_set()
5409 err = dspio_set_uint_param(codec, ca0132_effects[idx].mid, in ca0132_effects_set()
5421 static int ca0132_pe_switch_set(struct hda_codec *codec) in ca0132_pe_switch_set() argument
5423 struct ca0132_spec *spec = codec->spec; in ca0132_pe_switch_set()
5427 codec_dbg(codec, "ca0132_pe_switch_set: val=%ld\n", in ca0132_pe_switch_set()
5431 ca0132_alt_select_out(codec); in ca0132_pe_switch_set()
5437 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]); in ca0132_pe_switch_set()
5443 static int stop_mic1(struct hda_codec *codec) in stop_mic1() argument
5445 struct ca0132_spec *spec = codec->spec; in stop_mic1()
5446 unsigned int oldval = snd_hda_codec_read(codec, spec->adcs[0], 0, in stop_mic1()
5449 snd_hda_codec_write(codec, spec->adcs[0], 0, in stop_mic1()
5456 static void resume_mic1(struct hda_codec *codec, unsigned int oldval) in resume_mic1() argument
5458 struct ca0132_spec *spec = codec->spec; in resume_mic1()
5461 snd_hda_codec_write(codec, spec->adcs[0], 0, in resume_mic1()
5469 static int ca0132_cvoice_switch_set(struct hda_codec *codec) in ca0132_cvoice_switch_set() argument
5471 struct ca0132_spec *spec = codec->spec; in ca0132_cvoice_switch_set()
5476 codec_dbg(codec, "ca0132_cvoice_switch_set: val=%ld\n", in ca0132_cvoice_switch_set()
5483 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]); in ca0132_cvoice_switch_set()
5486 ret |= ca0132_voicefx_set(codec, (spec->voicefx_val ? 1 : 0)); in ca0132_cvoice_switch_set()
5489 oldval = stop_mic1(codec); in ca0132_cvoice_switch_set()
5491 ret |= ca0132_alt_set_vipsource(codec, 1); in ca0132_cvoice_switch_set()
5493 ret |= ca0132_set_vipsource(codec, 1); in ca0132_cvoice_switch_set()
5494 resume_mic1(codec, oldval); in ca0132_cvoice_switch_set()
5498 static int ca0132_mic_boost_set(struct hda_codec *codec, long val) in ca0132_mic_boost_set() argument
5500 struct ca0132_spec *spec = codec->spec; in ca0132_mic_boost_set()
5504 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_mic_boost_set()
5507 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_mic_boost_set()
5513 static int ca0132_alt_mic_boost_set(struct hda_codec *codec, long val) in ca0132_alt_mic_boost_set() argument
5515 struct ca0132_spec *spec = codec->spec; in ca0132_alt_mic_boost_set()
5518 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, in ca0132_alt_mic_boost_set()
5523 static int ae5_headphone_gain_set(struct hda_codec *codec, long val) in ae5_headphone_gain_set() argument
5528 ca0113_mmio_command_set(codec, 0x48, 0x11 + i, in ae5_headphone_gain_set()
5537 static int zxr_headphone_gain_set(struct hda_codec *codec, long val) in zxr_headphone_gain_set() argument
5539 ca0113_mmio_gpio_set(codec, 1, val); in zxr_headphone_gain_set()
5547 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_vnode_switch_set() local
5552 struct ca0132_spec *spec = codec->spec; in ca0132_vnode_switch_set()
5560 ca0132_alt_select_out(codec); in ca0132_vnode_switch_set()
5562 ca0132_select_out(codec); in ca0132_vnode_switch_set()
5571 ca0132_select_mic(codec); in ca0132_vnode_switch_set()
5577 ca0132_alt_select_out(codec); in ca0132_vnode_switch_set()
5579 ca0132_select_out(codec); in ca0132_vnode_switch_set()
5584 ca0132_select_mic(codec); in ca0132_vnode_switch_set()
5589 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid); in ca0132_vnode_switch_set()
5595 mutex_lock(&codec->control_mutex); in ca0132_vnode_switch_set()
5601 mutex_unlock(&codec->control_mutex); in ca0132_vnode_switch_set()
5608 static void ca0132_alt_bass_redirection_xover_set(struct hda_codec *codec, in ca0132_alt_bass_redirection_xover_set() argument
5611 snd_hda_power_up(codec); in ca0132_alt_bass_redirection_xover_set()
5613 dspio_set_param(codec, 0x96, 0x20, SPEAKER_BASS_REDIRECT_XOVER_FREQ, in ca0132_alt_bass_redirection_xover_set()
5616 snd_hda_power_down(codec); in ca0132_alt_bass_redirection_xover_set()
5628 static int ca0132_alt_slider_ctl_set(struct hda_codec *codec, hda_nid_t nid, in ca0132_alt_slider_ctl_set() argument
5642 snd_hda_power_up(codec); in ca0132_alt_slider_ctl_set()
5648 dspio_set_param(codec, ca0132_effects[i].mid, 0x20, in ca0132_alt_slider_ctl_set()
5657 dspio_set_param(codec, ca0132_effects[i].mid, 0x20, in ca0132_alt_slider_ctl_set()
5662 snd_hda_power_down(codec); in ca0132_alt_slider_ctl_set()
5670 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_xbass_xover_slider_ctl_get() local
5671 struct ca0132_spec *spec = codec->spec; in ca0132_alt_xbass_xover_slider_ctl_get()
5686 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_slider_ctl_get() local
5687 struct ca0132_spec *spec = codec->spec; in ca0132_alt_slider_ctl_get()
5729 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_xbass_xover_slider_put() local
5730 struct ca0132_spec *spec = codec->spec; in ca0132_alt_xbass_xover_slider_put()
5749 ca0132_alt_bass_redirection_xover_set(codec, *cur_val); in ca0132_alt_xbass_xover_slider_put()
5751 ca0132_alt_slider_ctl_set(codec, nid, float_xbass_xover_lookup, idx); in ca0132_alt_xbass_xover_slider_put()
5759 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_effect_slider_put() local
5760 struct ca0132_spec *spec = codec->spec; in ca0132_alt_effect_slider_put()
5773 ca0132_alt_slider_ctl_set(codec, nid, float_zero_to_one_lookup, idx); in ca0132_alt_effect_slider_put()
5806 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_mic_boost_get() local
5807 struct ca0132_spec *spec = codec->spec; in ca0132_alt_mic_boost_get()
5816 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_mic_boost_put() local
5817 struct ca0132_spec *spec = codec->spec; in ca0132_alt_mic_boost_put()
5824 codec_dbg(codec, "ca0132_alt_mic_boost: boost=%d\n", in ca0132_alt_mic_boost_put()
5830 ca0132_alt_mic_boost_set(codec, spec->mic_boost_enum_val); in ca0132_alt_mic_boost_put()
5860 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ae5_headphone_gain_get() local
5861 struct ca0132_spec *spec = codec->spec; in ae5_headphone_gain_get()
5870 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ae5_headphone_gain_put() local
5871 struct ca0132_spec *spec = codec->spec; in ae5_headphone_gain_put()
5878 codec_dbg(codec, "ae5_headphone_gain: boost=%d\n", in ae5_headphone_gain_put()
5884 ae5_headphone_gain_set(codec, spec->ae5_headphone_gain_val); in ae5_headphone_gain_put()
5913 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ae5_sound_filter_get() local
5914 struct ca0132_spec *spec = codec->spec; in ae5_sound_filter_get()
5923 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ae5_sound_filter_put() local
5924 struct ca0132_spec *spec = codec->spec; in ae5_sound_filter_put()
5931 codec_dbg(codec, "ae5_sound_filter: %s\n", in ae5_sound_filter_put()
5936 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, in ae5_sound_filter_put()
5963 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_input_source_get() local
5964 struct ca0132_spec *spec = codec->spec; in ca0132_alt_input_source_get()
5973 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_input_source_put() local
5974 struct ca0132_spec *spec = codec->spec; in ca0132_alt_input_source_put()
5988 codec_dbg(codec, "ca0132_alt_input_select: sel=%d, preset=%s\n", in ca0132_alt_input_source_put()
5993 ca0132_alt_select_in(codec); in ca0132_alt_input_source_put()
6015 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_output_select_get() local
6016 struct ca0132_spec *spec = codec->spec; in ca0132_alt_output_select_get()
6025 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_output_select_put() local
6026 struct ca0132_spec *spec = codec->spec; in ca0132_alt_output_select_put()
6034 codec_dbg(codec, "ca0132_alt_output_select: sel=%d, preset=%s\n", in ca0132_alt_output_select_put()
6042 ca0132_alt_select_out(codec); in ca0132_alt_output_select_put()
6066 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_speaker_channel_cfg_get() local
6067 struct ca0132_spec *spec = codec->spec; in ca0132_alt_speaker_channel_cfg_get()
6076 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_speaker_channel_cfg_put() local
6077 struct ca0132_spec *spec = codec->spec; in ca0132_alt_speaker_channel_cfg_put()
6084 codec_dbg(codec, "ca0132_alt_speaker_channels: sel=%d, channels=%s\n", in ca0132_alt_speaker_channel_cfg_put()
6090 ca0132_alt_select_out(codec); in ca0132_alt_speaker_channel_cfg_put()
6119 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_svm_setting_get() local
6120 struct ca0132_spec *spec = codec->spec; in ca0132_alt_svm_setting_get()
6129 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_svm_setting_put() local
6130 struct ca0132_spec *spec = codec->spec; in ca0132_alt_svm_setting_put()
6139 codec_dbg(codec, "ca0132_alt_svm_setting: sel=%d, preset=%s\n", in ca0132_alt_svm_setting_put()
6159 dspio_set_uint_param(codec, ca0132_effects[idx].mid, in ca0132_alt_svm_setting_put()
6183 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_eq_preset_get() local
6184 struct ca0132_spec *spec = codec->spec; in ca0132_alt_eq_preset_get()
6193 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_eq_preset_put() local
6194 struct ca0132_spec *spec = codec->spec; in ca0132_alt_eq_preset_put()
6202 codec_dbg(codec, "%s: sel=%d, preset=%s\n", __func__, sel, in ca0132_alt_eq_preset_put()
6209 err = dspio_set_uint_param(codec, ca0132_alt_eq_enum.mid, in ca0132_alt_eq_preset_put()
6240 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_voicefx_get() local
6241 struct ca0132_spec *spec = codec->spec; in ca0132_voicefx_get()
6250 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_voicefx_put() local
6251 struct ca0132_spec *spec = codec->spec; in ca0132_voicefx_put()
6258 codec_dbg(codec, "ca0132_voicefx_put: sel=%d, preset=%s\n", in ca0132_voicefx_put()
6266 err = dspio_set_uint_param(codec, ca0132_voicefx.mid, in ca0132_voicefx_put()
6276 ca0132_voicefx_set(codec, (sel ? 1 : 0)); in ca0132_voicefx_put()
6285 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_switch_get() local
6286 struct ca0132_spec *spec = codec->spec; in ca0132_switch_get()
6337 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_switch_put() local
6338 struct ca0132_spec *spec = codec->spec; in ca0132_switch_put()
6344 codec_dbg(codec, "ca0132_switch_put: nid=0x%x, val=%ld\n", in ca0132_switch_put()
6347 snd_hda_power_up(codec); in ca0132_switch_put()
6365 changed = ca0132_pe_switch_set(codec); in ca0132_switch_put()
6372 changed = ca0132_cvoice_switch_set(codec); in ca0132_switch_put()
6380 changed = ca0132_effects_set(codec, nid, *valp); in ca0132_switch_put()
6389 changed = ca0132_mic_boost_set(codec, *valp); in ca0132_switch_put()
6393 changed = ca0132_mic_boost_set(codec, *valp); in ca0132_switch_put()
6402 changed = zxr_headphone_gain_set(codec, *valp); in ca0132_switch_put()
6412 ca0132_alt_set_full_range_speaker(codec); in ca0132_switch_put()
6420 ca0132_alt_surround_set_bass_redirection(codec, *valp); in ca0132_switch_put()
6426 snd_hda_power_down(codec); in ca0132_switch_put()
6438 static void ca0132_alt_dsp_volume_put(struct hda_codec *codec, hda_nid_t nid) in ca0132_alt_dsp_volume_put() argument
6440 struct ca0132_spec *spec = codec->spec; in ca0132_alt_dsp_volume_put()
6451 dspio_set_uint_param(codec, in ca0132_alt_dsp_volume_put()
6458 dspio_set_uint_param(codec, in ca0132_alt_dsp_volume_put()
6463 dspio_set_uint_param(codec, in ca0132_alt_dsp_volume_put()
6471 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_volume_info() local
6472 struct ca0132_spec *spec = codec->spec; in ca0132_volume_info()
6483 mutex_lock(&codec->control_mutex); in ca0132_volume_info()
6488 mutex_unlock(&codec->control_mutex); in ca0132_volume_info()
6493 mutex_lock(&codec->control_mutex); in ca0132_volume_info()
6498 mutex_unlock(&codec->control_mutex); in ca0132_volume_info()
6509 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_volume_get() local
6510 struct ca0132_spec *spec = codec->spec; in ca0132_volume_get()
6530 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_volume_put() local
6531 struct ca0132_spec *spec = codec->spec; in ca0132_volume_put()
6550 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid); in ca0132_volume_put()
6555 snd_hda_power_up(codec); in ca0132_volume_put()
6556 mutex_lock(&codec->control_mutex); in ca0132_volume_put()
6562 mutex_unlock(&codec->control_mutex); in ca0132_volume_put()
6563 snd_hda_power_down(codec); in ca0132_volume_put()
6577 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_alt_volume_put() local
6578 struct ca0132_spec *spec = codec->spec; in ca0132_alt_volume_put()
6604 snd_hda_power_up(codec); in ca0132_alt_volume_put()
6605 ca0132_alt_dsp_volume_put(codec, vnid); in ca0132_alt_volume_put()
6606 mutex_lock(&codec->control_mutex); in ca0132_alt_volume_put()
6608 mutex_unlock(&codec->control_mutex); in ca0132_alt_volume_put()
6609 snd_hda_power_down(codec); in ca0132_alt_volume_put()
6617 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); in ca0132_volume_tlv() local
6618 struct ca0132_spec *spec = codec->spec; in ca0132_volume_tlv()
6629 mutex_lock(&codec->control_mutex); in ca0132_volume_tlv()
6634 mutex_unlock(&codec->control_mutex); in ca0132_volume_tlv()
6639 mutex_lock(&codec->control_mutex); in ca0132_volume_tlv()
6644 mutex_unlock(&codec->control_mutex); in ca0132_volume_tlv()
6653 static int ca0132_alt_add_effect_slider(struct hda_codec *codec, hda_nid_t nid, in ca0132_alt_add_effect_slider() argument
6680 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec)); in ca0132_alt_add_effect_slider()
6688 static int add_fx_switch(struct hda_codec *codec, hda_nid_t nid, in add_fx_switch() argument
6691 struct ca0132_spec *spec = codec->spec; in add_fx_switch()
6704 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec)); in add_fx_switch()
6707 static int add_voicefx(struct hda_codec *codec) in add_voicefx() argument
6715 return snd_hda_ctl_add(codec, VOICEFX, snd_ctl_new1(&knew, codec)); in add_voicefx()
6719 static int add_ca0132_alt_eq_presets(struct hda_codec *codec) in add_ca0132_alt_eq_presets() argument
6727 return snd_hda_ctl_add(codec, EQ_PRESET_ENUM, in add_ca0132_alt_eq_presets()
6728 snd_ctl_new1(&knew, codec)); in add_ca0132_alt_eq_presets()
6736 static int ca0132_alt_add_svm_enum(struct hda_codec *codec) in ca0132_alt_add_svm_enum() argument
6744 return snd_hda_ctl_add(codec, SMART_VOLUME_ENUM, in ca0132_alt_add_svm_enum()
6745 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_svm_enum()
6753 static int ca0132_alt_add_output_enum(struct hda_codec *codec) in ca0132_alt_add_output_enum() argument
6761 return snd_hda_ctl_add(codec, OUTPUT_SOURCE_ENUM, in ca0132_alt_add_output_enum()
6762 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_output_enum()
6770 static int ca0132_alt_add_speaker_channel_cfg_enum(struct hda_codec *codec) in ca0132_alt_add_speaker_channel_cfg_enum() argument
6778 return snd_hda_ctl_add(codec, SPEAKER_CHANNEL_CFG_ENUM, in ca0132_alt_add_speaker_channel_cfg_enum()
6779 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_speaker_channel_cfg_enum()
6787 static int ca0132_alt_add_front_full_range_switch(struct hda_codec *codec) in ca0132_alt_add_front_full_range_switch() argument
6793 return snd_hda_ctl_add(codec, SPEAKER_FULL_RANGE_FRONT, in ca0132_alt_add_front_full_range_switch()
6794 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_front_full_range_switch()
6797 static int ca0132_alt_add_rear_full_range_switch(struct hda_codec *codec) in ca0132_alt_add_rear_full_range_switch() argument
6803 return snd_hda_ctl_add(codec, SPEAKER_FULL_RANGE_REAR, in ca0132_alt_add_rear_full_range_switch()
6804 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_rear_full_range_switch()
6813 static int ca0132_alt_add_bass_redirection_crossover(struct hda_codec *codec) in ca0132_alt_add_bass_redirection_crossover() argument
6825 return snd_hda_ctl_add(codec, BASS_REDIRECTION_XOVER, in ca0132_alt_add_bass_redirection_crossover()
6826 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_bass_redirection_crossover()
6829 static int ca0132_alt_add_bass_redirection_switch(struct hda_codec *codec) in ca0132_alt_add_bass_redirection_switch() argument
6836 return snd_hda_ctl_add(codec, BASS_REDIRECTION, in ca0132_alt_add_bass_redirection_switch()
6837 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_bass_redirection_switch()
6845 static int ca0132_alt_add_input_enum(struct hda_codec *codec) in ca0132_alt_add_input_enum() argument
6853 return snd_hda_ctl_add(codec, INPUT_SOURCE_ENUM, in ca0132_alt_add_input_enum()
6854 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_input_enum()
6861 static int ca0132_alt_add_mic_boost_enum(struct hda_codec *codec) in ca0132_alt_add_mic_boost_enum() argument
6869 return snd_hda_ctl_add(codec, MIC_BOOST_ENUM, in ca0132_alt_add_mic_boost_enum()
6870 snd_ctl_new1(&knew, codec)); in ca0132_alt_add_mic_boost_enum()
6879 static int ae5_add_headphone_gain_enum(struct hda_codec *codec) in ae5_add_headphone_gain_enum() argument
6887 return snd_hda_ctl_add(codec, AE5_HEADPHONE_GAIN_ENUM, in ae5_add_headphone_gain_enum()
6888 snd_ctl_new1(&knew, codec)); in ae5_add_headphone_gain_enum()
6896 static int ae5_add_sound_filter_enum(struct hda_codec *codec) in ae5_add_sound_filter_enum() argument
6904 return snd_hda_ctl_add(codec, AE5_SOUND_FILTER_ENUM, in ae5_add_sound_filter_enum()
6905 snd_ctl_new1(&knew, codec)); in ae5_add_sound_filter_enum()
6908 static int zxr_add_headphone_gain_switch(struct hda_codec *codec) in zxr_add_headphone_gain_switch() argument
6914 return snd_hda_ctl_add(codec, ZXR_HEADPHONE_GAIN, in zxr_add_headphone_gain_switch()
6915 snd_ctl_new1(&knew, codec)); in zxr_add_headphone_gain_switch()
6945 static void ca0132_alt_add_chmap_ctls(struct hda_codec *codec) in ca0132_alt_add_chmap_ctls() argument
6950 list_for_each_entry(pcm, &codec->pcm_list_head, list) { in ca0132_alt_add_chmap_ctls()
6962 codec_dbg(codec, "snd_pcm_add_chmap_ctls failed!"); in ca0132_alt_add_chmap_ctls()
7038 static int ca0132_build_controls(struct hda_codec *codec) in ca0132_build_controls() argument
7040 struct ca0132_spec *spec = codec->spec; in ca0132_build_controls()
7046 err = snd_hda_add_new_ctls(codec, spec->mixers[i]); in ca0132_build_controls()
7052 snd_hda_set_vmaster_tlv(codec, spec->dacs[0], HDA_OUTPUT, in ca0132_build_controls()
7054 snd_hda_add_vmaster(codec, "Master Playback Volume", in ca0132_build_controls()
7057 err = __snd_hda_add_vmaster(codec, "Master Playback Switch", in ca0132_build_controls()
7077 err = add_fx_switch(codec, ca0132_effects[i].nid, in ca0132_build_controls()
7084 * If codec has use_alt_controls set to true, add effect level sliders, in ca0132_build_controls()
7089 err = ca0132_alt_add_svm_enum(codec); in ca0132_build_controls()
7093 err = add_ca0132_alt_eq_presets(codec); in ca0132_build_controls()
7097 err = add_fx_switch(codec, PLAY_ENHANCEMENT, in ca0132_build_controls()
7102 err = add_fx_switch(codec, CRYSTAL_VOICE, in ca0132_build_controls()
7109 err = ca0132_alt_add_effect_slider(codec, in ca0132_build_controls()
7117 err = ca0132_alt_add_effect_slider(codec, XBASS_XOVER, in ca0132_build_controls()
7123 err = add_fx_switch(codec, PLAY_ENHANCEMENT, in ca0132_build_controls()
7128 err = add_fx_switch(codec, CRYSTAL_VOICE, in ca0132_build_controls()
7133 err = add_voicefx(codec); in ca0132_build_controls()
7138 * If the codec uses alt_functions, you need the enumerated controls in ca0132_build_controls()
7143 err = ca0132_alt_add_output_enum(codec); in ca0132_build_controls()
7146 err = ca0132_alt_add_speaker_channel_cfg_enum(codec); in ca0132_build_controls()
7149 err = ca0132_alt_add_front_full_range_switch(codec); in ca0132_build_controls()
7152 err = ca0132_alt_add_rear_full_range_switch(codec); in ca0132_build_controls()
7155 err = ca0132_alt_add_bass_redirection_crossover(codec); in ca0132_build_controls()
7158 err = ca0132_alt_add_bass_redirection_switch(codec); in ca0132_build_controls()
7161 err = ca0132_alt_add_mic_boost_enum(codec); in ca0132_build_controls()
7169 err = ca0132_alt_add_input_enum(codec); in ca0132_build_controls()
7178 err = ae5_add_headphone_gain_enum(codec); in ca0132_build_controls()
7181 err = ae5_add_sound_filter_enum(codec); in ca0132_build_controls()
7186 err = zxr_add_headphone_gain_switch(codec); in ca0132_build_controls()
7195 add_tuning_ctls(codec); in ca0132_build_controls()
7198 err = snd_hda_jack_add_kctls(codec, &spec->autocfg); in ca0132_build_controls()
7203 err = snd_hda_create_spdif_out_ctls(codec, spec->dig_out, in ca0132_build_controls()
7207 err = snd_hda_create_spdif_share_sw(codec, &spec->multiout); in ca0132_build_controls()
7214 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in); in ca0132_build_controls()
7220 ca0132_alt_add_chmap_ctls(codec); in ca0132_build_controls()
7225 static int dbpro_build_controls(struct hda_codec *codec) in dbpro_build_controls() argument
7227 struct ca0132_spec *spec = codec->spec; in dbpro_build_controls()
7231 err = snd_hda_create_spdif_out_ctls(codec, spec->dig_out, in dbpro_build_controls()
7238 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in); in dbpro_build_controls()
7289 static int ca0132_build_pcms(struct hda_codec *codec) in ca0132_build_pcms() argument
7291 struct ca0132_spec *spec = codec->spec; in ca0132_build_pcms()
7294 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog"); in ca0132_build_pcms()
7312 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog Mic-In2"); in ca0132_build_pcms()
7321 info = snd_hda_codec_pcm_new(codec, "CA0132 What U Hear"); in ca0132_build_pcms()
7331 info = snd_hda_codec_pcm_new(codec, "CA0132 Digital"); in ca0132_build_pcms()
7349 static int dbpro_build_pcms(struct hda_codec *codec) in dbpro_build_pcms() argument
7351 struct ca0132_spec *spec = codec->spec; in dbpro_build_pcms()
7354 info = snd_hda_codec_pcm_new(codec, "CA0132 Alt Analog"); in dbpro_build_pcms()
7365 info = snd_hda_codec_pcm_new(codec, "CA0132 Digital"); in dbpro_build_pcms()
7383 static void init_output(struct hda_codec *codec, hda_nid_t pin, hda_nid_t dac) in init_output() argument
7386 snd_hda_set_pin_ctl(codec, pin, PIN_HP); in init_output()
7387 if (get_wcaps(codec, pin) & AC_WCAP_OUT_AMP) in init_output()
7388 snd_hda_codec_write(codec, pin, 0, in init_output()
7392 if (dac && (get_wcaps(codec, dac) & AC_WCAP_OUT_AMP)) in init_output()
7393 snd_hda_codec_write(codec, dac, 0, in init_output()
7397 static void init_input(struct hda_codec *codec, hda_nid_t pin, hda_nid_t adc) in init_input() argument
7400 snd_hda_set_pin_ctl(codec, pin, PIN_VREF80); in init_input()
7401 if (get_wcaps(codec, pin) & AC_WCAP_IN_AMP) in init_input()
7402 snd_hda_codec_write(codec, pin, 0, in init_input()
7406 if (adc && (get_wcaps(codec, adc) & AC_WCAP_IN_AMP)) { in init_input()
7407 snd_hda_codec_write(codec, adc, 0, AC_VERB_SET_AMP_GAIN_MUTE, in init_input()
7411 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0, in init_input()
7413 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0, in init_input()
7418 static void refresh_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir) in refresh_amp_caps() argument
7422 caps = snd_hda_param_read(codec, nid, dir == HDA_OUTPUT ? in refresh_amp_caps()
7424 snd_hda_override_amp_caps(codec, nid, dir, caps); in refresh_amp_caps()
7430 static void ca0132_set_dmic(struct hda_codec *codec, int enable) in ca0132_set_dmic() argument
7432 struct ca0132_spec *spec = codec->spec; in ca0132_set_dmic()
7437 codec_dbg(codec, "ca0132_set_dmic: enable=%d\n", enable); in ca0132_set_dmic()
7439 oldval = stop_mic1(codec); in ca0132_set_dmic()
7440 ca0132_set_vipsource(codec, 0); in ca0132_set_dmic()
7444 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_dmic()
7448 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_set_dmic()
7452 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 1); in ca0132_set_dmic()
7456 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_set_dmic()
7461 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_set_dmic()
7465 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 0); in ca0132_set_dmic()
7467 ca0132_set_vipsource(codec, 1); in ca0132_set_dmic()
7468 resume_mic1(codec, oldval); in ca0132_set_dmic()
7474 static void ca0132_init_dmic(struct hda_codec *codec) in ca0132_init_dmic() argument
7476 struct ca0132_spec *spec = codec->spec; in ca0132_init_dmic()
7489 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7499 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7515 snd_hda_codec_write(codec, spec->input_pins[0], 0, in ca0132_init_dmic()
7522 static void ca0132_init_analog_mic2(struct hda_codec *codec) in ca0132_init_analog_mic2() argument
7524 struct ca0132_spec *spec = codec->spec; in ca0132_init_analog_mic2()
7528 chipio_8051_write_exram_no_mutex(codec, 0x1920, 0x00); in ca0132_init_analog_mic2()
7529 chipio_8051_write_exram_no_mutex(codec, 0x192d, 0x00); in ca0132_init_analog_mic2()
7534 static void ca0132_refresh_widget_caps(struct hda_codec *codec) in ca0132_refresh_widget_caps() argument
7536 struct ca0132_spec *spec = codec->spec; in ca0132_refresh_widget_caps()
7539 codec_dbg(codec, "ca0132_refresh_widget_caps.\n"); in ca0132_refresh_widget_caps()
7540 snd_hda_codec_update_widgets(codec); in ca0132_refresh_widget_caps()
7543 refresh_amp_caps(codec, spec->dacs[i], HDA_OUTPUT); in ca0132_refresh_widget_caps()
7546 refresh_amp_caps(codec, spec->out_pins[i], HDA_OUTPUT); in ca0132_refresh_widget_caps()
7549 refresh_amp_caps(codec, spec->adcs[i], HDA_INPUT); in ca0132_refresh_widget_caps()
7550 refresh_amp_caps(codec, spec->input_pins[i], HDA_INPUT); in ca0132_refresh_widget_caps()
7556 static void ca0132_alt_free_active_dma_channels(struct hda_codec *codec) in ca0132_alt_free_active_dma_channels() argument
7562 status = chipio_read(codec, DSPDMAC_CHNLSTART_MODULE_OFFSET, &tmp); in ca0132_alt_free_active_dma_channels()
7571 codec_dbg(codec, "%s: Failed to read active DSP DMA channel register.\n", in ca0132_alt_free_active_dma_channels()
7581 if (dsp_is_dma_active(codec, i)) { in ca0132_alt_free_active_dma_channels()
7582 status = dspio_free_dma_chan(codec, i); in ca0132_alt_free_active_dma_channels()
7584 codec_dbg(codec, "%s: Failed to free active DSP DMA channel %d.\n", in ca0132_alt_free_active_dma_channels()
7611 static void ca0132_alt_start_dsp_audio_streams(struct hda_codec *codec) in ca0132_alt_start_dsp_audio_streams() argument
7614 struct ca0132_spec *spec = codec->spec; in ca0132_alt_start_dsp_audio_streams()
7624 chipio_get_stream_control(codec, dsp_dma_stream_ids[i], &tmp); in ca0132_alt_start_dsp_audio_streams()
7627 chipio_set_stream_control(codec, in ca0132_alt_start_dsp_audio_streams()
7639 ca0132_alt_free_active_dma_channels(codec); in ca0132_alt_start_dsp_audio_streams()
7644 chipio_set_stream_channels(codec, 0x0c, 6); in ca0132_alt_start_dsp_audio_streams()
7647 chipio_set_stream_control(codec, in ca0132_alt_start_dsp_audio_streams()
7701 static void chipio_remap_stream(struct hda_codec *codec, in chipio_remap_stream() argument
7707 chipio_8051_read_exram(codec, 0x1578 + remap_data->stream_id, in chipio_remap_stream()
7719 chipio_8051_read_exram(codec, 0x1578 + remap_data->stream_id, in chipio_remap_stream()
7728 codec_info(codec, "%s: Stream 0x%02x ports aren't allocated, remap failed!\n", in chipio_remap_stream()
7738 chipio_write_no_mutex(codec, in chipio_remap_stream()
7744 chipio_write_no_mutex(codec, 0x19042c, 0x00000001); in chipio_remap_stream()
7768 static void ca0132_alt_init_speaker_tuning(struct hda_codec *codec) in ca0132_alt_init_speaker_tuning() argument
7770 struct ca0132_spec *spec = codec->spec; in ca0132_alt_init_speaker_tuning()
7791 dspio_set_uint_param(codec, 0x96, SPEAKER_TUNING_ENABLE_CENTER_EQ, tmp); in ca0132_alt_init_speaker_tuning()
7796 dspio_set_uint_param(codec, 0x96, i, tmp); in ca0132_alt_init_speaker_tuning()
7801 dspio_set_uint_param(codec, 0x96, i, tmp); in ca0132_alt_init_speaker_tuning()
7805 dspio_set_uint_param(codec, 0x96, in ca0132_alt_init_speaker_tuning()
7812 static void ca0132_alt_init_analog_mics(struct hda_codec *codec) in ca0132_alt_init_analog_mics() argument
7814 struct ca0132_spec *spec = codec->spec; in ca0132_alt_init_analog_mics()
7818 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_alt_init_analog_mics()
7819 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_alt_init_analog_mics()
7821 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_init_analog_mics()
7825 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_init_analog_mics()
7828 chipio_set_conn_rate(codec, MEM_CONNID_MICIN2, SR_96_000); in ca0132_alt_init_analog_mics()
7829 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT2, SR_96_000); in ca0132_alt_init_analog_mics()
7831 chipio_set_conn_rate(codec, 0x0F, SR_96_000); in ca0132_alt_init_analog_mics()
7833 dspio_set_uint_param(codec, 0x80, 0x01, tmp); in ca0132_alt_init_analog_mics()
7842 static void sbz_connect_streams(struct hda_codec *codec) in sbz_connect_streams() argument
7844 struct ca0132_spec *spec = codec->spec; in sbz_connect_streams()
7848 codec_dbg(codec, "Connect Streams entered, mutex locked and loaded.\n"); in sbz_connect_streams()
7851 chipio_write_no_mutex(codec, 0x18a020, 0x00000043); in sbz_connect_streams()
7854 chipio_set_stream_source_dest(codec, 0x14, 0x48, 0x91); in sbz_connect_streams()
7855 chipio_set_conn_rate_no_mutex(codec, 0x48, SR_96_000); in sbz_connect_streams()
7856 chipio_set_conn_rate_no_mutex(codec, 0x91, SR_96_000); in sbz_connect_streams()
7857 chipio_set_stream_channels(codec, 0x14, 2); in sbz_connect_streams()
7858 chipio_set_stream_control(codec, 0x14, 1); in sbz_connect_streams()
7860 codec_dbg(codec, "Connect Streams exited, mutex released.\n"); in sbz_connect_streams()
7871 static void sbz_chipio_startup_data(struct hda_codec *codec) in sbz_chipio_startup_data() argument
7874 struct ca0132_spec *spec = codec->spec; in sbz_chipio_startup_data()
7877 codec_dbg(codec, "Startup Data entered, mutex locked and loaded.\n"); in sbz_chipio_startup_data()
7880 chipio_remap_stream(codec, &stream_remap_data[0]); in sbz_chipio_startup_data()
7898 chipio_remap_stream(codec, dsp_out_remap_data); in sbz_chipio_startup_data()
7900 codec_dbg(codec, "Startup Data exited, mutex released.\n"); in sbz_chipio_startup_data()
7904 static void ca0132_alt_dsp_initial_mic_setup(struct hda_codec *codec) in ca0132_alt_dsp_initial_mic_setup() argument
7906 struct ca0132_spec *spec = codec->spec; in ca0132_alt_dsp_initial_mic_setup()
7909 chipio_set_stream_control(codec, 0x03, 0); in ca0132_alt_dsp_initial_mic_setup()
7910 chipio_set_stream_control(codec, 0x04, 0); in ca0132_alt_dsp_initial_mic_setup()
7912 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_alt_dsp_initial_mic_setup()
7913 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_alt_dsp_initial_mic_setup()
7916 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_alt_dsp_initial_mic_setup()
7918 chipio_set_stream_control(codec, 0x03, 1); in ca0132_alt_dsp_initial_mic_setup()
7919 chipio_set_stream_control(codec, 0x04, 1); in ca0132_alt_dsp_initial_mic_setup()
7923 chipio_write(codec, 0x18b098, 0x0000000c); in ca0132_alt_dsp_initial_mic_setup()
7924 chipio_write(codec, 0x18b09C, 0x0000000c); in ca0132_alt_dsp_initial_mic_setup()
7927 chipio_write(codec, 0x18b098, 0x0000000c); in ca0132_alt_dsp_initial_mic_setup()
7928 chipio_write(codec, 0x18b09c, 0x0000004c); in ca0132_alt_dsp_initial_mic_setup()
7935 static void ae5_post_dsp_register_set(struct hda_codec *codec) in ae5_post_dsp_register_set() argument
7937 struct ca0132_spec *spec = codec->spec; in ae5_post_dsp_register_set()
7939 chipio_8051_write_direct(codec, 0x93, 0x10); in ae5_post_dsp_register_set()
7940 chipio_8051_write_pll_pmu(codec, 0x44, 0xc2); in ae5_post_dsp_register_set()
7955 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x3f); in ae5_post_dsp_register_set()
7956 ca0113_mmio_command_set(codec, 0x30, 0x2d, 0x3f); in ae5_post_dsp_register_set()
7957 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_post_dsp_register_set()
7960 static void ae5_post_dsp_param_setup(struct hda_codec *codec) in ae5_post_dsp_param_setup() argument
7967 chipio_set_control_param(codec, 3, 0); in ae5_post_dsp_param_setup()
7972 chipio_set_control_flag(codec, CONTROL_FLAG_ASI_96KHZ, 1); in ae5_post_dsp_param_setup()
7974 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x724, 0x83); in ae5_post_dsp_param_setup()
7975 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae5_post_dsp_param_setup()
7977 chipio_8051_write_exram(codec, 0xfa92, 0x22); in ae5_post_dsp_param_setup()
7980 static void ae5_post_dsp_pll_setup(struct hda_codec *codec) in ae5_post_dsp_pll_setup() argument
7982 chipio_8051_write_pll_pmu(codec, 0x41, 0xc8); in ae5_post_dsp_pll_setup()
7983 chipio_8051_write_pll_pmu(codec, 0x45, 0xcc); in ae5_post_dsp_pll_setup()
7984 chipio_8051_write_pll_pmu(codec, 0x40, 0xcb); in ae5_post_dsp_pll_setup()
7985 chipio_8051_write_pll_pmu(codec, 0x43, 0xc7); in ae5_post_dsp_pll_setup()
7986 chipio_8051_write_pll_pmu(codec, 0x51, 0x8d); in ae5_post_dsp_pll_setup()
7989 static void ae5_post_dsp_stream_setup(struct hda_codec *codec) in ae5_post_dsp_stream_setup() argument
7991 struct ca0132_spec *spec = codec->spec; in ae5_post_dsp_stream_setup()
7995 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x725, 0x81); in ae5_post_dsp_stream_setup()
7997 chipio_set_conn_rate_no_mutex(codec, 0x70, SR_96_000); in ae5_post_dsp_stream_setup()
7999 chipio_set_stream_source_dest(codec, 0x5, 0x43, 0x0); in ae5_post_dsp_stream_setup()
8001 chipio_set_stream_source_dest(codec, 0x18, 0x9, 0xd0); in ae5_post_dsp_stream_setup()
8002 chipio_set_conn_rate_no_mutex(codec, 0xd0, SR_96_000); in ae5_post_dsp_stream_setup()
8003 chipio_set_stream_channels(codec, 0x18, 6); in ae5_post_dsp_stream_setup()
8004 chipio_set_stream_control(codec, 0x18, 1); in ae5_post_dsp_stream_setup()
8006 chipio_set_control_param_no_mutex(codec, CONTROL_PARAM_ASI, 4); in ae5_post_dsp_stream_setup()
8008 chipio_8051_write_pll_pmu_no_mutex(codec, 0x43, 0xc7); in ae5_post_dsp_stream_setup()
8010 ca0113_mmio_command_set(codec, 0x48, 0x01, 0x80); in ae5_post_dsp_stream_setup()
8015 static void ae5_post_dsp_startup_data(struct hda_codec *codec) in ae5_post_dsp_startup_data() argument
8017 struct ca0132_spec *spec = codec->spec; in ae5_post_dsp_startup_data()
8021 chipio_write_no_mutex(codec, 0x189000, 0x0001f101); in ae5_post_dsp_startup_data()
8022 chipio_write_no_mutex(codec, 0x189004, 0x0001f101); in ae5_post_dsp_startup_data()
8023 chipio_write_no_mutex(codec, 0x189024, 0x00014004); in ae5_post_dsp_startup_data()
8024 chipio_write_no_mutex(codec, 0x189028, 0x0002000f); in ae5_post_dsp_startup_data()
8026 ca0113_mmio_command_set(codec, 0x48, 0x0a, 0x05); in ae5_post_dsp_startup_data()
8027 chipio_set_control_param_no_mutex(codec, CONTROL_PARAM_ASI, 7); in ae5_post_dsp_startup_data()
8028 ca0113_mmio_command_set(codec, 0x48, 0x0b, 0x12); in ae5_post_dsp_startup_data()
8029 ca0113_mmio_command_set(codec, 0x48, 0x04, 0x00); in ae5_post_dsp_startup_data()
8030 ca0113_mmio_command_set(codec, 0x48, 0x06, 0x48); in ae5_post_dsp_startup_data()
8031 ca0113_mmio_command_set(codec, 0x48, 0x0a, 0x05); in ae5_post_dsp_startup_data()
8032 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_post_dsp_startup_data()
8033 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae5_post_dsp_startup_data()
8034 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae5_post_dsp_startup_data()
8035 ca0113_mmio_gpio_set(codec, 0, true); in ae5_post_dsp_startup_data()
8036 ca0113_mmio_gpio_set(codec, 1, true); in ae5_post_dsp_startup_data()
8037 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x80); in ae5_post_dsp_startup_data()
8039 chipio_write_no_mutex(codec, 0x18b03c, 0x00000012); in ae5_post_dsp_startup_data()
8041 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae5_post_dsp_startup_data()
8042 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae5_post_dsp_startup_data()
8047 static void ae7_post_dsp_setup_ports(struct hda_codec *codec) in ae7_post_dsp_setup_ports() argument
8049 struct ca0132_spec *spec = codec->spec; in ae7_post_dsp_setup_ports()
8054 chipio_remap_stream(codec, &stream_remap_data[1]); in ae7_post_dsp_setup_ports()
8056 ca0113_mmio_command_set(codec, 0x30, 0x30, 0x00); in ae7_post_dsp_setup_ports()
8057 ca0113_mmio_command_set(codec, 0x48, 0x0d, 0x40); in ae7_post_dsp_setup_ports()
8058 ca0113_mmio_command_set(codec, 0x48, 0x17, 0x00); in ae7_post_dsp_setup_ports()
8059 ca0113_mmio_command_set(codec, 0x48, 0x19, 0x00); in ae7_post_dsp_setup_ports()
8060 ca0113_mmio_command_set(codec, 0x48, 0x11, 0xff); in ae7_post_dsp_setup_ports()
8061 ca0113_mmio_command_set(codec, 0x48, 0x12, 0xff); in ae7_post_dsp_setup_ports()
8062 ca0113_mmio_command_set(codec, 0x48, 0x13, 0xff); in ae7_post_dsp_setup_ports()
8063 ca0113_mmio_command_set(codec, 0x48, 0x14, 0x7f); in ae7_post_dsp_setup_ports()
8068 static void ae7_post_dsp_asi_stream_setup(struct hda_codec *codec) in ae7_post_dsp_asi_stream_setup() argument
8070 struct ca0132_spec *spec = codec->spec; in ae7_post_dsp_asi_stream_setup()
8074 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x725, 0x81); in ae7_post_dsp_asi_stream_setup()
8075 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x00); in ae7_post_dsp_asi_stream_setup()
8077 chipio_set_conn_rate_no_mutex(codec, 0x70, SR_96_000); in ae7_post_dsp_asi_stream_setup()
8079 chipio_set_stream_source_dest(codec, 0x05, 0x43, 0x00); in ae7_post_dsp_asi_stream_setup()
8080 chipio_set_stream_source_dest(codec, 0x18, 0x09, 0xd0); in ae7_post_dsp_asi_stream_setup()
8082 chipio_set_conn_rate_no_mutex(codec, 0xd0, SR_96_000); in ae7_post_dsp_asi_stream_setup()
8083 chipio_set_stream_channels(codec, 0x18, 6); in ae7_post_dsp_asi_stream_setup()
8084 chipio_set_stream_control(codec, 0x18, 1); in ae7_post_dsp_asi_stream_setup()
8086 chipio_set_control_param_no_mutex(codec, CONTROL_PARAM_ASI, 4); in ae7_post_dsp_asi_stream_setup()
8091 static void ae7_post_dsp_pll_setup(struct hda_codec *codec) in ae7_post_dsp_pll_setup() argument
8102 chipio_8051_write_pll_pmu_no_mutex(codec, addr[i], data[i]); in ae7_post_dsp_pll_setup()
8105 static void ae7_post_dsp_asi_setup_ports(struct hda_codec *codec) in ae7_post_dsp_asi_setup_ports() argument
8107 struct ca0132_spec *spec = codec->spec; in ae7_post_dsp_asi_setup_ports()
8118 chipio_8051_write_pll_pmu_no_mutex(codec, 0x43, 0xc7); in ae7_post_dsp_asi_setup_ports()
8120 chipio_write_no_mutex(codec, 0x189000, 0x0001f101); in ae7_post_dsp_asi_setup_ports()
8121 chipio_write_no_mutex(codec, 0x189004, 0x0001f101); in ae7_post_dsp_asi_setup_ports()
8122 chipio_write_no_mutex(codec, 0x189024, 0x00014004); in ae7_post_dsp_asi_setup_ports()
8123 chipio_write_no_mutex(codec, 0x189028, 0x0002000f); in ae7_post_dsp_asi_setup_ports()
8125 ae7_post_dsp_pll_setup(codec); in ae7_post_dsp_asi_setup_ports()
8126 chipio_set_control_param_no_mutex(codec, CONTROL_PARAM_ASI, 7); in ae7_post_dsp_asi_setup_ports()
8129 ca0113_mmio_command_set(codec, 0x48, target[i], data[i]); in ae7_post_dsp_asi_setup_ports()
8131 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_post_dsp_asi_setup_ports()
8132 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae7_post_dsp_asi_setup_ports()
8133 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae7_post_dsp_asi_setup_ports()
8135 chipio_set_stream_source_dest(codec, 0x21, 0x64, 0x56); in ae7_post_dsp_asi_setup_ports()
8136 chipio_set_stream_channels(codec, 0x21, 2); in ae7_post_dsp_asi_setup_ports()
8137 chipio_set_conn_rate_no_mutex(codec, 0x56, SR_8_000); in ae7_post_dsp_asi_setup_ports()
8139 chipio_set_control_param_no_mutex(codec, CONTROL_PARAM_NODE_ID, 0x09); in ae7_post_dsp_asi_setup_ports()
8145 chipio_set_control_param_no_mutex(codec, 0x20, 0x21); in ae7_post_dsp_asi_setup_ports()
8147 chipio_write_no_mutex(codec, 0x18b038, 0x00000088); in ae7_post_dsp_asi_setup_ports()
8158 ca0113_mmio_gpio_set(codec, 0, 1); in ae7_post_dsp_asi_setup_ports()
8159 ca0113_mmio_gpio_set(codec, 1, 1); in ae7_post_dsp_asi_setup_ports()
8161 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_post_dsp_asi_setup_ports()
8162 chipio_write_no_mutex(codec, 0x18b03c, 0x00000000); in ae7_post_dsp_asi_setup_ports()
8163 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x00); in ae7_post_dsp_asi_setup_ports()
8164 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x00); in ae7_post_dsp_asi_setup_ports()
8166 chipio_set_stream_source_dest(codec, 0x05, 0x43, 0x00); in ae7_post_dsp_asi_setup_ports()
8167 chipio_set_stream_source_dest(codec, 0x18, 0x09, 0xd0); in ae7_post_dsp_asi_setup_ports()
8169 chipio_set_conn_rate_no_mutex(codec, 0xd0, SR_96_000); in ae7_post_dsp_asi_setup_ports()
8170 chipio_set_stream_channels(codec, 0x18, 6); in ae7_post_dsp_asi_setup_ports()
8176 ae7_post_dsp_pll_setup(codec); in ae7_post_dsp_asi_setup_ports()
8177 chipio_set_control_param_no_mutex(codec, CONTROL_PARAM_ASI, 7); in ae7_post_dsp_asi_setup_ports()
8187 static void ae7_post_dsp_asi_setup(struct hda_codec *codec) in ae7_post_dsp_asi_setup() argument
8189 chipio_8051_write_direct(codec, 0x93, 0x10); in ae7_post_dsp_asi_setup()
8191 chipio_8051_write_pll_pmu(codec, 0x44, 0xc2); in ae7_post_dsp_asi_setup()
8193 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_post_dsp_asi_setup()
8194 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae7_post_dsp_asi_setup()
8196 chipio_set_control_param(codec, 3, 3); in ae7_post_dsp_asi_setup()
8197 chipio_set_control_flag(codec, CONTROL_FLAG_ASI_96KHZ, 1); in ae7_post_dsp_asi_setup()
8199 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x724, 0x83); in ae7_post_dsp_asi_setup()
8200 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae7_post_dsp_asi_setup()
8201 snd_hda_codec_write(codec, 0x17, 0, 0x794, 0x00); in ae7_post_dsp_asi_setup()
8203 chipio_8051_write_exram(codec, 0xfa92, 0x22); in ae7_post_dsp_asi_setup()
8205 ae7_post_dsp_pll_setup(codec); in ae7_post_dsp_asi_setup()
8206 ae7_post_dsp_asi_stream_setup(codec); in ae7_post_dsp_asi_setup()
8208 chipio_8051_write_pll_pmu(codec, 0x43, 0xc7); in ae7_post_dsp_asi_setup()
8210 ae7_post_dsp_asi_setup_ports(codec); in ae7_post_dsp_asi_setup()
8216 static void ca0132_setup_defaults(struct hda_codec *codec) in ca0132_setup_defaults() argument
8218 struct ca0132_spec *spec = codec->spec; in ca0132_setup_defaults()
8230 dspio_set_uint_param(codec, ca0132_effects[idx].mid, in ca0132_setup_defaults()
8238 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in ca0132_setup_defaults()
8241 dspio_set_uint_param(codec, 0x8f, 0x01, tmp); in ca0132_setup_defaults()
8245 dspio_set_uint_param(codec, 0x80, 0x00, tmp); in ca0132_setup_defaults()
8246 dspio_set_uint_param(codec, 0x80, 0x01, tmp); in ca0132_setup_defaults()
8250 dspio_set_uint_param(codec, 0x80, 0x05, tmp); in ca0132_setup_defaults()
8254 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in ca0132_setup_defaults()
8261 static void r3d_setup_defaults(struct hda_codec *codec) in r3d_setup_defaults() argument
8263 struct ca0132_spec *spec = codec->spec; in r3d_setup_defaults()
8271 ca0132_alt_init_analog_mics(codec); in r3d_setup_defaults()
8272 ca0132_alt_start_dsp_audio_streams(codec); in r3d_setup_defaults()
8276 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in r3d_setup_defaults()
8280 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in r3d_setup_defaults()
8281 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); in r3d_setup_defaults()
8284 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in r3d_setup_defaults()
8287 r3di_gpio_dsp_status_set(codec, R3DI_DSP_DOWNLOADED); in r3d_setup_defaults()
8291 ca0113_mmio_gpio_set(codec, 2, false); in r3d_setup_defaults()
8292 ca0113_mmio_gpio_set(codec, 4, true); in r3d_setup_defaults()
8299 dspio_set_uint_param(codec, in r3d_setup_defaults()
8311 static void sbz_setup_defaults(struct hda_codec *codec) in sbz_setup_defaults() argument
8313 struct ca0132_spec *spec = codec->spec; in sbz_setup_defaults()
8321 ca0132_alt_init_analog_mics(codec); in sbz_setup_defaults()
8322 ca0132_alt_start_dsp_audio_streams(codec); in sbz_setup_defaults()
8323 sbz_connect_streams(codec); in sbz_setup_defaults()
8324 sbz_chipio_startup_data(codec); in sbz_setup_defaults()
8331 dspio_set_uint_param(codec, 0x37, 0x08, tmp); in sbz_setup_defaults()
8332 dspio_set_uint_param(codec, 0x37, 0x10, tmp); in sbz_setup_defaults()
8336 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in sbz_setup_defaults()
8340 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in sbz_setup_defaults()
8341 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); in sbz_setup_defaults()
8344 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in sbz_setup_defaults()
8346 ca0132_alt_dsp_initial_mic_setup(codec); in sbz_setup_defaults()
8352 dspio_set_uint_param(codec, in sbz_setup_defaults()
8359 ca0132_alt_init_speaker_tuning(codec); in sbz_setup_defaults()
8365 static void ae5_setup_defaults(struct hda_codec *codec) in ae5_setup_defaults() argument
8367 struct ca0132_spec *spec = codec->spec; in ae5_setup_defaults()
8375 ca0132_alt_init_analog_mics(codec); in ae5_setup_defaults()
8376 ca0132_alt_start_dsp_audio_streams(codec); in ae5_setup_defaults()
8380 dspio_set_uint_param(codec, 0x96, 0x29, tmp); in ae5_setup_defaults()
8381 dspio_set_uint_param(codec, 0x96, 0x2a, tmp); in ae5_setup_defaults()
8382 dspio_set_uint_param(codec, 0x80, 0x0d, tmp); in ae5_setup_defaults()
8383 dspio_set_uint_param(codec, 0x80, 0x0e, tmp); in ae5_setup_defaults()
8385 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae5_setup_defaults()
8386 ca0113_mmio_gpio_set(codec, 0, false); in ae5_setup_defaults()
8387 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ae5_setup_defaults()
8391 dspio_set_uint_param(codec, 0x37, 0x08, tmp); in ae5_setup_defaults()
8392 dspio_set_uint_param(codec, 0x37, 0x10, tmp); in ae5_setup_defaults()
8396 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in ae5_setup_defaults()
8400 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in ae5_setup_defaults()
8401 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); in ae5_setup_defaults()
8404 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in ae5_setup_defaults()
8406 ca0132_alt_dsp_initial_mic_setup(codec); in ae5_setup_defaults()
8407 ae5_post_dsp_register_set(codec); in ae5_setup_defaults()
8408 ae5_post_dsp_param_setup(codec); in ae5_setup_defaults()
8409 ae5_post_dsp_pll_setup(codec); in ae5_setup_defaults()
8410 ae5_post_dsp_stream_setup(codec); in ae5_setup_defaults()
8411 ae5_post_dsp_startup_data(codec); in ae5_setup_defaults()
8417 dspio_set_uint_param(codec, in ae5_setup_defaults()
8424 ca0132_alt_init_speaker_tuning(codec); in ae5_setup_defaults()
8430 static void ae7_setup_defaults(struct hda_codec *codec) in ae7_setup_defaults() argument
8432 struct ca0132_spec *spec = codec->spec; in ae7_setup_defaults()
8440 ca0132_alt_init_analog_mics(codec); in ae7_setup_defaults()
8441 ca0132_alt_start_dsp_audio_streams(codec); in ae7_setup_defaults()
8442 ae7_post_dsp_setup_ports(codec); in ae7_setup_defaults()
8445 dspio_set_uint_param(codec, 0x96, in ae7_setup_defaults()
8447 dspio_set_uint_param(codec, 0x96, in ae7_setup_defaults()
8450 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae7_setup_defaults()
8453 dspio_set_uint_param(codec, 0x80, 0x0d, tmp); in ae7_setup_defaults()
8454 dspio_set_uint_param(codec, 0x80, 0x0e, tmp); in ae7_setup_defaults()
8456 ca0113_mmio_gpio_set(codec, 0, false); in ae7_setup_defaults()
8460 dspio_set_uint_param(codec, 0x37, 0x08, tmp); in ae7_setup_defaults()
8461 dspio_set_uint_param(codec, 0x37, 0x10, tmp); in ae7_setup_defaults()
8465 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); in ae7_setup_defaults()
8469 dspio_set_uint_param(codec, 0x31, 0x00, tmp); in ae7_setup_defaults()
8470 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); in ae7_setup_defaults()
8473 dspio_set_uint_param(codec, 0x32, 0x00, tmp); in ae7_setup_defaults()
8474 ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00); in ae7_setup_defaults()
8480 ca0132_alt_init_analog_mics(codec); in ae7_setup_defaults()
8482 ae7_post_dsp_asi_setup(codec); in ae7_setup_defaults()
8488 ca0113_mmio_gpio_set(codec, 0, true); in ae7_setup_defaults()
8489 ca0113_mmio_gpio_set(codec, 1, true); in ae7_setup_defaults()
8492 ca0113_mmio_command_set(codec, 0x48, 0x0f, 0x04); in ae7_setup_defaults()
8493 ca0113_mmio_command_set(codec, 0x48, 0x10, 0x04); in ae7_setup_defaults()
8494 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x80); in ae7_setup_defaults()
8500 dspio_set_uint_param(codec, in ae7_setup_defaults()
8507 ca0132_alt_init_speaker_tuning(codec); in ae7_setup_defaults()
8513 static void ca0132_init_flags(struct hda_codec *codec) in ca0132_init_flags() argument
8515 struct ca0132_spec *spec = codec->spec; in ca0132_init_flags()
8518 chipio_set_control_flag(codec, CONTROL_FLAG_DSP_96KHZ, 1); in ca0132_init_flags()
8519 chipio_set_control_flag(codec, CONTROL_FLAG_DAC_96KHZ, 1); in ca0132_init_flags()
8520 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_B_96KHZ, 1); in ca0132_init_flags()
8521 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_96KHZ, 1); in ca0132_init_flags()
8522 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_RATE_96KHZ, 1); in ca0132_init_flags()
8523 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0); in ca0132_init_flags()
8524 chipio_set_control_flag(codec, CONTROL_FLAG_SPDIF2OUT, 0); in ca0132_init_flags()
8525 chipio_set_control_flag(codec, in ca0132_init_flags()
8527 chipio_set_control_flag(codec, in ca0132_init_flags()
8530 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0); in ca0132_init_flags()
8531 chipio_set_control_flag(codec, in ca0132_init_flags()
8533 chipio_set_control_flag(codec, in ca0132_init_flags()
8535 chipio_set_control_flag(codec, in ca0132_init_flags()
8537 chipio_set_control_flag(codec, in ca0132_init_flags()
8539 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_HIGH_PASS, 1); in ca0132_init_flags()
8546 static void ca0132_init_params(struct hda_codec *codec) in ca0132_init_params() argument
8548 struct ca0132_spec *spec = codec->spec; in ca0132_init_params()
8551 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); in ca0132_init_params()
8552 chipio_set_conn_rate(codec, 0x0B, SR_48_000); in ca0132_init_params()
8553 chipio_set_control_param(codec, CONTROL_PARAM_SPDIF1_SOURCE, 0); in ca0132_init_params()
8554 chipio_set_control_param(codec, 0, 0); in ca0132_init_params()
8555 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0); in ca0132_init_params()
8558 chipio_set_control_param(codec, CONTROL_PARAM_PORTA_160OHM_GAIN, 6); in ca0132_init_params()
8559 chipio_set_control_param(codec, CONTROL_PARAM_PORTD_160OHM_GAIN, 6); in ca0132_init_params()
8562 static void ca0132_set_dsp_msr(struct hda_codec *codec, bool is96k) in ca0132_set_dsp_msr() argument
8564 chipio_set_control_flag(codec, CONTROL_FLAG_DSP_96KHZ, is96k); in ca0132_set_dsp_msr()
8565 chipio_set_control_flag(codec, CONTROL_FLAG_DAC_96KHZ, is96k); in ca0132_set_dsp_msr()
8566 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_RATE_96KHZ, is96k); in ca0132_set_dsp_msr()
8567 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_CLOCK_196MHZ, is96k); in ca0132_set_dsp_msr()
8568 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_B_96KHZ, is96k); in ca0132_set_dsp_msr()
8569 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_96KHZ, is96k); in ca0132_set_dsp_msr()
8571 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); in ca0132_set_dsp_msr()
8572 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); in ca0132_set_dsp_msr()
8573 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); in ca0132_set_dsp_msr()
8576 static bool ca0132_download_dsp_images(struct hda_codec *codec) in ca0132_download_dsp_images() argument
8579 struct ca0132_spec *spec = codec->spec; in ca0132_download_dsp_images()
8592 codec->card->dev) != 0) in ca0132_download_dsp_images()
8593 codec_dbg(codec, "Desktop firmware not found."); in ca0132_download_dsp_images()
8595 codec_dbg(codec, "Desktop firmware selected."); in ca0132_download_dsp_images()
8599 codec->card->dev) != 0) in ca0132_download_dsp_images()
8600 codec_dbg(codec, "Recon3Di alt firmware not detected."); in ca0132_download_dsp_images()
8602 codec_dbg(codec, "Recon3Di firmware selected."); in ca0132_download_dsp_images()
8609 * exists for your particular codec. in ca0132_download_dsp_images()
8612 codec_dbg(codec, "Default firmware selected."); in ca0132_download_dsp_images()
8614 codec->card->dev) != 0) in ca0132_download_dsp_images()
8619 if (dspload_image(codec, dsp_os_image, 0, 0, true, 0)) { in ca0132_download_dsp_images()
8620 codec_err(codec, "ca0132 DSP load image failed\n"); in ca0132_download_dsp_images()
8624 dsp_loaded = dspload_wait_loaded(codec); in ca0132_download_dsp_images()
8632 static void ca0132_download_dsp(struct hda_codec *codec) in ca0132_download_dsp() argument
8634 struct ca0132_spec *spec = codec->spec; in ca0132_download_dsp()
8643 chipio_enable_clocks(codec); in ca0132_download_dsp()
8647 if (!ca0132_download_dsp_images(codec)) in ca0132_download_dsp()
8655 ca0132_set_dsp_msr(codec, true); in ca0132_download_dsp()
8658 static void ca0132_process_dsp_response(struct hda_codec *codec, in ca0132_process_dsp_response() argument
8661 struct ca0132_spec *spec = codec->spec; in ca0132_process_dsp_response()
8663 codec_dbg(codec, "ca0132_process_dsp_response\n"); in ca0132_process_dsp_response()
8664 snd_hda_power_up_pm(codec); in ca0132_process_dsp_response()
8666 if (dspio_get_response_data(codec) >= 0) in ca0132_process_dsp_response()
8670 dspio_clear_response_queue(codec); in ca0132_process_dsp_response()
8671 snd_hda_power_down_pm(codec); in ca0132_process_dsp_response()
8674 static void hp_callback(struct hda_codec *codec, struct hda_jack_callback *cb) in hp_callback() argument
8676 struct ca0132_spec *spec = codec->spec; in hp_callback()
8682 tbl = snd_hda_jack_tbl_get(codec, cb->nid); in hp_callback()
8688 static void amic_callback(struct hda_codec *codec, struct hda_jack_callback *cb) in amic_callback() argument
8690 struct ca0132_spec *spec = codec->spec; in amic_callback()
8693 ca0132_alt_select_in(codec); in amic_callback()
8695 ca0132_select_mic(codec); in amic_callback()
8698 static void ca0132_setup_unsol(struct hda_codec *codec) in ca0132_setup_unsol() argument
8700 struct ca0132_spec *spec = codec->spec; in ca0132_setup_unsol()
8701 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_hp, hp_callback); in ca0132_setup_unsol()
8702 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_amic1, in ca0132_setup_unsol()
8704 snd_hda_jack_detect_enable_callback(codec, UNSOL_TAG_DSP, in ca0132_setup_unsol()
8708 snd_hda_jack_detect_enable_callback(codec, in ca0132_setup_unsol()
8787 static void ca0132_init_chip(struct hda_codec *codec) in ca0132_init_chip() argument
8789 struct ca0132_spec *spec = codec->spec; in ca0132_init_chip()
8803 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0); in ca0132_init_chip()
8804 chipio_write_no_mutex(codec, 0x18b0a4, 0x000000c2); in ca0132_init_chip()
8806 snd_hda_codec_write(codec, codec->core.afg, 0, in ca0132_init_chip()
8808 snd_hda_codec_write(codec, codec->core.afg, 0, in ca0132_init_chip()
8864 ca0132_init_tuning_defaults(codec); in ca0132_init_chip()
8872 static void r3di_gpio_shutdown(struct hda_codec *codec) in r3di_gpio_shutdown() argument
8874 snd_hda_codec_write(codec, 0x01, 0, AC_VERB_SET_GPIO_DATA, 0x00); in r3di_gpio_shutdown()
8880 static void sbz_region2_exit(struct hda_codec *codec) in sbz_region2_exit() argument
8882 struct ca0132_spec *spec = codec->spec; in sbz_region2_exit()
8890 ca0113_mmio_gpio_set(codec, 0, false); in sbz_region2_exit()
8891 ca0113_mmio_gpio_set(codec, 1, false); in sbz_region2_exit()
8892 ca0113_mmio_gpio_set(codec, 4, true); in sbz_region2_exit()
8893 ca0113_mmio_gpio_set(codec, 5, false); in sbz_region2_exit()
8894 ca0113_mmio_gpio_set(codec, 7, false); in sbz_region2_exit()
8897 static void sbz_set_pin_ctl_default(struct hda_codec *codec) in sbz_set_pin_ctl_default() argument
8902 snd_hda_codec_write(codec, 0x11, 0, in sbz_set_pin_ctl_default()
8906 snd_hda_codec_write(codec, pins[i], 0, in sbz_set_pin_ctl_default()
8910 static void ca0132_clear_unsolicited(struct hda_codec *codec) in ca0132_clear_unsolicited() argument
8916 snd_hda_codec_write(codec, pins[i], 0, in ca0132_clear_unsolicited()
8922 static void sbz_gpio_shutdown_commands(struct hda_codec *codec, int dir, in sbz_gpio_shutdown_commands() argument
8926 snd_hda_codec_write(codec, 0x01, 0, in sbz_gpio_shutdown_commands()
8929 snd_hda_codec_write(codec, 0x01, 0, in sbz_gpio_shutdown_commands()
8933 snd_hda_codec_write(codec, 0x01, 0, in sbz_gpio_shutdown_commands()
8937 static void zxr_dbpro_power_state_shutdown(struct hda_codec *codec) in zxr_dbpro_power_state_shutdown() argument
8943 snd_hda_codec_write(codec, pins[i], 0, in zxr_dbpro_power_state_shutdown()
8947 static void sbz_exit_chip(struct hda_codec *codec) in sbz_exit_chip() argument
8949 chipio_set_stream_control(codec, 0x03, 0); in sbz_exit_chip()
8950 chipio_set_stream_control(codec, 0x04, 0); in sbz_exit_chip()
8953 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, -1); in sbz_exit_chip()
8954 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x05); in sbz_exit_chip()
8955 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x01); in sbz_exit_chip()
8957 chipio_set_stream_control(codec, 0x14, 0); in sbz_exit_chip()
8958 chipio_set_stream_control(codec, 0x0C, 0); in sbz_exit_chip()
8960 chipio_set_conn_rate(codec, 0x41, SR_192_000); in sbz_exit_chip()
8961 chipio_set_conn_rate(codec, 0x91, SR_192_000); in sbz_exit_chip()
8963 chipio_write(codec, 0x18a020, 0x00000083); in sbz_exit_chip()
8965 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x03); in sbz_exit_chip()
8966 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x07); in sbz_exit_chip()
8967 sbz_gpio_shutdown_commands(codec, 0x07, 0x07, 0x06); in sbz_exit_chip()
8969 chipio_set_stream_control(codec, 0x0C, 0); in sbz_exit_chip()
8971 chipio_set_control_param(codec, 0x0D, 0x24); in sbz_exit_chip()
8973 ca0132_clear_unsolicited(codec); in sbz_exit_chip()
8974 sbz_set_pin_ctl_default(codec); in sbz_exit_chip()
8976 snd_hda_codec_write(codec, 0x0B, 0, in sbz_exit_chip()
8979 sbz_region2_exit(codec); in sbz_exit_chip()
8982 static void r3d_exit_chip(struct hda_codec *codec) in r3d_exit_chip() argument
8984 ca0132_clear_unsolicited(codec); in r3d_exit_chip()
8985 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in r3d_exit_chip()
8986 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x5b); in r3d_exit_chip()
8989 static void ae5_exit_chip(struct hda_codec *codec) in ae5_exit_chip() argument
8991 chipio_set_stream_control(codec, 0x03, 0); in ae5_exit_chip()
8992 chipio_set_stream_control(codec, 0x04, 0); in ae5_exit_chip()
8994 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ae5_exit_chip()
8995 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_exit_chip()
8996 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_exit_chip()
8997 ca0113_mmio_command_set(codec, 0x30, 0x30, 0x00); in ae5_exit_chip()
8998 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x00); in ae5_exit_chip()
8999 ca0113_mmio_command_set(codec, 0x30, 0x2d, 0x00); in ae5_exit_chip()
9000 ca0113_mmio_gpio_set(codec, 0, false); in ae5_exit_chip()
9001 ca0113_mmio_gpio_set(codec, 1, false); in ae5_exit_chip()
9003 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ae5_exit_chip()
9004 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in ae5_exit_chip()
9006 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae5_exit_chip()
9008 chipio_set_stream_control(codec, 0x18, 0); in ae5_exit_chip()
9009 chipio_set_stream_control(codec, 0x0c, 0); in ae5_exit_chip()
9011 snd_hda_codec_write(codec, 0x01, 0, 0x724, 0x83); in ae5_exit_chip()
9014 static void ae7_exit_chip(struct hda_codec *codec) in ae7_exit_chip() argument
9016 chipio_set_stream_control(codec, 0x18, 0); in ae7_exit_chip()
9017 chipio_set_stream_source_dest(codec, 0x21, 0xc8, 0xc8); in ae7_exit_chip()
9018 chipio_set_stream_channels(codec, 0x21, 0); in ae7_exit_chip()
9019 chipio_set_control_param(codec, CONTROL_PARAM_NODE_ID, 0x09); in ae7_exit_chip()
9020 chipio_set_control_param(codec, 0x20, 0x01); in ae7_exit_chip()
9022 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 0); in ae7_exit_chip()
9024 chipio_set_stream_control(codec, 0x18, 0); in ae7_exit_chip()
9025 chipio_set_stream_control(codec, 0x0c, 0); in ae7_exit_chip()
9027 ca0113_mmio_command_set(codec, 0x30, 0x2b, 0x00); in ae7_exit_chip()
9028 snd_hda_codec_write(codec, 0x15, 0, 0x724, 0x83); in ae7_exit_chip()
9029 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae7_exit_chip()
9030 ca0113_mmio_command_set(codec, 0x30, 0x30, 0x00); in ae7_exit_chip()
9031 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x00); in ae7_exit_chip()
9032 ca0113_mmio_gpio_set(codec, 0, false); in ae7_exit_chip()
9033 ca0113_mmio_gpio_set(codec, 1, false); in ae7_exit_chip()
9034 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ae7_exit_chip()
9036 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in ae7_exit_chip()
9037 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in ae7_exit_chip()
9040 static void zxr_exit_chip(struct hda_codec *codec) in zxr_exit_chip() argument
9042 chipio_set_stream_control(codec, 0x03, 0); in zxr_exit_chip()
9043 chipio_set_stream_control(codec, 0x04, 0); in zxr_exit_chip()
9044 chipio_set_stream_control(codec, 0x14, 0); in zxr_exit_chip()
9045 chipio_set_stream_control(codec, 0x0C, 0); in zxr_exit_chip()
9047 chipio_set_conn_rate(codec, 0x41, SR_192_000); in zxr_exit_chip()
9048 chipio_set_conn_rate(codec, 0x91, SR_192_000); in zxr_exit_chip()
9050 chipio_write(codec, 0x18a020, 0x00000083); in zxr_exit_chip()
9052 snd_hda_codec_write(codec, 0x01, 0, 0x793, 0x00); in zxr_exit_chip()
9053 snd_hda_codec_write(codec, 0x01, 0, 0x794, 0x53); in zxr_exit_chip()
9055 ca0132_clear_unsolicited(codec); in zxr_exit_chip()
9056 sbz_set_pin_ctl_default(codec); in zxr_exit_chip()
9057 snd_hda_codec_write(codec, 0x0B, 0, AC_VERB_SET_EAPD_BTLENABLE, 0x00); in zxr_exit_chip()
9059 ca0113_mmio_gpio_set(codec, 5, false); in zxr_exit_chip()
9060 ca0113_mmio_gpio_set(codec, 2, false); in zxr_exit_chip()
9061 ca0113_mmio_gpio_set(codec, 3, false); in zxr_exit_chip()
9062 ca0113_mmio_gpio_set(codec, 0, false); in zxr_exit_chip()
9063 ca0113_mmio_gpio_set(codec, 4, true); in zxr_exit_chip()
9064 ca0113_mmio_gpio_set(codec, 0, true); in zxr_exit_chip()
9065 ca0113_mmio_gpio_set(codec, 5, true); in zxr_exit_chip()
9066 ca0113_mmio_gpio_set(codec, 2, false); in zxr_exit_chip()
9067 ca0113_mmio_gpio_set(codec, 3, false); in zxr_exit_chip()
9070 static void ca0132_exit_chip(struct hda_codec *codec) in ca0132_exit_chip() argument
9074 if (dspload_is_loaded(codec)) in ca0132_exit_chip()
9075 dsp_reset(codec); in ca0132_exit_chip()
9086 static void sbz_dsp_startup_check(struct hda_codec *codec) in sbz_dsp_startup_check() argument
9088 struct ca0132_spec *spec = codec->spec; in sbz_dsp_startup_check()
9101 chipio_read(codec, cur_address, &dsp_data_check[i]); in sbz_dsp_startup_check()
9109 codec_dbg(codec, "Startup Check: %d ", failure); in sbz_dsp_startup_check()
9111 codec_info(codec, "DSP not initialized properly. Attempting to fix."); in sbz_dsp_startup_check()
9118 codec_info(codec, "Reloading... Tries left: %d", reload); in sbz_dsp_startup_check()
9119 sbz_exit_chip(codec); in sbz_dsp_startup_check()
9121 codec->patch_ops.init(codec); in sbz_dsp_startup_check()
9124 chipio_read(codec, cur_address, &dsp_data_check[i]); in sbz_dsp_startup_check()
9135 codec_info(codec, "DSP fixed."); in sbz_dsp_startup_check()
9140 …codec_info(codec, "DSP failed to initialize properly. Either try a full shutdown or a suspend to c… in sbz_dsp_startup_check()
9151 static void ca0132_alt_vol_setup(struct hda_codec *codec) in ca0132_alt_vol_setup() argument
9153 snd_hda_codec_write(codec, 0x02, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9154 snd_hda_codec_write(codec, 0x02, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9155 snd_hda_codec_write(codec, 0x03, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9156 snd_hda_codec_write(codec, 0x03, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9157 snd_hda_codec_write(codec, 0x04, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9158 snd_hda_codec_write(codec, 0x04, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9159 snd_hda_codec_write(codec, 0x07, 0, 0x797, 0x00); in ca0132_alt_vol_setup()
9160 snd_hda_codec_write(codec, 0x07, 0, 0x798, 0x00); in ca0132_alt_vol_setup()
9166 static void sbz_pre_dsp_setup(struct hda_codec *codec) in sbz_pre_dsp_setup() argument
9168 struct ca0132_spec *spec = codec->spec; in sbz_pre_dsp_setup()
9173 chipio_write(codec, 0x18b0a4, 0x000000c2); in sbz_pre_dsp_setup()
9175 snd_hda_codec_write(codec, 0x11, 0, in sbz_pre_dsp_setup()
9179 static void r3d_pre_dsp_setup(struct hda_codec *codec) in r3d_pre_dsp_setup() argument
9181 chipio_write(codec, 0x18b0a4, 0x000000c2); in r3d_pre_dsp_setup()
9183 chipio_8051_write_exram(codec, 0x1c1e, 0x5b); in r3d_pre_dsp_setup()
9185 snd_hda_codec_write(codec, 0x11, 0, in r3d_pre_dsp_setup()
9189 static void r3di_pre_dsp_setup(struct hda_codec *codec) in r3di_pre_dsp_setup() argument
9191 chipio_write(codec, 0x18b0a4, 0x000000c2); in r3di_pre_dsp_setup()
9193 chipio_8051_write_exram(codec, 0x1c1e, 0x5b); in r3di_pre_dsp_setup()
9194 chipio_8051_write_exram(codec, 0x1920, 0x00); in r3di_pre_dsp_setup()
9195 chipio_8051_write_exram(codec, 0x1921, 0x40); in r3di_pre_dsp_setup()
9197 snd_hda_codec_write(codec, 0x11, 0, in r3di_pre_dsp_setup()
9206 static void zxr_pre_dsp_setup(struct hda_codec *codec) in zxr_pre_dsp_setup() argument
9212 chipio_write(codec, 0x189000, 0x0001f100); in zxr_pre_dsp_setup()
9214 chipio_write(codec, 0x18900c, 0x0001f100); in zxr_pre_dsp_setup()
9223 chipio_8051_write_exram(codec, 0xfa92, 0x22); in zxr_pre_dsp_setup()
9225 chipio_8051_write_pll_pmu(codec, 0x51, 0x98); in zxr_pre_dsp_setup()
9227 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x725, 0x82); in zxr_pre_dsp_setup()
9228 chipio_set_control_param(codec, CONTROL_PARAM_ASI, 3); in zxr_pre_dsp_setup()
9230 chipio_write(codec, 0x18902c, 0x00000000); in zxr_pre_dsp_setup()
9232 chipio_write(codec, 0x18902c, 0x00000003); in zxr_pre_dsp_setup()
9236 chipio_8051_write_pll_pmu(codec, addr[i], data[i]); in zxr_pre_dsp_setup()
9279 static void ca0132_mmio_init_sbz(struct hda_codec *codec) in ca0132_mmio_init_sbz() argument
9281 struct ca0132_spec *spec = codec->spec; in ca0132_mmio_init_sbz()
9329 static void ca0132_mmio_init_ae5(struct hda_codec *codec) in ca0132_mmio_init_ae5() argument
9331 struct ca0132_spec *spec = codec->spec; in ca0132_mmio_init_ae5()
9361 static void ca0132_mmio_init(struct hda_codec *codec) in ca0132_mmio_init() argument
9363 struct ca0132_spec *spec = codec->spec; in ca0132_mmio_init()
9369 ca0132_mmio_init_sbz(codec); in ca0132_mmio_init()
9372 ca0132_mmio_init_ae5(codec); in ca0132_mmio_init()
9391 * eventually resets the codec with the 0x7ff verb. Not quite sure why it does
9394 static void ae5_register_set(struct hda_codec *codec) in ae5_register_set() argument
9396 struct ca0132_spec *spec = codec->spec; in ae5_register_set()
9404 chipio_8051_write_pll_pmu(codec, 0x41, 0xc8); in ae5_register_set()
9406 chipio_8051_write_direct(codec, 0x93, 0x10); in ae5_register_set()
9407 chipio_8051_write_pll_pmu(codec, 0x44, 0xc2); in ae5_register_set()
9435 ca0113_mmio_command_set_type2(codec, 0x48, 0x07, 0x83); in ae5_register_set()
9436 ca0113_mmio_command_set(codec, 0x30, 0x2e, 0x3f); in ae5_register_set()
9438 ca0113_mmio_command_set(codec, 0x30, 0x2d, 0x3f); in ae5_register_set()
9441 chipio_8051_write_direct(codec, 0x90, 0x00); in ae5_register_set()
9442 chipio_8051_write_direct(codec, 0x90, 0x10); in ae5_register_set()
9445 ca0113_mmio_command_set(codec, 0x48, 0x07, 0x83); in ae5_register_set()
9453 static void ca0132_alt_init(struct hda_codec *codec) in ca0132_alt_init() argument
9455 struct ca0132_spec *spec = codec->spec; in ca0132_alt_init()
9457 ca0132_alt_vol_setup(codec); in ca0132_alt_init()
9461 codec_dbg(codec, "SBZ alt_init"); in ca0132_alt_init()
9462 ca0132_gpio_init(codec); in ca0132_alt_init()
9463 sbz_pre_dsp_setup(codec); in ca0132_alt_init()
9464 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9465 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9468 codec_dbg(codec, "R3DI alt_init"); in ca0132_alt_init()
9469 ca0132_gpio_init(codec); in ca0132_alt_init()
9470 ca0132_gpio_setup(codec); in ca0132_alt_init()
9471 r3di_gpio_dsp_status_set(codec, R3DI_DSP_DOWNLOADING); in ca0132_alt_init()
9472 r3di_pre_dsp_setup(codec); in ca0132_alt_init()
9473 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9474 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 0x6FF, 0xC4); in ca0132_alt_init()
9477 r3d_pre_dsp_setup(codec); in ca0132_alt_init()
9478 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9479 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9482 ca0132_gpio_init(codec); in ca0132_alt_init()
9483 chipio_8051_write_pll_pmu(codec, 0x49, 0x88); in ca0132_alt_init()
9484 chipio_write(codec, 0x18b030, 0x00000020); in ca0132_alt_init()
9485 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9486 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9487 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ca0132_alt_init()
9490 ca0132_gpio_init(codec); in ca0132_alt_init()
9491 chipio_8051_write_pll_pmu(codec, 0x49, 0x88); in ca0132_alt_init()
9492 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9493 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9494 chipio_write(codec, 0x18b008, 0x000000f8); in ca0132_alt_init()
9495 chipio_write(codec, 0x18b008, 0x000000f0); in ca0132_alt_init()
9496 chipio_write(codec, 0x18b030, 0x00000020); in ca0132_alt_init()
9497 ca0113_mmio_command_set(codec, 0x30, 0x32, 0x3f); in ca0132_alt_init()
9500 chipio_8051_write_pll_pmu(codec, 0x49, 0x88); in ca0132_alt_init()
9501 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_alt_init()
9502 snd_hda_sequence_write(codec, spec->desktop_init_verbs); in ca0132_alt_init()
9503 zxr_pre_dsp_setup(codec); in ca0132_alt_init()
9510 static int ca0132_init(struct hda_codec *codec) in ca0132_init() argument
9512 struct ca0132_spec *spec = codec->spec; in ca0132_init()
9519 * there's only two reasons for it. One, the codec has awaken from a in ca0132_init()
9528 dsp_loaded = dspload_is_loaded(codec); in ca0132_init()
9534 sbz_dsp_startup_check(codec); in ca0132_init()
9544 ca0132_mmio_init(codec); in ca0132_init()
9546 snd_hda_power_up_pm(codec); in ca0132_init()
9549 ae5_register_set(codec); in ca0132_init()
9551 ca0132_init_params(codec); in ca0132_init()
9552 ca0132_init_flags(codec); in ca0132_init()
9554 snd_hda_sequence_write(codec, spec->base_init_verbs); in ca0132_init()
9557 ca0132_alt_init(codec); in ca0132_init()
9559 ca0132_download_dsp(codec); in ca0132_init()
9561 ca0132_refresh_widget_caps(codec); in ca0132_init()
9566 r3d_setup_defaults(codec); in ca0132_init()
9570 sbz_setup_defaults(codec); in ca0132_init()
9573 ae5_setup_defaults(codec); in ca0132_init()
9576 ae7_setup_defaults(codec); in ca0132_init()
9579 ca0132_setup_defaults(codec); in ca0132_init()
9580 ca0132_init_analog_mic2(codec); in ca0132_init()
9581 ca0132_init_dmic(codec); in ca0132_init()
9586 init_output(codec, spec->out_pins[i], spec->dacs[0]); in ca0132_init()
9588 init_output(codec, cfg->dig_out_pins[0], spec->dig_out); in ca0132_init()
9591 init_input(codec, spec->input_pins[i], spec->adcs[i]); in ca0132_init()
9593 init_input(codec, cfg->dig_in_pin, spec->dig_in); in ca0132_init()
9596 snd_hda_sequence_write(codec, spec->chip_init_verbs); in ca0132_init()
9597 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in ca0132_init()
9599 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, in ca0132_init()
9604 ca0132_gpio_setup(codec); in ca0132_init()
9606 snd_hda_sequence_write(codec, spec->spec_init_verbs); in ca0132_init()
9608 ca0132_alt_select_out(codec); in ca0132_init()
9609 ca0132_alt_select_in(codec); in ca0132_init()
9611 ca0132_select_out(codec); in ca0132_init()
9612 ca0132_select_mic(codec); in ca0132_init()
9615 snd_hda_jack_report_sync(codec); in ca0132_init()
9623 ca0132_pe_switch_set(codec); in ca0132_init()
9626 snd_hda_power_down_pm(codec); in ca0132_init()
9631 static int dbpro_init(struct hda_codec *codec) in dbpro_init() argument
9633 struct ca0132_spec *spec = codec->spec; in dbpro_init()
9637 init_output(codec, cfg->dig_out_pins[0], spec->dig_out); in dbpro_init()
9638 init_input(codec, cfg->dig_in_pin, spec->dig_in); in dbpro_init()
9641 init_input(codec, spec->input_pins[i], spec->adcs[i]); in dbpro_init()
9646 static void ca0132_free(struct hda_codec *codec) in ca0132_free() argument
9648 struct ca0132_spec *spec = codec->spec; in ca0132_free()
9651 snd_hda_power_up(codec); in ca0132_free()
9654 sbz_exit_chip(codec); in ca0132_free()
9657 zxr_exit_chip(codec); in ca0132_free()
9660 r3d_exit_chip(codec); in ca0132_free()
9663 ae5_exit_chip(codec); in ca0132_free()
9666 ae7_exit_chip(codec); in ca0132_free()
9669 r3di_gpio_shutdown(codec); in ca0132_free()
9675 snd_hda_sequence_write(codec, spec->base_exit_verbs); in ca0132_free()
9676 ca0132_exit_chip(codec); in ca0132_free()
9678 snd_hda_power_down(codec); in ca0132_free()
9681 pci_iounmap(codec->bus->pci, spec->mem_base); in ca0132_free()
9684 kfree(codec->spec); in ca0132_free()
9687 static void dbpro_free(struct hda_codec *codec) in dbpro_free() argument
9689 struct ca0132_spec *spec = codec->spec; in dbpro_free()
9691 zxr_dbpro_power_state_shutdown(codec); in dbpro_free()
9694 kfree(codec->spec); in dbpro_free()
9697 static int ca0132_suspend(struct hda_codec *codec) in ca0132_suspend() argument
9699 struct ca0132_spec *spec = codec->spec; in ca0132_suspend()
9721 static void ca0132_config(struct hda_codec *codec) in ca0132_config() argument
9723 struct ca0132_spec *spec = codec->spec; in ca0132_config()
9739 codec_dbg(codec, "%s: QUIRK_ALIENWARE applied.\n", __func__); in ca0132_config()
9740 snd_hda_apply_pincfgs(codec, alienware_pincfgs); in ca0132_config()
9743 codec_dbg(codec, "%s: QUIRK_SBZ applied.\n", __func__); in ca0132_config()
9744 snd_hda_apply_pincfgs(codec, sbz_pincfgs); in ca0132_config()
9747 codec_dbg(codec, "%s: QUIRK_ZXR applied.\n", __func__); in ca0132_config()
9748 snd_hda_apply_pincfgs(codec, zxr_pincfgs); in ca0132_config()
9751 codec_dbg(codec, "%s: QUIRK_R3D applied.\n", __func__); in ca0132_config()
9752 snd_hda_apply_pincfgs(codec, r3d_pincfgs); in ca0132_config()
9755 codec_dbg(codec, "%s: QUIRK_R3DI applied.\n", __func__); in ca0132_config()
9756 snd_hda_apply_pincfgs(codec, r3di_pincfgs); in ca0132_config()
9759 codec_dbg(codec, "%s: QUIRK_AE5 applied.\n", __func__); in ca0132_config()
9760 snd_hda_apply_pincfgs(codec, ae5_pincfgs); in ca0132_config()
9763 codec_dbg(codec, "%s: QUIRK_AE7 applied.\n", __func__); in ca0132_config()
9764 snd_hda_apply_pincfgs(codec, ae7_pincfgs); in ca0132_config()
9921 static int ca0132_prepare_verbs(struct hda_codec *codec) in ca0132_prepare_verbs() argument
9925 struct ca0132_spec *spec = codec->spec; in ca0132_prepare_verbs()
9966 * Sound Blaster Z cards. However, they have different HDA codec subsystem
9970 static void sbz_detect_quirk(struct hda_codec *codec) in sbz_detect_quirk() argument
9972 switch (codec->core.subsystem_id) { in sbz_detect_quirk()
9974 codec->fixup_id = QUIRK_ZXR; in sbz_detect_quirk()
9977 codec->fixup_id = QUIRK_ZXR_DBPRO; in sbz_detect_quirk()
9980 codec->fixup_id = QUIRK_SBZ; in sbz_detect_quirk()
9985 static int patch_ca0132(struct hda_codec *codec) in patch_ca0132() argument
9990 codec_dbg(codec, "patch_ca0132\n"); in patch_ca0132()
9995 codec->spec = spec; in patch_ca0132()
9996 spec->codec = codec; in patch_ca0132()
9998 /* Detect codec quirk */ in patch_ca0132()
9999 snd_hda_pick_fixup(codec, ca0132_quirk_models, ca0132_quirks, NULL); in patch_ca0132()
10001 sbz_detect_quirk(codec); in patch_ca0132()
10004 codec->patch_ops = dbpro_patch_ops; in patch_ca0132()
10006 codec->patch_ops = ca0132_patch_ops; in patch_ca0132()
10008 codec->pcm_format_first = 1; in patch_ca0132()
10009 codec->no_sticky_stream = 1; in patch_ca0132()
10019 snd_hda_codec_set_name(codec, "Sound Blaster Z"); in patch_ca0132()
10023 snd_hda_codec_set_name(codec, "Sound Blaster ZxR"); in patch_ca0132()
10029 snd_hda_codec_set_name(codec, "Recon3D"); in patch_ca0132()
10033 snd_hda_codec_set_name(codec, "Recon3Di"); in patch_ca0132()
10037 snd_hda_codec_set_name(codec, "Sound BlasterX AE-5"); in patch_ca0132()
10041 snd_hda_codec_set_name(codec, "Sound Blaster AE-7"); in patch_ca0132()
10073 spec->mem_base = pci_iomap(codec->bus->pci, 2, 0xC20); in patch_ca0132()
10075 codec_warn(codec, "pci_iomap failed! Setting quirk to QUIRK_NONE."); in patch_ca0132()
10076 codec->fixup_id = QUIRK_NONE; in patch_ca0132()
10086 ca0132_init_chip(codec); in patch_ca0132()
10088 ca0132_config(codec); in patch_ca0132()
10090 err = ca0132_prepare_verbs(codec); in patch_ca0132()
10094 err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, NULL); in patch_ca0132()
10098 ca0132_setup_unsol(codec); in patch_ca0132()
10103 ca0132_free(codec); in patch_ca0132()
10117 MODULE_DESCRIPTION("Creative Sound Core3D codec");