Project

General

Profile

XMMBoot » History » Version 213

Denis 'GNUtoo' Carikli, 02/03/2022 01:35 PM
Add info about modem retrieving the battery voltage

1 1 Denis 'GNUtoo' Carikli
h1. XMMBoot
2
3 59 Denis 'GNUtoo' Carikli
{{toc}}
4
5 1 Denis 'GNUtoo' Carikli
h2.  Introduction
6
7
For both libsamsung-ipc and the Linux driver it's interesting to understand better the boot of the modem in order to come with good names for the abstraction.
8
9 194 Denis 'GNUtoo' Carikli
h2. High level boot process 
10
11
The exact boot sequence is different on different devices:
12
* On most / all the devices we need to start by powering off the modem, and the link between the SOC and the modem. This makes sure that we can reliabily boot the modem at all times. 
13
* Then we need to configure the hardware to put the modem in loading mode and have everything ready for loading its firmware. On some device, the link needed to load the modem needs to be configured as well.
14
* Then we send the modem firmware to the modem
15
* Then on some devices we need extra step (like triggering an HSIC re-enumeration) once it's done. 
16
17 58 Denis 'GNUtoo' Carikli
h2. Abstraction
18
19
* hci_power -> link_power
20
21 63 Denis 'GNUtoo' Carikli
TODO:
22
* Find the difference between power_on and boot_power_on
23
** Look at the GPIOs and understand what they do
24
** Just read the code that use the GPIOs
25
** Diff both procedures
26 67 Denis 'GNUtoo' Carikli
* Look which device has which XMM626X
27
* Add XMM6210 devices too
28 63 Denis 'GNUtoo' Carikli
29 16 Denis 'GNUtoo' Carikli
h2. GPIOs
30
31 55 Denis 'GNUtoo' Carikli
h3. Devices GPIOs assignement and drivers
32 47 Denis 'GNUtoo' Carikli
33 79 Denis 'GNUtoo' Carikli
|_\4. Hardware |_\2. Linux |_\1. libsamsung-ipc |
34
|_. Variant |_. SOC |_. Modem  |_. Link |_. GPIO usage |_. GPIO assignement |_. device driver name |
35
| Galaxy Tab:
36 109 Denis 'GNUtoo' Carikli
  GT-P1000 | Exynos 3310 | | RAM | | | aries | 
37 77 Denis 'GNUtoo' Carikli
| Galaxy S:
38 110 Denis 'GNUtoo' Carikli
  GT-I9000 | Exynos 3110 | "XMM6160":https://www.wikidata.org/wiki/Q88838210#Q88838210$d5389045-4624-171a-18c5-ed1b15e1b3f5 | RAM | | | aries |
39 1 Denis 'GNUtoo' Carikli
| Nexus S:
40
  GT-I9020
41
  GT-I9020A
42 79 Denis 'GNUtoo' Carikli
  GT-I9023 | Exynos 3110 | | RAM | | | crespo |
43 74 Denis 'GNUtoo' Carikli
| Galaxy SII:
44 105 Denis 'GNUtoo' Carikli
  GT-I9100 | Exynos 4210 | XMM6260 | HSIC | "CONFIG_UMTS_MODEM_XMM6260=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9100_defconfig#n1321 | | galaxys2 |
45
| Galaxy Note:
46
  GT-N7000 | Exynos 4210 | XMM6260 | HSIC | "CONFIG_UMTS_MODEM_XMM6260=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_n7000_defconfig#n1330 | | galaxys2 |
47 74 Denis 'GNUtoo' Carikli
| Galaxy Nexus:
48 111 Denis 'GNUtoo' Carikli
  GT-I9250 | OMAP 4460 | XMM6260 | MIPI | "CONFIG_UMTS_MODEM_XMM6260=y":https://git.replicant.us/replicant/kernel_samsung_tuna/tree/arch/arm/configs/tuna_defconfig#n1209
49
                                          "Makefile":https://git.replicant.us/replicant/kernel_samsung_tuna/tree/drivers/misc/modem_if/Makefile#n10
50
                                          "modem_modemctl_device_xmm6260.c":https://git.replicant.us/replicant/kernel_samsung_tuna/tree/drivers/misc/modem_if/modem_modemctl_device_xmm6260.c | | maguro |
