aboutsummaryrefslogtreecommitdiff
path: root/src/mainboard/lenovo/x200/hda_verb.h
diff options
context:
space:
mode:
authorVladimir Serbinenko <phcoder@gmail.com>2014-08-12 22:51:53 +0200
committerVladimir Serbinenko <phcoder@gmail.com>2014-08-13 09:35:36 +0200
commit61ffb4ca2e53004d3a282bfc2c97e58131cc9ef3 (patch)
treed642a289367c4f620dca125da348113260195bbc /src/mainboard/lenovo/x200/hda_verb.h
parent883e7acc65e1edba8b2453decf23c88eafeae8b0 (diff)
lenovo/x200: New mainboard.
Change-Id: I64e59648064d5875907b5057e2f9f72f2c5997b1 Signed-off-by: Vladimir Serbinenko <phcoder@gmail.com> Reviewed-on: http://review.coreboot.org/6631 Tested-by: build bot (Jenkins) Reviewed-by: Edward O'Callaghan <eocallaghan@alterapraxis.com>
Diffstat (limited to 'src/mainboard/lenovo/x200/hda_verb.h')
-rw-r--r--src/mainboard/lenovo/x200/hda_verb.h58
1 files changed, 58 insertions, 0 deletions
diff --git a/src/mainboard/lenovo/x200/hda_verb.h b/src/mainboard/lenovo/x200/hda_verb.h
new file mode 100644
index 0000000000..6c9f60b057
--- /dev/null
+++ b/src/mainboard/lenovo/x200/hda_verb.h
@@ -0,0 +1,58 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (C) 2007-2009 coresystems GmbH
+ * 2012 secunet Security Networks AG
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#define PIN_CFG(pin, val) \
+ (pin << 20) | ( 0x71c << 8) | (val & 0xff), \
+ (pin << 20) | ( 0x71d << 8) | ((val >> 8) & 0xff), \
+ (pin << 20) | ( 0x71e << 8) | ((val >> 16) & 0xff), \
+ (pin << 20) | ( 0x71f << 8) | ((val >> 24) & 0xff)
+
+static const u32 mainboard_cim_verb_data[] = {
+ /* coreboot specific header */
+ 0x14f15051, // Conexant CX20561 (Hermosa)
+ 0x17aa20ff, // Subsystem ID
+ 0x00000008, // Number of entries
+
+ /* Pin Widget Verb Table */
+
+ PIN_CFG(0x16, 0x042140f0),
+ PIN_CFG(0x17, 0x61a190f0),
+ PIN_CFG(0x18, 0x04a190f0),
+ PIN_CFG(0x19, 0x612140f0),
+ PIN_CFG(0x1a, 0x901701f0),
+ PIN_CFG(0x1b, 0x40f001f0),
+ PIN_CFG(0x1c, 0x40f001f0),
+ PIN_CFG(0x1d, 0x90a601f0)
+};
+extern const u32 *cim_verb_data;
+extern u32 cim_verb_data_size;
+
+static const u32 mainboard_pc_beep_verbs[] = {
+ 0x00170500, /* power up codec */
+ 0x01470500, /* power up speakers */
+ 0x01470100, /* select lout1 (input 0x0) for speakers */
+ 0x01470740, /* enable speakers output */
+ 0x00b37517, /* unmute beep (mixer's input 0x5), set amp 0dB */
+ 0x00c37100, /* unmute mixer in lout1 (lout1 input 0x1) */
+ 0x00c3b015, /* set lout1 output volume -15dB */
+ 0x0143b000, /* unmute speakers */
+};
+extern const u32 * pc_beep_verbs;
+extern u32 pc_beep_verbs_size;