]> git.zerfleddert.de Git - ms2-kexec/blame - hs_cons.c
serial seems to work, but produces no output on headphone jack
[ms2-kexec] / hs_cons.c
CommitLineData
c4dc8ddb
MG
1/*
2 * Provide kernel console on headphone jack
8eb83dc7
MG
3 *
4 * Copyright (C) 2011 Michael Gernoth <michael@gernoth.net>
5 *
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file "COPYING" in the main directory of this archive
8 * for more details.
c4dc8ddb
MG
9 */
10
11#include <linux/module.h>
12#include <linux/gpio_mapping.h>
13#include <linux/gpio.h>
8eb83dc7
MG
14#include <linux/platform_device.h>
15#include <linux/serial_reg.h>
16#include <linux/clk.h>
17
18#include <plat/board.h>
19#include <plat/control.h>
20#include <asm/mach/serial_omap.h>
21
22#include "prm.h"
23#include "prm-regbits-34xx.h"
c4dc8ddb 24
81799b4e
MG
25static int hs_switch = -1;
26
c4dc8ddb
MG
27/*
28 * int add_preferred_console(char *name, int idx, char *options)
29 * c0069208 T add_preferred_console
30 */
31
32static int (*add_preferred_console)(char *, int, char*) = (int (*)(char*, int, char*))0xc0069208;
33
8eb83dc7
MG
34void my_omap_serial_init(int wake_gpio_strobe, unsigned int wake_strobe_enable_mask);
35int my_omap_hs_init(void);
e14c6eae 36int my_serial_omap_init(void);
8eb83dc7
MG
37
38#define MAPPHONE_BPWAKE_STROBE_GPIO 157
39
c4dc8ddb
MG
40static int __init headphone_cons_init(void)
41{
c4dc8ddb
MG
42 /* Get the headset switch gpio number from devtree */
43 hs_switch = get_gpio_by_name("headset_uart_switch");
44 if (hs_switch < 0)
45 return -EINVAL;
46
66526df8 47 printk(KERN_INFO "headset_uart_switch: %d, value: %d\n", hs_switch, gpio_get_value(hs_switch));
81799b4e 48
8eb83dc7 49 if (!gpio_get_value(hs_switch))
81799b4e 50 return -ENODEV;
8eb83dc7 51
e14c6eae
MG
52 printk(KERN_INFO "Loading slightly modified omap serial driver...\n");
53 my_serial_omap_init();
54
8eb83dc7
MG
55 printk(KERN_INFO "Enabling UART3...\n");
56 my_omap_serial_init(MAPPHONE_BPWAKE_STROBE_GPIO, 0x01);
57 my_omap_hs_init();
c4dc8ddb
MG
58
59 /* route kernel uart out headset jack */
60 gpio_direction_output(hs_switch, 0);
66526df8 61 printk(KERN_INFO "headset_uart_switch: %d, value: %d\n", hs_switch, gpio_get_value(hs_switch));
c4dc8ddb 62
8eb83dc7 63 //add_preferred_console("ttyS", 2, "115200");
c4dc8ddb
MG
64 return 0;
65}
66
8eb83dc7 67#if 0
81799b4e
MG
68static void __exit headphone_cons_exit(void)
69{
70 if (hs_switch < 0)
71 return;
72
73 printk(KERN_INFO "value: %d\n", gpio_get_value(hs_switch));
74 gpio_direction_output(hs_switch, 1);
75 printk(KERN_INFO "value: %d\n", gpio_get_value(hs_switch));
76}
8eb83dc7 77#endif
81799b4e
MG
78
79
c4dc8ddb 80module_init(headphone_cons_init);
8eb83dc7 81#if 0
81799b4e 82module_exit(headphone_cons_exit);
8eb83dc7 83#endif
c4dc8ddb
MG
84
85MODULE_LICENSE("GPL");
86MODULE_AUTHOR("Michael Gernoth <michael@gernoth.net>");
Impressum, Datenschutz