]> git.zerfleddert.de Git - ms2-kexec/blame - hs_cons.c
add more serial stuff, still not working...
[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
81799b4e
MG
47 printk(KERN_INFO "headset_uart_switch: %d\n", hs_switch);
48
49 printk(KERN_INFO "value: %d\n", gpio_get_value(hs_switch));
8eb83dc7 50 if (!gpio_get_value(hs_switch))
81799b4e 51 return -ENODEV;
8eb83dc7 52
e14c6eae
MG
53 printk(KERN_INFO "Loading slightly modified omap serial driver...\n");
54 my_serial_omap_init();
55
8eb83dc7
MG
56 printk(KERN_INFO "Enabling UART3...\n");
57 my_omap_serial_init(MAPPHONE_BPWAKE_STROBE_GPIO, 0x01);
58 my_omap_hs_init();
c4dc8ddb
MG
59
60 /* route kernel uart out headset jack */
61 gpio_direction_output(hs_switch, 0);
81799b4e 62 printk(KERN_INFO "value: %d\n", gpio_get_value(hs_switch));
c4dc8ddb 63
8eb83dc7 64 //add_preferred_console("ttyS", 2, "115200");
c4dc8ddb
MG
65 return 0;
66}
67
8eb83dc7 68#if 0
81799b4e
MG
69static void __exit headphone_cons_exit(void)
70{
71 if (hs_switch < 0)
72 return;
73
74 printk(KERN_INFO "value: %d\n", gpio_get_value(hs_switch));
75 gpio_direction_output(hs_switch, 1);
76 printk(KERN_INFO "value: %d\n", gpio_get_value(hs_switch));
77}
8eb83dc7 78#endif
81799b4e
MG
79
80
c4dc8ddb 81module_init(headphone_cons_init);
8eb83dc7 82#if 0
81799b4e 83module_exit(headphone_cons_exit);
8eb83dc7 84#endif
c4dc8ddb
MG
85
86MODULE_LICENSE("GPL");
87MODULE_AUTHOR("Michael Gernoth <michael@gernoth.net>");
Impressum, Datenschutz