コード例 #1
0
static void xonar_d2_init(struct oxygen *chip)
{
    struct xonar_data *data = chip->model_data;

    data->anti_pop_delay = 300;
    data->output_enable_bit = GPIO_D2_OUTPUT_ENABLE;
    data->pcm1796_oversampling = PCM1796_OS_64;
    if (data->model == MODEL_D2X) {
        data->ext_power_reg = OXYGEN_GPIO_DATA;
        data->ext_power_int_reg = OXYGEN_GPIO_INTERRUPT_MASK;
        data->ext_power_bit = GPIO_D2X_EXT_POWER;
        oxygen_clear_bits16(chip, OXYGEN_GPIO_CONTROL,
                            GPIO_D2X_EXT_POWER);
    }

    pcm1796_init(chip);

    oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL, GPIO_D2_ALT);
    oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA, GPIO_D2_ALT);

    xonar_common_init(chip);

    snd_component_add(chip->card, "PCM1796");
    snd_component_add(chip->card, "CS5381");
}
コード例 #2
0
static void xonar_d1_init(struct oxygen *chip)
{
    struct xonar_data *data = chip->model_data;

    data->anti_pop_delay = 800;
    data->output_enable_bit = GPIO_DX_OUTPUT_ENABLE;
    data->cs4398_fm = CS4398_FM_SINGLE | CS4398_DEM_NONE | CS4398_DIF_LJUST;
    data->cs4362a_fm = CS4362A_FM_SINGLE |
                       CS4362A_ATAPI_B_R | CS4362A_ATAPI_A_L;
    if (data->model == MODEL_DX) {
        data->ext_power_reg = OXYGEN_GPI_DATA;
        data->ext_power_int_reg = OXYGEN_GPI_INTERRUPT_MASK;
        data->ext_power_bit = GPI_DX_EXT_POWER;
    }

    oxygen_write16(chip, OXYGEN_2WIRE_BUS_STATUS,
                   OXYGEN_2WIRE_LENGTH_8 |
                   OXYGEN_2WIRE_INTERRUPT_MASK |
                   OXYGEN_2WIRE_SPEED_FAST);

    cs43xx_init(chip);

    oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL,
                      GPIO_DX_FRONT_PANEL | GPIO_DX_INPUT_ROUTE);
    oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA,
                        GPIO_DX_FRONT_PANEL | GPIO_DX_INPUT_ROUTE);

    xonar_common_init(chip);

    snd_component_add(chip->card, "CS4398");
    snd_component_add(chip->card, "CS4362A");
    snd_component_add(chip->card, "CS5361");
}
コード例 #3
0
ファイル: virtuoso.c プロジェクト: antonywcl/AR-5315u_PLD
static void xonar_stx_init(struct oxygen *chip)
{
	struct xonar_data *data = chip->model_data;

	oxygen_write16(chip, OXYGEN_2WIRE_BUS_STATUS,
		       OXYGEN_2WIRE_LENGTH_8 |
		       OXYGEN_2WIRE_INTERRUPT_MASK |
		       OXYGEN_2WIRE_SPEED_FAST);

	data->anti_pop_delay = 100;
	data->dacs = 1;
	data->output_enable_bit = GPIO_DX_OUTPUT_ENABLE;
	data->ext_power_reg = OXYGEN_GPI_DATA;
	data->ext_power_int_reg = OXYGEN_GPI_INTERRUPT_MASK;
	data->ext_power_bit = GPI_DX_EXT_POWER;
	data->pcm1796_oversampling = PCM1796_OS_64;

	pcm1796_init(chip);

	oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL,
			  GPIO_DX_INPUT_ROUTE | GPIO_ST_HP_REAR | GPIO_ST_HP);
	oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA,
			    GPIO_DX_INPUT_ROUTE | GPIO_ST_HP_REAR | GPIO_ST_HP);

	xonar_common_init(chip);

	snd_component_add(chip->card, "PCM1792A");
	snd_component_add(chip->card, "CS5381");
}
コード例 #4
0
ファイル: virtuoso.c プロジェクト: 274914765/C
static void xonar_d2_init(struct oxygen *chip)
{
    struct xonar_data *data = chip->model_data;
    unsigned int i;

    data->anti_pop_delay = 300;
    data->output_enable_bit = GPIO_D2_OUTPUT_ENABLE;

    for (i = 0; i < 4; ++i) {
        pcm1796_write(chip, i, 18, PCM1796_MUTE | PCM1796_DMF_DISABLED |
                  PCM1796_FMT_24_LJUST | PCM1796_ATLD);
        pcm1796_write(chip, i, 19, PCM1796_FLT_SHARP | PCM1796_ATS_1);
        pcm1796_write(chip, i, 20, PCM1796_OS_64);
        pcm1796_write(chip, i, 21, 0);
        pcm1796_write(chip, i, 16, 0x0f); /* set ATL/ATR after ATLD */
        pcm1796_write(chip, i, 17, 0x0f);
    }

    oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL, GPIO_D2_ALT);
    oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA, GPIO_D2_ALT);

    xonar_common_init(chip);

    snd_component_add(chip->card, "PCM1796");
    snd_component_add(chip->card, "CS5381");
}
コード例 #5
0
ファイル: virtuoso.c プロジェクト: 274914765/C
static void xonar_dx_init(struct oxygen *chip)
{
    struct xonar_data *data = chip->model_data;

    data->anti_pop_delay = 800;
    data->output_enable_bit = GPIO_DX_OUTPUT_ENABLE;
    data->ext_power_reg = OXYGEN_GPI_DATA;
    data->ext_power_int_reg = OXYGEN_GPI_INTERRUPT_MASK;
    data->ext_power_bit = GPI_DX_EXT_POWER;

    oxygen_write16(chip, OXYGEN_2WIRE_BUS_STATUS,
               OXYGEN_2WIRE_LENGTH_8 |
               OXYGEN_2WIRE_INTERRUPT_MASK |
               OXYGEN_2WIRE_SPEED_FAST);

    /* set CPEN (control port mode) and power down */
    cs4398_write(chip, 8, CS4398_CPEN | CS4398_PDN);
    cs4362a_write(chip, 0x01, CS4362A_PDN | CS4362A_CPEN);
    /* configure */
    cs4398_write(chip, 2, CS4398_FM_SINGLE |
             CS4398_DEM_NONE | CS4398_DIF_LJUST);
    cs4398_write(chip, 3, CS4398_ATAPI_B_R | CS4398_ATAPI_A_L);
    cs4398_write(chip, 4, CS4398_MUTEP_LOW | CS4398_PAMUTE);
    cs4398_write(chip, 5, 0xfe);
    cs4398_write(chip, 6, 0xfe);
    cs4398_write(chip, 7, CS4398_RMP_DN | CS4398_RMP_UP |
             CS4398_ZERO_CROSS | CS4398_SOFT_RAMP);
    cs4362a_write(chip, 0x02, CS4362A_DIF_LJUST);
    cs4362a_write(chip, 0x03, CS4362A_MUTEC_6 | CS4362A_AMUTE |
              CS4362A_RMP_UP | CS4362A_ZERO_CROSS | CS4362A_SOFT_RAMP);
    cs4362a_write(chip, 0x04, CS4362A_RMP_DN | CS4362A_DEM_NONE);
    cs4362a_write(chip, 0x05, 0);
    cs4362a_write(chip, 0x06, CS4362A_FM_SINGLE |
              CS4362A_ATAPI_B_R | CS4362A_ATAPI_A_L);
    cs4362a_write(chip, 0x07, 0x7f | CS4362A_MUTE);
    cs4362a_write(chip, 0x08, 0x7f | CS4362A_MUTE);
    cs4362a_write(chip, 0x09, CS4362A_FM_SINGLE |
              CS4362A_ATAPI_B_R | CS4362A_ATAPI_A_L);
    cs4362a_write(chip, 0x0a, 0x7f | CS4362A_MUTE);
    cs4362a_write(chip, 0x0b, 0x7f | CS4362A_MUTE);
    cs4362a_write(chip, 0x0c, CS4362A_FM_SINGLE |
              CS4362A_ATAPI_B_R | CS4362A_ATAPI_A_L);
    cs4362a_write(chip, 0x0d, 0x7f | CS4362A_MUTE);
    cs4362a_write(chip, 0x0e, 0x7f | CS4362A_MUTE);
    /* clear power down */
    cs4398_write(chip, 8, CS4398_CPEN);
    cs4362a_write(chip, 0x01, CS4362A_CPEN);

    oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL,
              GPIO_DX_FRONT_PANEL | GPIO_DX_INPUT_ROUTE);
    oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA,
                GPIO_DX_FRONT_PANEL | GPIO_DX_INPUT_ROUTE);

    xonar_common_init(chip);

    snd_component_add(chip->card, "CS4398");
    snd_component_add(chip->card, "CS4362A");
    snd_component_add(chip->card, "CS5361");
}
コード例 #6
0
ファイル: virtuoso.c プロジェクト: antonywcl/AR-5315u_PLD
static void xonar_d2_init(struct oxygen *chip)
{
	struct xonar_data *data = chip->model_data;

	data->anti_pop_delay = 300;
	data->dacs = 4;
	data->output_enable_bit = GPIO_D2_OUTPUT_ENABLE;
	data->pcm1796_oversampling = PCM1796_OS_64;

	pcm1796_init(chip);

	oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL, GPIO_D2_ALT);
	oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA, GPIO_D2_ALT);

	xonar_common_init(chip);

	snd_component_add(chip->card, "PCM1796");
	snd_component_add(chip->card, "CS5381");
}
コード例 #7
0
ファイル: virtuoso.c プロジェクト: antonywcl/AR-5315u_PLD
static void xonar_hdav_init(struct oxygen *chip)
{
	struct xonar_data *data = chip->model_data;
	u8 param;

	oxygen_write16(chip, OXYGEN_2WIRE_BUS_STATUS,
		       OXYGEN_2WIRE_LENGTH_8 |
		       OXYGEN_2WIRE_INTERRUPT_MASK |
		       OXYGEN_2WIRE_SPEED_FAST);

	data->anti_pop_delay = 100;
	data->dacs = chip->model.private_data == MODEL_HDAV_H6 ? 4 : 1;
	data->output_enable_bit = GPIO_DX_OUTPUT_ENABLE;
	data->ext_power_reg = OXYGEN_GPI_DATA;
	data->ext_power_int_reg = OXYGEN_GPI_INTERRUPT_MASK;
	data->ext_power_bit = GPI_DX_EXT_POWER;
	data->pcm1796_oversampling = PCM1796_OS_64;

	pcm1796_init(chip);

	oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL, GPIO_DX_INPUT_ROUTE);
	oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA, GPIO_DX_INPUT_ROUTE);

	oxygen_reset_uart(chip);
	param = 0;
	hdmi_write_command(chip, 0x61, 1, &param);
	param = 1;
	hdmi_write_command(chip, 0x74, 1, &param);
	data->hdmi_params[1] = IEC958_AES3_CON_FS_48000;
	data->hdmi_params[4] = 1;
	hdmi_write_command(chip, 0x54, 5, data->hdmi_params);

	xonar_common_init(chip);

	snd_component_add(chip->card, "PCM1796");
	snd_component_add(chip->card, "CS5381");
}