blob: 7fd9853d8e900b7ad9f42677fba8277a47556528 [file] [log] [blame]
Matt DeVillier1b25f1b2018-09-14 21:39:00 -05001/*
2 * This file is part of the coreboot project.
3 *
4 * Copyright (C) 2014 Google Inc.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License as
8 * published by the Free Software Foundation; version 2 of
9 * the License.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 */
16
17#include <device/azalia_device.h>
18
19const u32 cim_verb_data[] = {
20 /* coreboot specific header */
21 0x10ec0283, // Codec Vendor / Device ID: Realtek ALC283
22 0x10ec0283, // Subsystem ID
23 0x0000000d, // Number of jacks (NID entries)
24
25 0x0017ff00, // Function Reset
26 0x0017ff00, // Double Function Reset
27 0x000F0000, // Pad - get vendor id
28 0x000F0002, // Pad - get revision id
29
30 /* Bits 31:28 - Codec Address */
31 /* Bits 27:20 - NID */
32 /* Bits 19:8 - Verb ID */
33 /* Bits 7:0 - Payload */
34
35 /* NID 0x01, HDA Codec Subsystem ID Verb Table: 0x10ec0283 */
36 0x00172083,
37 0x00172102,
38 0x001722ec,
39 0x00172310,
40
41 /* Pin Widget Verb Table */
42
43 /* Pin Complex (NID 0x12) DMIC - Disabled */
44 0x01271cf0, //
45 0x01271d11, //
46 0x01271e11, //
47 0x01271f41, //
48
49 /* Pin Complex (NID 0x14) SPKR-OUT - Internal Speakers */
50 0x01471c10, // group 1, cap 0
51 0x01471d01, // no connector, no jack detect
52 0x01471e17, // speaker out, analog
53 0x01471f90, // fixed function, internal, Location N/A
54
55 /* Pin Complex (NID 0x17) MONO Out - Disabled */
56 0x01771cf0, //
57 0x01771d11, //
58 0x01771e11, //
59 0x01771f41, //
60
61 /* Pin Complex (NID 0x18) Disabled */
62 0x01871cf0, //
63 0x01871d11, //
64 0x01871e11, //
65 0x01871f41, //
66
67 /* Pin Complex (NID 0x19) MIC2 - 3.5mm Jack */
68 0x01971c20, // group2, cap 0
69 0x01971d10, // black, jack detect
70 0x01971ea1, // Mic in, 3.5mm Jack
71 0x01971f03, // connector, External left panel
72
73 /* Pin Complex (NID 0x1A) LINE1 - Internal Mic */
74 0x01a71c11, // group 1, cap 1
75 0x01a71d01, // no connector, no jack detect
76 0x01a71ea7, // mic in, analog connection
77 0x01a71f90, // Fixed function, internal, Location N/A
78
79 /* Pin Complex (NID 0x1B) LINE2 - Disabled */
80 0x01b71cf0, //
81 0x01b71d11, //
82 0x01b71e11, //
83 0x01b71f41, //
84
85 /* Pin Complex (NID 0x1D) PCBeep */
86 0x01d71c2d, // eapd low on ex-amp, laptop, custom enable
87 0x01d71d81, // mute spkr on hpout
88 0x01d71e15, // pcbeep en able, checksum
89 0x01d71f40, // no physical, Internal, Location N/A
90
91 /* Pin Complex (NID 0x1E) SPDIF-OUT - Disabled*/
92 0x01e71cf0, //
93 0x01e71d11, //
94 0x01e71e11, //
95 0x01e71f41, //
96
97 /* Pin Complex (NID 0x21) HP-OUT - 3.5mm Jack*/
98 0x02171c21, // group2, cap 1
99 0x02171d10, // black, jack detect
100 0x02171e21, // HPOut, 3.5mm Jack
101 0x02171f03, // connector, left panel
102
103 /* Undocumented settings from Realtek (needed for beep_gen) */
104 /* Widget node 0x20 */
105 0x02050010,
106 0x02040c20,
107 0x0205001b,
108 0x0204081b,
109};
110
111const u32 pc_beep_verbs[] = {
112 0x00170500, /* power up everything (codec, dac, adc, mixers) */
113 0x01470c00, /* set speaker EAPD pin to low */
114 0x01470740, /* enable speaker out */
115 0x0143b01f, /* unmute speaker */
116 0x00c37100, /* unmute mixer nid 0xc input 1 */
117 0x00b37410, /* unmute mixer nid 0xb beep input and set volume */
118 0x01470c02, /* set speaker EAPD pin to high */
119};
120
121AZALIA_ARRAY_SIZES;