Project

General

Profile

XMMBoot » History » Version 74

Denis 'GNUtoo' Carikli, 03/25/2020 05:12 PM

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 58 Denis 'GNUtoo' Carikli
h2. Abstraction
10
11
* hci_power -> link_power
12
13 63 Denis 'GNUtoo' Carikli
TODO:
14
* Find the difference between power_on and boot_power_on
15
** Look at the GPIOs and understand what they do
16
** Just read the code that use the GPIOs
17
** Diff both procedures
18 67 Denis 'GNUtoo' Carikli
* Look which device has which XMM626X
19
* Add XMM6210 devices too
20 63 Denis 'GNUtoo' Carikli
21 16 Denis 'GNUtoo' Carikli
h2. GPIOs
22
23 55 Denis 'GNUtoo' Carikli
h3. Devices GPIOs assignement and drivers
24 47 Denis 'GNUtoo' Carikli
25 73 Denis 'GNUtoo' Carikli
|_. Variant |_. SOC |_. Modem  |_. Link |_. GPIO usage |_. GPIO assignement |
26 74 Denis 'GNUtoo' Carikli
| Galaxy S:
27
  GT-I91000 | Exynos 3110 | |
28
| Nexus S:
29
  GT-I9020
30
  GT-I9020A
31
  GT-I9023 | Exynos 3110 | |
32
| Galaxy SII:
33
  GT-I9100 | Exynos 4410 | XMM6260 | | "CONFIG_UMTS_MODEM_XMM6260=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9100_defconfig#n1321 | |
34
| Galaxy Nexus:
35
  GT-I9250 | OMAP 4460 | |
36
| Galaxy SIII:
37
  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
38 1 Denis 'GNUtoo' Carikli
"Makefile":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/drivers/misc/modem_if/Makefile#n10
39 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
40
"Makefile":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/Makefile#n320
41 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 
42
"CONFIG_MACH_M0=y":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/configs/lineageos_i9300_defconfig#n455
43 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
44
"gpio-rev00-m0.h":https://git.replicant.us/replicant/kernel_samsung_smdk4412/tree/arch/arm/mach-exynos/include/mach/gpio-rev00-m0.h |
45 74 Denis 'GNUtoo' Carikli
| Galaxy Note 8.0 GSM:
46
  GT-N5100 | Exynos 4412 | |
47
| Galaxy Note II:
48
  GT-N7100 | Exynos 4412 | |
49
| Galaxy Tab 2:
50
  GT-P3100 
51
  GT-P5100 | | |