51 74 Denis 'GNUtoo' Carikli
| Galaxy SIII:
52 49 Denis 'GNUtoo' Carikli
  GT-I9300 | Exynos 4412 | XMM6262 | HSIC | "CONFIG_UMTS_MODEM_XMM6262=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n1350
53 1 Denis 'GNUtoo' Carikli
"Makefile":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/Makefile#n10
54
"modem_modemctl_device_xmm6262.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/modem_modemctl_device_xmm6262.c | "CONFIG_SEC_MODEM_M0=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n541
55
"Makefile":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/Makefile#n320
56 50 Denis 'GNUtoo' Carikli
"board-m0-modems.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c 
57 1 Denis 'GNUtoo' Carikli
"CONFIG_MACH_M0=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n455
58
"gpio-midas.h":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-midas.h#n28
59 79 Denis 'GNUtoo' Carikli
"gpio-rev00-m0.h":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h | i9300 |
60 74 Denis 'GNUtoo' Carikli
| Galaxy Note 8.0 GSM:
61 104 Denis 'GNUtoo' Carikli
  GT-N5100 | Exynos 4412 | XMM6262 | HSIC | "CONFIG_UMTS_MODEM_XMM6262=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_n5100_defconfig#n1335 | | n5100 |
62 74 Denis 'GNUtoo' Carikli
| Galaxy Note II:
63 79 Denis 'GNUtoo' Carikli
  GT-N7100 | Exynos 4412 | XMM6262 | HSIC | "CONFIG_UMTS_MODEM_XMM6262=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_n7100_defconfig#n1356 | | n7100 |
64 74 Denis 'GNUtoo' Carikli
| Galaxy Tab 2:
65
  GT-P3100 
66 103 Denis 'GNUtoo' Carikli
  GT-P5100 | OMAP 4430 | XMM6262 | MIPI | "CONFIG_UMTS_MODEM_XMM6262=y":https://git.replicant.us/replicant/kernel_samsung_espresso10/tree/arch/arm/configs/espresso_defconfig#n224 | | piranah |
67 55 Denis 'GNUtoo' Carikli
68
h3. GPIOs usage
69
70 65 Denis 'GNUtoo' Carikli
TODO: make sure to mention what applies to what device
71
* Start with I9300. Assume I9300 if device is not mentioned. Mention device when not I9300
72
* Add more devices and mention them
73
74 91 Denis 'GNUtoo' Carikli
Note that we don't limit ourselves to the drivers that are in use on the devices supported by Replicant.
75
As Samsung wrote drivers for the modem interfaces, and that the interface is similar across many different modems, other unused drivers and their comments also gives many hints about what the GPIOs are supposed to be used for.
76
77 204 Denis 'GNUtoo' Carikli
|_. gpio platform data name |_. present |_. absent |_. direction |_. comments |
78 196 Denis 'GNUtoo' Carikli
| "gpio_cp_on":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n237 | | | powers on the modem? in which state (PMIC?, CPU?)
79 89 Denis 'GNUtoo' Carikli
                     * On GT-I9100 it's connected to the ON1 modem pin and ON2 is not connected. |
80 205 Denis 'GNUtoo' Carikli
| "gpio_cp_reset":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n239| | read + write | Resets the modem CPU? PMIC?:
81 89 Denis 'GNUtoo' Carikli
                        * "''check the reset timming with C2C connection''":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/modem_modemctl_device_xmm6262.c#n106 : Here C2C probably means chip to chip
82
                        Can also read the modem CPU? and/or PMIC? reset state?
83 210 Denis 'GNUtoo' Carikli
                        * "Reads from the GPIO and ''CP not ready, Active State low'' comment":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n287
84
                        Also used in umts_link_reconnect (todo: check firmware status) |
85 208 Denis 'GNUtoo' Carikli
| "gpio_reset_req_n":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n238 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h#n261) | | | It seems to reset the modem. On some device with an MSM SOC (modem? AP?) in the smdk4412 kernel, it resets the modem PMIC. It can also be used to keep the modem (SOC? PMIC? CPU?) in reset mode while powered on.
86 206 Denis 'GNUtoo' Carikli
It could very well be the PMIC with the GT-I9300 as we have the following sequence in "xmm6262_on":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/modem_modemctl_device_xmm6262.c#n31 :
87
<pre>
88
	gpio_set_value(mc->gpio_reset_req_n, 0);
