summaryrefslogtreecommitdiff
path: root/target/linux/s3c24xx/patches-2.6.24/1178-debug-codec-register-setting-sysfs.patch.patch
blob: 0fd000819369c1d25c655c665d5b871c23570d6c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
From 79b99f7d65cce0730998a84d2fb615ae5ad0cff5 Mon Sep 17 00:00:00 2001
From: Andy Green <andy@openmoko.com>
Date: Wed, 2 Jul 2008 22:39:01 +0100
Subject: [PATCH] debug-codec-register-setting-sysfs.patch
 Allow direct setting of codec registers for super mega meddling power
 Signed-off-by: Andy Green <andy@openmoko.com>

---
 sound/soc/soc-core.c |   35 +++++++++++++++++++++++++++++++++++
 1 files changed, 35 insertions(+), 0 deletions(-)

diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c
index 25f7818..9e20333 100644
--- a/sound/soc/soc-core.c
+++ b/sound/soc/soc-core.c
@@ -928,6 +928,38 @@ static ssize_t codec_reg_show(struct device *dev,
 }
 static DEVICE_ATTR(codec_reg, 0444, codec_reg_show, NULL);
 
+
+static ssize_t codec_reg_write(struct device *dev,
+			       struct device_attribute *attr,
+			       const char *buf, size_t count)
+{
+	u32 address;
+	u32 data;
+	char * end;
+	size_t left = count;
+	struct snd_soc_device *devdata = dev_get_drvdata(dev);
+	struct snd_soc_codec *codec = devdata->codec;
+
+	address = simple_strtoul(buf, &end, 16);
+	left -= (int)(end - buf);
+	while ((*end == ' ') && (left)) {
+		end++;
+		left--;
+	}
+	if (!left)
+		return count;
+	data = simple_strtoul(end, &end, 16);
+
+	printk(KERN_INFO"user writes Codec reg 0x%02X with Data 0x%04X\n",
+								address, data);
+
+	codec->write(codec, address, data);
+
+	return count;
+}
+
+static DEVICE_ATTR(codec_reg_write, 0644, NULL, codec_reg_write);
+
 /**
  * snd_soc_new_ac97_codec - initailise AC97 device
  * @codec: audio codec
@@ -1139,6 +1171,9 @@ int snd_soc_register_card(struct snd_soc_device *socdev)
 	err = device_create_file(socdev->dev, &dev_attr_codec_reg);
 	if (err < 0)
 		printk(KERN_WARNING "asoc: failed to add codec sysfs entries\n");
+	err = device_create_file(socdev->dev, &dev_attr_codec_reg_write);
+	if (err < 0)
+		printk(KERN_WARNING "asoc: failed to add codec sysfs entries\n");
 out:
 	mutex_unlock(&codec->mutex);
 	return ret;
-- 
1.5.6.5