Project

General

Profile

XMMBoot » History » Version 58

Denis 'GNUtoo' Carikli, 03/25/2020 04:23 AM

1 1 Denis 'GNUtoo' Carikli
h1. XMMBoot
2
3
h2.  Introduction
4
5
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.
6
7 58 Denis 'GNUtoo' Carikli
h2. Abstraction
8
9
* hci_power -> link_power
10
11 16 Denis 'GNUtoo' Carikli
h2. GPIOs
12
13 55 Denis 'GNUtoo' Carikli
h3. Devices GPIOs assignement and drivers
14 47 Denis 'GNUtoo' Carikli
15 49 Denis 'GNUtoo' Carikli
|_. Variant |_. SOC |_. Modem  |_. GPIO usage |_. GPIO assignement |
16 48 Denis 'GNUtoo' Carikli
| GT-I9300 | Exynos 4412 | XMM6262 | "CONFIG_UMTS_MODEM_XMM6262=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n1350
17 1 Denis 'GNUtoo' Carikli
"Makefile":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/Makefile#n10
18 49 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 | "CONFIG_SEC_MODEM_M0=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n541
19
"Makefile":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/Makefile#n320
20 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 
21
"CONFIG_MACH_M0=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n455
22 1 Denis 'GNUtoo' Carikli
"gpio-midas.h":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-midas.h#n28
23
"gpio-rev00-m0.h":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h |
24 55 Denis 'GNUtoo' Carikli
25
h3. GPIOs usage
26
27
|_. gpio platform data name |_. present |_. absent |_. Implementation |_. comments |
28
| gpio_cp_on | | | | powers on the modem? in which state (PMIC?, CPU?)
29
* On GT-I9100 it's connected to the ON1 modem pin and ON2 is not connected. |
30
| gpio_cp_reset | | | | Resets the modem CPU? PMIC?:
31
* "''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
32
Can also read the modem CPU? and/or PMIC? reset state?
33
* "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 |
34
| gpio_reset_req_n | | | |
35
| gpio_pda_active | | | | Tell the modem if the SOC CPUs are sleeping/active or not?
36
* "PDA == Application processor":https://android.stackexchange.com/questions/176515/what-do-the-terms-bl-ap-cp-and-csc-mean-in-odin
37
* "''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
38
* "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
39
* "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
40
* 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 |
41
| gpio_phone_active | | | | |
42
| gpio_cp_dump_int | | | | cp: baseband processor |
43
| gpio_flm_uart_sel |\2. Only used for the Galaxy Nexus in libsamsung-ipc | | Modem download mode ? |
44
| gpio_cp_warm_reset | | | | cp: baseband processor |
45
| gpio_revers_bias_clear | | | | |
46
| gpio_revers_bias_restore | | | | |
47
| gpio_sim_detect | | | | Detect SIM card presence ? |
48 47 Denis 'GNUtoo' Carikli
49 53 Denis 'GNUtoo' Carikli
h3. Libsamsung-ipc
50 52 Denis 'GNUtoo' Carikli
51 1 Denis 'GNUtoo' Carikli
|/2. ioctl / function |\6. Devices |
52 54 Denis 'GNUtoo' Carikli
| GT-I9250 (maguro) | GT-I9100 | GT-I9300 | GT-N5100 | GT-N7100 | GT-P3100 / GT-P5100 (piranah) |
53 52 Denis 'GNUtoo' Carikli
| open, close, read, write 
54 1 Denis 'GNUtoo' Carikli
fmt/rfs
55
gprs
56 54 Denis 'GNUtoo' Carikli
power |\6. Yes |
57 52 Denis 'GNUtoo' Carikli
| boot_power
58 54 Denis 'GNUtoo' Carikli
status_online_wait | Yes |\5. No |
59 1 Denis 'GNUtoo' Carikli
| hci_power
60 52 Denis 'GNUtoo' Carikli
link_control_enable
61
link_control_active
62
link_control_wait
63 54 Denis 'GNUtoo' Carikli
link_get_hostwake_wait | No |\4. Yes | No |
64 52 Denis 'GNUtoo' Carikli
65 56 Denis 'GNUtoo' Carikli
h3. libsamsung-ipc <-> kernel functions <-> gpios
66 10 Denis 'GNUtoo' Carikli
67 56 Denis 'GNUtoo' Carikli
|_. libsamsung-ipc |_\3. Kernel |
68 57 Denis 'GNUtoo' Carikli
|_. Function using the ioctl |_. ioctl name |_. function pointer name |_. GPIO used |
69
| xmm626_kernel_smdk4412_power | IOCTL_MODEM_ON
70
IOCTL_MODEM_OFF | modem_on
71
modem_off | gpio_cp_on
72
gpio_cp_reset
73
gpio_reset_req_n
74
gpio_pda_active |
75 56 Denis 'GNUtoo' Carikli
| | | | gpio_phone_active |
76
| | | | gpio_cp_dump_int |
77 36 Denis 'GNUtoo' Carikli
| xmm626_kernel_smdk4412_boot_power | IOCTL_MODEM_BOOT_ON
78 1 Denis 'GNUtoo' Carikli
IOCTL_MODEM_BOOT_OFF | modem_boot_on
79 56 Denis 'GNUtoo' Carikli
modem_boot_off | gpio_flm_uart_sel |
80
| | | | gpio_cp_warm_reset |
81
| | | | gpio_revers_bias_clear |
82
| | | | gpio_revers_bias_restore |
83
| | | | gpio_sim_detect |
84 44 Denis 'GNUtoo' Carikli
85
h3. Glossary
86
87
* cp: baseband processor
88 1 Denis 'GNUtoo' Carikli
89 16 Denis 'GNUtoo' Carikli
h3. SIM card presence detection
90 7 Denis 'GNUtoo' Carikli
91
Do we really want to check the SIM card presence?
92
93
Would it be possible not to for privacy reasons?
94
95
Example:
96
* Boot a modem with a SIM
97
* Take away the SIM card
98 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.
99 7 Denis 'GNUtoo' Carikli
100 16 Denis 'GNUtoo' Carikli
h3. TODO
101 1 Denis 'GNUtoo' Carikli
102
* check gpio_flm_uart_sel in smdk4412 kernel too
103 16 Denis 'GNUtoo' Carikli
104
h2. Modem partitions
105
106 30 Denis 'GNUtoo' Carikli
h3. GT-I9300, GT-N7100
107 3 Denis 'GNUtoo' Carikli
108 19 Denis 'GNUtoo' Carikli
|_. Location |_. Name |_. Content |
109 25 Denis 'GNUtoo' Carikli
| [ 0x0 -> 0xfff ] | ? | Partition table? |
110 31 Denis 'GNUtoo' Carikli
| [ 0x1000 -> 0xefff ] | PSIRAM | First stage bootloader? |
111
| [ 0xF000 -> 0x27fff ] | EBL | Second stage bootloader ? |
112 29 Denis 'GNUtoo' Carikli
| [ 0x28000 -> 0x9ff7ff ] | MAIN | ? |
113 28 Denis 'GNUtoo' Carikli
| [ 0x9ff800 -> 0x9fffff ] | SECPACK | ? |
114 1 Denis 'GNUtoo' Carikli
| [ 0xa00000 -> 0xbfffff ] | NV | ? |
115
116 31 Denis 'GNUtoo' Carikli
References for the table:
117
* https://git.replicant.us/replicant/external_libsamsung-ipc/tree/samsung-ipc/devices/i9300/i9300.h?id=9ff9785a7f48e32f107ca7fb2e298b1320ad4cbc
118
* https://git.replicant.us/replicant/external_libsamsung-ipc/tree/samsung-ipc/devices/n7100/n7100.h?id=9ff9785a7f48e32f107ca7fb2e298b1320ad4cbc
119
* Verified on GT-I9300 and GT-N7100 modem partition table
120 23 Denis 'GNUtoo' Carikli
121 32 Denis 'GNUtoo' Carikli
h4. GT-I9300 and GT-N7100 modem partition table dump
122 23 Denis 'GNUtoo' Carikli
123
<pre>
124 24 Denis 'GNUtoo' Carikli
$ hexdump -C RADIO.img
125
00000000  50 53 49 52 41 4d 00 00  00 00 00 00 00 10 00 00  |PSIRAM..........|
126
00000010  00 00 00 00 00 e0 00 00  00 00 00 00 00 00 00 00  |................|
127
00000020  45 42 4c 00 00 00 00 00  00 00 00 00 00 f0 00 00  |EBL.............|
128
00000030  00 00 00 60 00 90 01 00  00 00 00 00 00 00 00 00  |...`............|
129
00000040  4d 41 49 4e 00 00 00 00  00 00 00 00 00 80 02 00  |MAIN............|
130
00000050  00 00 30 60 00 78 9d 00  00 00 00 00 00 00 00 00  |..0`.x..........|
131
00000060  53 45 43 50 41 43 4b 00  00 00 00 00 00 f8 9f 00  |SECPACK.........|
132
00000070  00 00 00 00 00 08 00 00  00 00 00 00 00 00 00 00  |................|
133
00000080  4e 56 00 00 00 00 00 00  00 00 00 00 00 00 a0 00  |NV..............|
134
00000090  00 00 e8 60 00 00 20 00  00 00 00 00 00 00 00 00  |...`.. .........|
135
000000a0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
136
*
137
[...]
138 1 Denis 'GNUtoo' Carikli
</pre>
139 32 Denis 'GNUtoo' Carikli
140
h3. Devices without a partition table or with a different one
141
142
* GT-I9250
143 17 Denis 'GNUtoo' Carikli
144 1 Denis 'GNUtoo' Carikli
h2. Links
145
146 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
147 1 Denis 'GNUtoo' Carikli
* https://forum.xda-developers.com/galaxy-s2/help/how-to-talk-to-modem-commands-t1471241/page4
148 45 Denis 'GNUtoo' Carikli
* http://www.arteris.com/blog/bid/59433/Interchip-Connectivity-HSIC-UniPro-HSI-C2C-LLI-oh-my