89
	gpio_set_value(mc->gpio_cp_on, 0);
90
	gpio_set_value(mc->gpio_cp_reset, 0);
91
	msleep(100);
92
	gpio_set_value(mc->gpio_cp_reset, 1);
93
	/* If XMM6262 was connected with C2C, AP wait 50ms to BB Reset*/
94
	msleep(50);
95
	gpio_set_value(mc->gpio_reset_req_n, 1);
96
97
	gpio_set_value(mc->gpio_cp_on, 1);
98
	udelay(60);
99
	gpio_set_value(mc->gpio_cp_on, 0);
100
	msleep(20);
101
</pre> 
102
SOCs probably need to have a very specific voltage ramp up sequences to boot (voltage ramps and so on are described in the SOC datasheets, TODO: check with a specific example).
103
If that's true it would mean that the CPU has to not be off at boot but still be in some reset mode to accept a firmware?
104
In that case, once everything is off, the CPU power would be turned on first, then the PMIC, then the reset line for the firmware loading (way later) |
105 196 Denis 'GNUtoo' Carikli
| "gpio_pda_active":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n240| | | Tell the modem if the SOC CPUs are sleeping/active or not?
106 89 Denis 'GNUtoo' Carikli
                          * "PDA == Application processor":https://android.stackexchange.com/questions/176515/what-do-the-terms-bl-ap-cp-and-csc-mean-in-odin
107
                          * "''PDA_ACTIVE, let cp know AP sleep'' comment in status gc1-gpio.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/gc1-gpio.c#n213
108
                          * "PDA_ACTIVE set to 0 right after cpu_pm_enter()":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/cpuidle-exynos4.c#n701
109
                          * "PDA_ACTIVE set to 1 right before cpu_pm_exit()":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/cpuidle-exynos4.c#n796
110 94 Denis 'GNUtoo' Carikli
                          * GPIO direction is output on AP side and input on BP side, which is also confirmed by the "pinout table in XDA":https://forum.xda-developers.com/galaxy-s2/help/how-to-talk-to-modem-commands-t1471241/page4
111
                          Also indicates when the CPU is ready to process modem stuff:
112
                          * "set to 1 *at the end* of xmm6262_on in modem_modemctl_device_xmm6262.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/modem_modemctl_device_xmm6262.c#n68
113 95 Denis 'GNUtoo' Carikli
                          * The CPU can't process stuff if the HSIC link is in low power mode, "as shown in set_hsic_lpa_states in board-m0-modems.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n310 so it sets gpio_pda_active to 0 in these cases. |
114 196 Denis 'GNUtoo' Carikli
| "gpio_phone_active":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n241 | | | Seem the modem counterpart of gpio_pda_active:
115 90 Denis 'GNUtoo' Carikli
                            * See "umts_link_reconnect in board-m0-modems.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n341
116 93 Denis 'GNUtoo' Carikli
                            * See also "mc_work in the unused modemctl.c driver":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/svnet/modemctl.c#n484 where that GPIO is used both to signal when the modem finished booting everything and is ready, and when the modem crashes or is reset 
117
                            * "phone_active_irq_handler in modem_modemctl_device_xmm6262.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/modem_modemctl_device_xmm6262.c#n139 seem to be doing exactly the same thing. |