52
53
54 55 Denis 'GNUtoo' Carikli
55
h3. GPIOs usage
56
57 65 Denis 'GNUtoo' Carikli
TODO: make sure to mention what applies to what device
58
* Start with I9300. Assume I9300 if device is not mentioned. Mention device when not I9300
59
* Add more devices and mention them
60
61 55 Denis 'GNUtoo' Carikli
|_. gpio platform data name |_. present |_. absent |_. Implementation |_. comments |
62
| gpio_cp_on | | | | powers on the modem? in which state (PMIC?, CPU?)
63
* On GT-I9100 it's connected to the ON1 modem pin and ON2 is not connected. |
64
| gpio_cp_reset | | | | Resets the modem CPU? PMIC?:
65
* "''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
66
Can also read the modem CPU? and/or PMIC? reset state?
67
* "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 |
68
| gpio_reset_req_n | | | |
69
| gpio_pda_active | | | | Tell the modem if the SOC CPUs are sleeping/active or not?
70
* "PDA == Application processor":https://android.stackexchange.com/questions/176515/what-do-the-terms-bl-ap-cp-and-csc-mean-in-odin
71
* "''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
72
* "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
73
* "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
74
* 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 |
75
| gpio_phone_active | | | | |
76
| gpio_cp_dump_int | | | | cp: baseband processor |
77
| gpio_flm_uart_sel |\2. Only used for the Galaxy Nexus in libsamsung-ipc | | Modem download mode ? |
78
| gpio_cp_warm_reset | | | | cp: baseband processor |
79
| gpio_revers_bias_clear | | | | |
80
| gpio_revers_bias_restore | | | | |
81
| gpio_sim_detect | | | | Detect SIM card presence ? |
82 47 Denis 'GNUtoo' Carikli
83 53 Denis 'GNUtoo' Carikli
h3. Libsamsung-ipc
84 52 Denis 'GNUtoo' Carikli
85 1 Denis 'GNUtoo' Carikli
|/2. ioctl / function |\6. Devices |
86 54 Denis 'GNUtoo' Carikli
| GT-I9250 (maguro) | GT-I9100 | GT-I9300 | GT-N5100 | GT-N7100 | GT-P3100 / GT-P5100 (piranah) |
87 52 Denis 'GNUtoo' Carikli
| open, close, read, write 
88 1 Denis 'GNUtoo' Carikli
fmt/rfs
89
gprs
90 54 Denis 'GNUtoo' Carikli
power |\6. Yes |
91 52 Denis 'GNUtoo' Carikli
| boot_power
92 54 Denis 'GNUtoo' Carikli
status_online_wait | Yes |\5. No |
93 1 Denis 'GNUtoo' Carikli
| hci_power
94 52 Denis 'GNUtoo' Carikli
link_control_enable
95
link_control_active
96
link_control_wait
97 54 Denis 'GNUtoo' Carikli
link_get_hostwake_wait | No |\4. Yes | No |
98 52 Denis 'GNUtoo' Carikli
99 66 Denis 'GNUtoo' Carikli
TODO:
100
* Don't use abbreviated function names
101
102 56 Denis 'GNUtoo' Carikli
h3. libsamsung-ipc <-> kernel functions <-> gpios
103 10 Denis 'GNUtoo' Carikli
104 56 Denis 'GNUtoo' Carikli
|_. libsamsung-ipc |_\3. Kernel |
105 57 Denis 'GNUtoo' Carikli
|_. Function using the ioctl |_. ioctl name |_. function pointer name |_. GPIO used |
106
| xmm626_kernel_smdk4412_power | IOCTL_MODEM_ON
107
IOCTL_MODEM_OFF | modem_on
108
modem_off | gpio_cp_on
109
gpio_cp_reset
110
gpio_reset_req_n
111
gpio_pda_active |
112 56 Denis 'GNUtoo' Carikli
| | | | gpio_phone_active |
113
| | | | gpio_cp_dump_int |
114 36 Denis 'GNUtoo' Carikli
| xmm626_kernel_smdk4412_boot_power | IOCTL_MODEM_BOOT_ON
115 1 Denis 'GNUtoo' Carikli
IOCTL_MODEM_BOOT_OFF | modem_boot_on
116 56 Denis 'GNUtoo' Carikli
modem_boot_off | gpio_flm_uart_sel |
117
| | | | gpio_cp_warm_reset |
118
| | | | gpio_revers_bias_clear |
119
| | | | gpio_revers_bias_restore |
120
| | | | gpio_sim_detect |
121 44 Denis 'GNUtoo' Carikli
122
h3. Glossary
123
124 72 Denis 'GNUtoo' Carikli
Terms for the modem CPU:
125 61 Denis 'GNUtoo' Carikli
* BP: Baseband processor
126
* CP: Cellular? processor
127 60 Denis 'GNUtoo' Carikli
128 72 Denis 'GNUtoo' Carikli
Term for the CPU of the system on a chip running Replicant:
129 60 Denis 'GNUtoo' Carikli
* AP: Application processor
130 1 Denis 'GNUtoo' Carikli
131 62 Denis 'GNUtoo' Carikli
TODO: move in its own page and point to it
132
133 16 Denis 'GNUtoo' Carikli
h3. SIM card presence detection
134 7 Denis 'GNUtoo' Carikli
135
Do we really want to check the SIM card presence?
136
137
Would it be possible not to for privacy reasons?
138
139
Example:
140
* Boot a modem with a SIM
141
* Take away the SIM card
142 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.
143 7 Denis 'GNUtoo' Carikli
144 16 Denis 'GNUtoo' Carikli
h3. TODO
145 1 Denis 'GNUtoo' Carikli
146
* check gpio_flm_uart_sel in smdk4412 kernel too
147 16 Denis 'GNUtoo' Carikli
148
h2. Modem partitions
149
150 30 Denis 'GNUtoo' Carikli
h3. GT-I9300, GT-N7100
151 3 Denis 'GNUtoo' Carikli
152 19 Denis 'GNUtoo' Carikli
|_. Location |_. Name |_. Content |
153 71 Denis 'GNUtoo' Carikli
| [ 0x0 -> 0xfff ] | ? | Partition table ? |
154
| [ 0x1000 -> 0xefff ] | PSIRAM | First stage bootloader ? |
155 31 Denis 'GNUtoo' Carikli
| [ 0xF000 -> 0x27fff ] | EBL | Second stage bootloader ? |
156 29 Denis 'GNUtoo' Carikli
| [ 0x28000 -> 0x9ff7ff ] | MAIN | ? |
157 28 Denis 'GNUtoo' Carikli
| [ 0x9ff800 -> 0x9fffff ] | SECPACK | ? |
158 70 Denis 'GNUtoo' Carikli
| [ 0xa00000 -> 0xbfffff ] | NV | nvdata default values?
159
TODO: find the place in libsamsung-ipc source mentioning that |
160 1 Denis 'GNUtoo' Carikli
161 31 Denis 'GNUtoo' Carikli
References for the table:
162
* https://git.replicant.us/replicant/external_libsamsung-ipc/tree/samsung-ipc/devices/i9300/i9300.h?id=9ff9785a7f48e32f107ca7fb2e298b1320ad4cbc
163
* https://git.replicant.us/replicant/external_libsamsung-ipc/tree/samsung-ipc/devices/n7100/n7100.h?id=9ff9785a7f48e32f107ca7fb2e298b1320ad4cbc
164
* Verified on GT-I9300 and GT-N7100 modem partition table
165 23 Denis 'GNUtoo' Carikli
166 32 Denis 'GNUtoo' Carikli
h4. GT-I9300 and GT-N7100 modem partition table dump
167 23 Denis 'GNUtoo' Carikli
168 68 Denis 'GNUtoo' Carikli
TODO:
169
* Send patch for the "modem-partition-tool#n33":https://git.replicant.us/contrib/GNUtoo/hardware_replicant_libsamsung-ipc/tree/tools/modem-image-tool.c?h=patches-todo/modem-partition-tool#n33
170
* Make sure that we know the device from the command line
171
* Understand the field depths along the way when supporting more devices
172
* Document all other devices that don't have this partition table
173
* Find the name of this partition table
174
175 23 Denis 'GNUtoo' Carikli
<pre>
176 24 Denis 'GNUtoo' Carikli
$ hexdump -C RADIO.img
177
00000000  50 53 49 52 41 4d 00 00  00 00 00 00 00 10 00 00  |PSIRAM..........|
178
00000010  00 00 00 00 00 e0 00 00  00 00 00 00 00 00 00 00  |................|
179
00000020  45 42 4c 00 00 00 00 00  00 00 00 00 00 f0 00 00  |EBL.............|
180
00000030  00 00 00 60 00 90 01 00  00 00 00 00 00 00 00 00  |...`............|
181
00000040  4d 41 49 4e 00 00 00 00  00 00 00 00 00 80 02 00  |MAIN............|
182
00000050  00 00 30 60 00 78 9d 00  00 00 00 00 00 00 00 00  |..0`.x..........|
183
00000060  53 45 43 50 41 43 4b 00  00 00 00 00 00 f8 9f 00  |SECPACK.........|
184
00000070  00 00 00 00 00 08 00 00  00 00 00 00 00 00 00 00  |................|
185
00000080  4e 56 00 00 00 00 00 00  00 00 00 00 00 00 a0 00  |NV..............|
186
00000090  00 00 e8 60 00 00 20 00  00 00 00 00 00 00 00 00  |...`.. .........|
187
000000a0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
188
*
189
[...]
190 1 Denis 'GNUtoo' Carikli
</pre>
191 32 Denis 'GNUtoo' Carikli
192
h3. Devices without a partition table or with a different one
193
194 69 Denis 'GNUtoo' Carikli
* GT-I9100, GT-I9250, GT-N7000, GT-P3100
195
* Probably GT-P5100 as well, as it's similar to GT-P3100 
196
* All the devices with Qualcomm modems (GT-I9305, GT-N7105)
197
198
Unknown:
199
* Galaxy Note 8.0
200 17 Denis 'GNUtoo' Carikli
201 1 Denis 'GNUtoo' Carikli
h2. Links
202
203 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
204 1 Denis 'GNUtoo' Carikli
* https://forum.xda-developers.com/galaxy-s2/help/how-to-talk-to-modem-commands-t1471241/page4
205 45 Denis 'GNUtoo' Carikli
* http://www.arteris.com/blog/bid/59433/Interchip-Connectivity-HSIC-UniPro-HSI-C2C-LLI-oh-my
206 64 Denis 'GNUtoo' Carikli
** TODO: move this link somewhere where it's more useful