
At Mon, 11 May 2015 22:17:01 +0200, Gabriele Martino wrote:
On 04/05/2015 14:30, Takashi Iwai wrote:
Hm, this can be changed via a proper pin config?
In anyway, I'm traveling in this week and next week, so cannot debug the things. Will check it later once when I back from vacation. Just ping me.
Hi, this should be the final version. There are some big changes:
- all the pin configuration is now performed in ca0132_config(), no more
static definitions
- some initialization verbs depend on the pin configuration, so they are
generated from the pin configuration
- the quirks management code now is a simple "if" in the pin configuration
I can't split the patch because the quirks part requires the dynamic verbs generation. I'm using this since 5 May without any trouble, so it shouldn't blow up things.
The patch looks almost OK, but just a few things:
+static int ca0132_prepare_verbs(struct hda_codec *codec) +{
- struct ca0132_spec *spec = codec->spec;
- static struct hda_verb empty_verb = {};
+#define NUM_SPEC_VERBS 4
- spec->chip_init_verbs = ca0132_init_verbs0;
- spec->spec_init_verbs = kzalloc(sizeof(struct hda_verb) * NUM_SPEC_VERBS, GFP_KERNEL);
- if (!spec->spec_init_verbs)
return -ENOMEM;
- /* HP jack autodetection */
- spec->spec_init_verbs[0].nid = spec->unsol_tag_hp;
- spec->spec_init_verbs[0].param = AC_VERB_SET_UNSOLICITED_ENABLE;
- spec->spec_init_verbs[0].verb = AC_USRSP_EN | spec->unsol_tag_hp;
- /* MIC1 jack autodetection */
- spec->spec_init_verbs[1].nid = spec->unsol_tag_amic1;
- spec->spec_init_verbs[1].param = AC_VERB_SET_UNSOLICITED_ENABLE;
- spec->spec_init_verbs[1].verb = AC_USRSP_EN | spec->unsol_tag_amic1;
- /* config EAPD */
- spec->spec_init_verbs[2].nid = 0x0b;
- spec->spec_init_verbs[2].param = 0x78D;
- spec->spec_init_verbs[2].verb = 0x00;
- /* Previously commented configuration */
- /*
- spec->spec_init_verbs[3].nid = 0x0b;
- spec->spec_init_verbs[3].param = AC_VERB_SET_EAPD_BTLENABLE;
- spec->spec_init_verbs[3].verb = 0x02;
- spec->spec_init_verbs[4].nid = 0x10;
- spec->spec_init_verbs[4].param = 0x78D;
- spec->spec_init_verbs[4].verb = 0x02;
- spec->spec_init_verbs[5].nid = 0x10;
- spec->spec_init_verbs[5].param = AC_VERB_SET_EAPD_BTLENABLE;
- spec->spec_init_verbs[5].verb = 0x02;
- */
- /* Empty element */
- spec->spec_init_verbs[NUM_SPEC_VERBS-1] = empty_verb;
This line is superfluous when you allocated via kzalloc().
Could you fix it and give a proper patch changelog and your signed-off-by tag?
thanks,
Takashi