118 197 Denis 'GNUtoo' Carikli
| "gpio_cp_dump_int":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n246 | | | Maybe used for crash dump. Reference: [[AcademicPapersAndPresentations#A-walk-with-Shannon-Walkthrough-of-a-pwn2own-baseband-exploit|Presentation about exploiting XMM modems]]: The nonfree s-boot 4.0 bootloader can probably get the modem crashdump. (cp is the modem) |
119 196 Denis 'GNUtoo' Carikli
| "gpio_flm_uart_sel":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | Only used for the Galaxy Nexus in libsamsung-ipc | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n242 | | Modem download mode ? 
120 112 Denis 'GNUtoo' Carikli
                                                                                                                                                                                         * FLM could be Firmware Load mode ?
121 1 Denis 'GNUtoo' Carikli
                                                                                                                                                                                         * On several devices, that GPIO seem to be used to switch between different UART, and the PMIC seem involved too in some devices. Not sure how it switches |
122 196 Denis 'GNUtoo' Carikli
| "gpio_cp_warm_reset":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n248 | | |
123 199 Denis 'GNUtoo' Carikli
| gpio_revers_bias_clear | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n268 | | | |
124
| gpio_revers_bias_restore | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n268 | | | |
125 209 Denis 'GNUtoo' Carikli
| "gpio_sim_detect":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n251 | | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n255 (GPIO_SIM_DETECT is not set)| | Detect SIM card presence ? |
126 201 Denis 'GNUtoo' Carikli
| "gpio_link_enable":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n112 | | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n221 | | "power management (modemlink_pm_data)":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n218 |
127
| "gpio_link_active":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n112 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n222 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h#n257) | | | set to 0 when the (HSIC) link is in low power and to 1 when it's back, "like in set_hsic_lpa_states in board-m0-modems.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n304 , "power management (modemlink_pm_data)":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n218 |
128 212 Denis 'GNUtoo' Carikli
| "gpio_link_hostwake":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n112 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n223 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h#n264) | | | "power management (modemlink_pm_data)":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n218
129
According to the code below in "modem_link_device_hsic.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/modem_link_device_hsic.c, it seems that the modem can tell the host to set the HSIC link to sleep when that GPIO is high, and to re-enable the link when it's low:
130
<pre>
131
static irqreturn_t link_pm_irq_handler(int irq, void *data)
132
{
133
        int value;
134
        struct link_pm_data *pm_data = data;
135
136
#if defined(CONFIG_SLP)
137
        pm_wakeup_event(pm_data->miscdev.this_device, 0);
138
#endif
139
140
        if (!pm_data->link_pm_active)
141
                return IRQ_HANDLED;
142
143
        /* host wake up HIGH */
144
        /*
145
                resume usb runtime pm start
146
        */
147
        /* host wake up LOW */
148
        /*
149
                slave usb enumeration end,
150
                host can send usb packet after
151
                runtime pm status changes to ACTIVE
152
        */
153
        [...]
154
}
155
</pre> |
156 211 Denis 'GNUtoo' Carikli
| "gpio_link_slavewake":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/include/linux/platform_data/modem.h#n112 | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n224 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h#n263)| | | "power management (modemlink_pm_data)":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n218 
157
According to the code in board-m0-modems.c, it seems to be used to wakup the modem or to make it exit low power mode by triggering a rising edge but I don't know why it checks the hostwake GPIO in the code below:
158
<pre>
159
/* HSIC specific function */
160
void set_slave_wake(void)
161
{
162
        if (gpio_get_value(modem_link_pm_data.gpio_link_hostwake)) {
163
                pr_info("[MODEM_IF]Slave Wake\n");
164
                if (gpio_get_value(modem_link_pm_data.gpio_link_slavewake)) {
165
                        pr_info("[MODEM_IF]Slave Wake set _-\n");
166
                        gpio_direction_output(
167
                        modem_link_pm_data.gpio_link_slavewake, 0);
168
                        mdelay(10);
169
                }
170
                gpio_direction_output(
171
                        modem_link_pm_data.gpio_link_slavewake, 1);
172
        }
173
}
174
[...]
175
void set_hsic_lpa_states(int states)
176
{
177
        int val = gpio_get_value(umts_modem_data.gpio_cp_reset);
178
179
        mif_trace("\n");
180
181
        if (val) {
182
                switch (states) {
183
                [...]
184
                case STATE_HSIC_LPA_PHY_INIT:
185
                        gpio_set_value(umts_modem_data.gpio_pda_active, 1);
186
                        set_slave_wake();
187
                        pr_info(LOG_TAG "set hsic lpa phy init: "
188
                                "slave wake-up (%d)\n",
189
                                gpio_get_value(
190
                                        modem_link_pm_data.gpio_link_slavewake)
191
                                );
192
                        break;
193
                }
194
        }
195
}
196
</pre> |
197 197 Denis 'GNUtoo' Carikli
| gpio_ap_dump_int | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n244 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h#n268)| | | Maybe used for crash dump. Reference: [[AcademicPapersAndPresentations#A-walk-with-Shannon-Walkthrough-of-a-pwn2own-baseband-exploit|Presentation about exploiting XMM modems]]: The nonfree s-boot 4.0 bootloader can probably get the modem crashdump. Here it would indicate that the host somehow can send crashdumps to the modem somehow? |
198 196 Denis 'GNUtoo' Carikli
| gpio_sim_io_sel | | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n250 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n539) | |/3. Seem to be used for some dual modem feature which is not present in any Replicant kernels (aries, crespo, espresso10, smdk4412, tuna) for Replicant 6 (or 4.2 for aries and crespo) |
199
| gpio_cp_ctrl1 | | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n251 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n539) | |
200
| gpio_cp_ctrl2 | | "GT-I9300":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n252 ("define":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n539) | |
201 47 Denis 'GNUtoo' Carikli
202 53 Denis 'GNUtoo' Carikli
h3. Libsamsung-ipc
203 52 Denis 'GNUtoo' Carikli
204 165 Denis 'GNUtoo' Carikli
|/2. ioctl / function |\8. Devices |
205 166 Denis 'GNUtoo' Carikli
| GT-I9250 | GT-I9100 / GT-N7000 | GT-I9300 | GT-N5100 | GT-N7100 | GT-P3100 / GT-P5100 | Galaxy S (GT-I9000) / Galaxy Tab  | Nexus S (GT-I902x) |
206
| libsamsung-ipc driver | maguro | galaxys2 | i9300 | n5100 | n7100 | piranah | aries | crespo |
207 52 Denis 'GNUtoo' Carikli
| open, close, read, write 
208 1 Denis 'GNUtoo' Carikli
fmt/rfs
209
gprs
210 54 Denis 'GNUtoo' Carikli
power |\6. Yes |
211 52 Denis 'GNUtoo' Carikli
| boot_power
212 168 Denis 'GNUtoo' Carikli
status_online_wait | Yes |\5. No |/3\2. No |
213 1 Denis 'GNUtoo' Carikli
| hci_power
214 52 Denis 'GNUtoo' Carikli
link_control_active
215 167 Denis 'GNUtoo' Carikli
link_connected_wait
216 160 Denis 'GNUtoo' Carikli
link_get_hostwake_wait |/2. No |\4. Yes |/2. No |
217 163 Denis 'GNUtoo' Carikli
| link_control_enable | Yes (ignored by Linux[4][5][6]) |\3. Yes (ignored by Linux[1][2][3]) |
218 169 Denis 'GNUtoo' Carikli
| psi_send | xmm626_mipi_psi_send |\4. xmm626_hsic_psi_send | xmm626_mipi_psi_send |\2. xmm616_psi_send | 
219 170 Denis 'GNUtoo' Carikli
| firmware_send | xmm626_mipi_firmware_send |\4. xmm626_hsic_firmware_send | xmm626_mipi_firmware_send |\2. xmm616_firmware_send | 
220
| nv_data_send | xmm626_mipi_nv_data_send |\4. xmm626_hsic_nv_data_send | xmm626_mipi_nv_data_send |\2. xmm616_nv_data_send | 
221 52 Denis 'GNUtoo' Carikli
222 161 Denis 'GNUtoo' Carikli
fn1. https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n221
223
224
fn2. https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n218
225
226 1 Denis 'GNUtoo' Carikli
fn3. https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n136
227 162 Denis 'GNUtoo' Carikli
228
fn4. https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-u1-modems.c#n153
229
230
fn5. https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-u1-modems.c#n151
231
232
fn6. https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-u1-modems.c#n139
233 66 Denis 'GNUtoo' Carikli
234 56 Denis 'GNUtoo' Carikli
h3. libsamsung-ipc <-> kernel functions <-> gpios
235 10 Denis 'GNUtoo' Carikli
236 56 Denis 'GNUtoo' Carikli
|_. libsamsung-ipc |_\3. Kernel |
237 157 Denis 'GNUtoo' Carikli
|_. Function using the ioctl |_. ioctl name |_. pointer signature |_. GPIO used | comment |
238 57 Denis 'GNUtoo' Carikli
| xmm626_kernel_smdk4412_power | IOCTL_MODEM_ON
239 156 Denis 'GNUtoo' Carikli
                                 IOCTL_MODEM_OFF | <pre>int (*modem_on)(struct modem_ctl*);</pre>
240
                                                   <pre>int (*modem_off)(struct modem_ctl*);</pre> | gpio_cp_on
241 153 Denis 'GNUtoo' Carikli
                                                                                      gpio_cp_reset
242
                                                                                      gpio_reset_req_n
243
                                                                                      gpio_pda_active |
244 56 Denis 'GNUtoo' Carikli
| | | | gpio_phone_active |
245 1 Denis 'GNUtoo' Carikli
| | | | gpio_cp_dump_int |
246 56 Denis 'GNUtoo' Carikli
| xmm626_kernel_smdk4412_boot_power | IOCTL_MODEM_BOOT_ON
247 156 Denis 'GNUtoo' Carikli
                                      IOCTL_MODEM_BOOT_OFF | <pre>int (*modem_boot_on)(struct modem_ctl*);</pre>
248
                                                             <pre>int (*modem_boot_off)(struct modem_ctl*);</pre> | gpio_flm_uart_sel |
249 56 Denis 'GNUtoo' Carikli
| | | | gpio_cp_warm_reset |
250
| | | | gpio_revers_bias_clear |
251
| | | | gpio_revers_bias_restore |
252 1 Denis 'GNUtoo' Carikli
| | | | gpio_sim_detect |
253 157 Denis 'GNUtoo' Carikli
| xmm626_kernel_smdk4412_status_online_wait | IOCTL_MODEM_STATUS | int phone_state; | gpio_cp_on
254
                                                                                      gpio_cp_reset
255
                                                                                      gpio_pda_active
256
                                                                                      gpio_reset_req_n
257 158 Denis 'GNUtoo' Carikli
                                                                                      gpio_phone_active | int phone_state get assigned the status computed from the various GPIO states
258
                                                                                                          xmm626_kernel_smdk4412_status_online_wait only waits for the online status    |
259 159 Denis 'GNUtoo' Carikli
| xmm626_kernel_smdk4412_link_control_enable | IOCTL_LINK_CONTROL_ENABLE | <pre>int (*link_ldo_enable)(bool);</pre> | gpio_link_enable | on i9300:
260
                                                                                                                                        * link_ldo_enable only returns 0 and has a comment ("Exynos HSIC V1.2 LDO was controlled by kernel")
261
                                                                                                                                        * gpio_link_enable is set to 0 (so it's ignored) |
262 44 Denis 'GNUtoo' Carikli
263
h3. Glossary
264
265 72 Denis 'GNUtoo' Carikli
Terms for the modem CPU:
266 61 Denis 'GNUtoo' Carikli
* BP: Baseband processor
267
* CP: Cellular? processor
268 60 Denis 'GNUtoo' Carikli
269 72 Denis 'GNUtoo' Carikli
Term for the CPU of the system on a chip running Replicant:
270 60 Denis 'GNUtoo' Carikli
* AP: Application processor
271 1 Denis 'GNUtoo' Carikli
272 62 Denis 'GNUtoo' Carikli
TODO: move in its own page and point to it
273
274 101 Denis 'GNUtoo' Carikli
LPA: Low power mode active (Related to ULPI specs only?)
275
276
ULPI: Probably a USB PHY spec
277
278 16 Denis 'GNUtoo' Carikli
h3. SIM card presence detection
279 7 Denis 'GNUtoo' Carikli
280
Do we really want to check the SIM card presence?
281
282
Would it be possible not to for privacy reasons?
283
284
Example:
285
* Boot a modem with a SIM
286
* Take away the SIM card
287 1 Denis 'GNUtoo' Carikli
* Go to a protest with only the SIM card and a phone with no data on it to be able to call if necessary.
288 7 Denis 'GNUtoo' Carikli
289 16 Denis 'GNUtoo' Carikli
h3. TODO
290 1 Denis 'GNUtoo' Carikli
291
* check gpio_flm_uart_sel in smdk4412 kernel too
292 16 Denis 'GNUtoo' Carikli
293 82 Denis 'GNUtoo' Carikli
h2. Potential privacy and security issues
294
295 83 Denis 'GNUtoo' Carikli
h3. gpio_pda_active
296
297
From "cpuidle-exynos4.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/cpuidle-exynos4.c#n701 we have things like that:
298
<pre>
299
	cpu_pm_enter();
300
301
#if defined(CONFIG_INTERNAL_MODEM_IF) || defined(CONFIG_SAMSUNG_PHONE_TTY)
302
	gpio_set_value(GPIO_PDA_ACTIVE, 0);
303
#endif
304
305
	if (log_en)
306
		pr_debug("+++lpa\n")
307
</pre>
308
309
and:
310
<pre>
311
	if (log_en)
312
		pr_debug("---lpa\n");
313
#if defined(CONFIG_INTERNAL_MODEM_IF) || defined(CONFIG_SAMSUNG_PHONE_TTY)
314
	gpio_set_value(GPIO_PDA_ACTIVE, 1);
315
#endif
316
317
	cpu_pm_exit();
318
</pre>
319 84 Denis 'GNUtoo' Carikli
320 83 Denis 'GNUtoo' Carikli
Does it means that we are telling the modem about each time we go in suspend to RAM?
321 84 Denis 'GNUtoo' Carikli
322 85 Denis 'GNUtoo' Carikli
Devices affected or not affected:
323
324 84 Denis 'GNUtoo' Carikli
|_. Device |_. Config |
325
| GT-I9300 | "# CONFIG_INTERNAL_MODEM_IF is not set":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n1373
326
             "# CONFIG_SAMSUNG_PHONE_TTY is not set":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n3039 |
327 83 Denis 'GNUtoo' Carikli
328 82 Denis 'GNUtoo' Carikli
h3. gpio_phone_active 
329
330
From "ehci-s5p.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/usb/host/ehci-s5p.c#n129 we have things like that:
331
<pre>
332
#if defined(CONFIG_UMTS_MODEM_XMM6262)
333
	if (pdata->get_cp_active_state && !pdata->get_cp_active_state()) {
334
		s5p_ehci_port_control(pdev, CP_PORT, 0);
335
		pr_err("mif: force port%d off by cp reset\n", CP_PORT);
336
	}
337
#endif
338
</pre>
339 86 Denis 'GNUtoo' Carikli
340 82 Denis 'GNUtoo' Carikli
Does it allows the modem to trigger a re-enumeration of the HSIC bus?
341 86 Denis 'GNUtoo' Carikli
342
Devices affected or not affected:
343
344
|_. Device |_. Config |
345 87 Denis 'GNUtoo' Carikli
| GT-I9300 | "CONFIG_UMTS_MODEM_XMM6262=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n1350
346
             ".gpio_phone_active = GPIO_PHONE_ACTIVE":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/board-m0-modems.c#n241 |
347 82 Denis 'GNUtoo' Carikli
348 213 Denis 'GNUtoo' Carikli
h3. Other connections
349
350
According to the modem logs gathered with xgoldmon, on the Galaxy SII (GT-I9100) with Replicant 6.0, the Galaxy Nexus under Replicant 6.0 and the Galaxy SIII (GT-I9300) with the stock OS, the modem has a way to get information about the battery status.
351
352
Since libsamsung-ipc doesn't send that information, the modem probably is connected to a chip or resistance that can see get that information.
353
354
The [[XMMProtocolInterfaces#GT-I9100]] article has an example of log for the Galaxy SII (GT-I9100) that has information about the battery voltage.
355
356
357
358 1 Denis 'GNUtoo' Carikli
h2. Links
359
360 45 Denis 'GNUtoo' Carikli
* "modem_modemctl_device_xmm6262.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/modem_modemctl_device_xmm6262.c
361 1 Denis 'GNUtoo' Carikli
* https://forum.xda-developers.com/galaxy-s2/help/how-to-talk-to-modem-commands-t1471241/page4
362 45 Denis 'GNUtoo' Carikli
* http://www.arteris.com/blog/bid/59433/Interchip-Connectivity-HSIC-UniPro-HSI-C2C-LLI-oh-my
363 64 Denis 'GNUtoo' Carikli
** TODO: move this link somewhere where it's more useful