Project

General

Profile

ModemIsolationResearch » History » Version 52

Denis 'GNUtoo' Carikli, 01/05/2020 11:13 AM

1 46 Denis 'GNUtoo' Carikli
h1. History
2
3
When Replicant was started, the HTC Dream was the only available Android phone, and it had a Qualcomm System On a Chip (SOC) with an integrated modem. We then also added support for other very similar devices.
4
5
The System On a Chip family used by these devices was the MSM7K. While working on Replicant, very serious flaws were discovered with that System On a Chip family:
6
* The modem (which runs only non-free software) handled things that were too privacy sensitive, such as the audio CODEC, which, as I understand, makes it possible, hardware wise, for the modem to enable the microphone without the Application Processor (which ran Replicant) being involved.
7
* The RAM chips were shared between the CPU of the GSM modem and the SOC CPU. This was also the case for some of the supported devices that had a Samsung Exynos SOC like the Nexus S. This could enable the modem to take control of the processor running Replicant.
8
* The modem processor was in charge of booting the device. To do that it had to:
9
** Intialize all the system RAM
10
** Load the bootloader of the Application Processor in RAM and instruct that processor to run that code.
11
* The modem also handled the GPS. This is also a concern for other devices with different System On a Chip like the Nokia N900.
12
13
Despite the huge amount of work required, when alternatives became available, we switched away from devices with this System On a Chip family because the gravity of the issues was a nightmare.
14
15
While some of the above issues have been fixed in more recent Qualcomm System On a Chip families, the increasing amount of proprietary libraries for theses new families, and the lack of strong guarantees that would prevent the modem from being able to take control of the processor running Replicant made the project ignore and discourage the use of the newer Qualcomm System On a Chip families.
16
17
Despite that, it may be possible to make sure that the modem cannot physically access and modify the Application Processor's RAM content, for instance by using the SOC IOMMU, if there is one, but that would require significant work. It would at least require:
18
* to be able to use a mainline kernel (to be able to have some trust in the code)
19
* to have public documentation on the System On a Chip IOMMU.
20
* to have people analyze the security of the IOMMU.
21
* to make sure that the IOMMU setup even before the RAM is even initialized. Nonfree bootloader most probably prevent that.
22
23
Despite that we may still accept contributions for devices with such System On a Chip, but it's best to contact the Replicant project (for instance on the mailing list or on IRC) before starting to work on that, to collectively decide how to handle that.
24
25
For instance some tablets use Qualcomm SOCs have no modems. So if the most important privacy sensitive hardware is under the control of the Application Processor, it might be possible to add support for such tablets if work is done to make sure that they can be useful without any proprietary libraries.
26
27 18 Denis 'GNUtoo' Carikli
h1. Modem shared memory
28 1 Denis 'GNUtoo' Carikli
29 17 Denis 'GNUtoo' Carikli
This section documents in more details the architecture of system on a chip and devices that have shared memory between the modem and the processor running Android. Since the modem runs (only) proprietary software, devices that doesn't have any mechanism that prevent the modem from taking control of the processor running Android are a grave concern for users freedom ans security.
30 4 Denis 'GNUtoo' Carikli
31 47 Denis 'GNUtoo' Carikli
This section focuses on that issue.
32 4 Denis 'GNUtoo' Carikli
33 5 Denis 'GNUtoo' Carikli
Documenting the issue more in depth might allow us to understand if some devices with shared memory between the modem and the processor running Android might be able to be used safely.
34
35 15 Denis 'GNUtoo' Carikli
h2. Requirements
36
37 16 Denis 'GNUtoo' Carikli
Having the modem and the processor running Android in separate chip, connected through a bus (like USB) that doesn't allow the modem to access the Android processor's memory offers pretty good guarantee that the modem cannot take the control of the processor running Android at a hardware level. 
38
When the modem and the Android processor are in the same chip or when they use shared memory to communicate, and that memory is also used by the processor operating system, such guarantees are gone.
39 15 Denis 'GNUtoo' Carikli
40 16 Denis 'GNUtoo' Carikli
Several hardware mechanism that can bring them back exist:
41 15 Denis 'GNUtoo' Carikli
* Some smartphones manufacturer could connect the modem to the processor running Android with separate dedicated memory that is not used for things other than enabling them to communicate.
42
* IOMMUs are hardware dedicated to prevent peripherals (like a modem) from taking control of the processor (that is here running Android). To have enough guarantee, such hardware should have good technical documentation and the code using it should have good peer review (It should be good enough if it is in upstream Linux).
43
44 6 Denis 'GNUtoo' Carikli
h2. System on a chip
45
46 13 Denis 'GNUtoo' Carikli
|_. Vendor |_. System on a chip |_. Isolation |_. Market share |_. References |
47 2 Denis 'GNUtoo' Carikli
| Qualcomm | Mobile Station Modem (MSM) Snapdragon 7x30 | Bad:
48 3 Denis 'GNUtoo' Carikli
* The modem is in charge of loading the bootloader of the processor running Android. Because of that it can temper with that bootloader and take control of the processor running Android.
49
* The modem can access the memory of the processor running Android, and can take control of it through that way.
50
* The modem has access to the storage of the processor running Android, so it can take control of it through that.
51 52 Denis 'GNUtoo' Carikli
| | "boot process":http://tjworld.net/wiki/Android/HTC/Vision/BootProcess |
52 14 Denis 'GNUtoo' Carikli
| Qualcomm | Snapdragon S4 | Unknown:
53
* The modem is booted by the processor running Android (which in turn is booted by a separate boot processor called RPM)
54
* There is not enough public documentation to understand if there is enough isolation between the modem and the processor running android.
55 52 Denis 'GNUtoo' Carikli
 | |
56 10 Denis 'GNUtoo' Carikli
*"Boot process":https://forum.xda-developers.com/showthread.php?t=1769411&page=25
57 13 Denis 'GNUtoo' Carikli
*"The Security of chip fabric page of rpw-pacsec2013-hexagon.pdf":https://web.archive.org/web/20131224103934if_/https://rpw.io/slides/rpw-pacsec2013-hexagon.pdf |
58 48 Denis 'GNUtoo' Carikli
| Qualcomm | APQ* | No modem | | |
59 49 Denis 'GNUtoo' Carikli
| Samsung | Exynos 4210 | No modem | | |
60 48 Denis 'GNUtoo' Carikli
| Samsung | Exynos 4412 | No modem | | |
61 50 Denis 'GNUtoo' Carikli
| Texas Instruments (TI) | OMAP 4460 | * No modem
62
* Has some DSP cores (no known use as modem, typically used for audio and video decoding offload) | | |
63 7 Denis 'GNUtoo' Carikli
64
h2. Devices
65
66
This lists devices that have the modem and the processor running Android in separate chips and use shared memory between them, along with the way the processor running Android is isolated from the modem, or not.
67
68 9 Denis 'GNUtoo' Carikli
|_. Vendor |_. Device |_. Isolation |_. References |
69 7 Denis 'GNUtoo' Carikli
| Samsung | Nexus S | ? | ? |
70
| Samsung | Galaxy S | ? | ? |
71 19 Denis 'GNUtoo' Carikli
72
h1. Isolated modems
73
74
h2. Supported devices
75
76 23 Denis 'GNUtoo' Carikli
|_. Vendor |_. Device |_. Link |_. Isolation |_. References |
77 39 Denis 'GNUtoo' Carikli
|/8. Samsung | Galaxy Nexus (I9250) |/3. MIPI |/3. * With MIPI it's most probably not possible for the peripheral to access the host RAM | * "board-tuna.c:":https://git.replicant.us/replicant/kernel_samsung_tuna/plain/arch/arm/mach-omap2/board-tuna.c
78 22 Denis 'GNUtoo' Carikli
<pre>
79
#ifdef CONFIG_OMAP_HSI_DEVICE
80
        if (TUNA_TYPE_MAGURO == omap4_tuna_get_type())
81 1 Denis 'GNUtoo' Carikli
                omap_hsi_init();
82 22 Denis 'GNUtoo' Carikli
#endif
83 23 Denis 'GNUtoo' Carikli
</pre>
84 1 Denis 'GNUtoo' Carikli
* "modem_link_device_mipi.c":https://git.replicant.us/replicant/kernel_samsung_tuna/plain/drivers/misc/modem_if/modem_link_device_mipi.c |
85 39 Denis 'GNUtoo' Carikli
| Galaxy Tab 2 7.0 (P31xx) |/2. * "espresso_defconfig:":https://git.replicant.us/replicant/kernel_samsung_espresso10/plain/arch/arm/configs/espresso_defconfig?h=replicant-6.0 CONFIG_LINK_DEVICE_MIPI=y |
86
| Galaxy Tab 2 10.1 (P51xx) |
87 37 Denis 'GNUtoo' Carikli
| Galaxy S 3 (I9300) |/5. HSIC |/5. * HSIC is a subset of the USB protocol  => the peripheral has no access to the host RAM
88 44 Denis 'GNUtoo' Carikli
* The device cannot change USB IDs "without the host powering up and down the bus":https://github.com/fourkbomb/linux/commit/5c71c549206351c16412d23c38e3d8d62763f454 |/5. * "lineageos_i9300_defconfig:":https://git.replicant.us/replicant/kernel_samsung_smdk4412/plain/arch/arm/configs/lineageos_i9300_defconfig CONFIG_MODEM_M0
89 37 Denis 'GNUtoo' Carikli
* "lineageos_i7000_defconfig:":https://git.replicant.us/replicant/kernel_samsung_smdk4412/plain/arch/arm/configs/lineageos_i7000_defconfig CONFIG_LINK_DEVICE_HSIC=y
90 35 Denis 'GNUtoo' Carikli
* "lineageos_i7100_defconfig:":https://git.replicant.us/replicant/kernel_samsung_smdk4412/plain/arch/arm/configs/lineageos_i7100_defconfig CONFIG_MODEM_M0
91 1 Denis 'GNUtoo' Carikli
* "lineageos_i5100_defconfig:":https://git.replicant.us/replicant/kernel_samsung_smdk4412/plain/arch/arm/configs/lineageos_i5100_defconfig CONFIG_MODEM_M0
92 33 Denis 'GNUtoo' Carikli
* "lineageos_i9100_defconfig:":https://git.replicant.us/replicant/kernel_samsung_smdk4412/plain/arch/arm/configs/lineageos_i9100_defconfig CONFIG_LINK_DEVICE_HSIC=y
93 36 Denis 'GNUtoo' Carikli
* "board-m0-modems.c":https://git.replicant.us/replicant/kernel_samsung_smdk4412/plain/arch/arm/mach-exynos/board-m0-modems.c |
94 37 Denis 'GNUtoo' Carikli
| Galaxy Note (N7000) |
95
| Galaxy Note 2 (N7100) |
96 34 Denis 'GNUtoo' Carikli
| Galaxy Note 8.0 (N51xx) |
97
| Galaxy S 2 (I9100) |
98 40 Denis 'GNUtoo' Carikli
99
h2. Powering off the modem
100
101 42 Denis 'GNUtoo' Carikli
h3. Android airplane mode interface
102 40 Denis 'GNUtoo' Carikli
103
The "RIL_REQUEST_RADIO_POWER command":https://git.replicant.us/LineageOS-mirror/android_hardware_ril/tree/include/telephony/ril.h#n2112 is used by the airplane mode.
104
105 42 Denis 'GNUtoo' Carikli
h3. current libsamsung-ril and libsamsung-ipc implementation
106 1 Denis 'GNUtoo' Carikli
107
"In libsamsung-ril, RIL_REQUEST_RADIO_POWER":https://git.replicant.us/replicant/hardware_ril_samsung-ril/tree/samsung-ril.c#n262 is implemneted in the "ril_request_radio_power":https://git.replicant.us/replicant/hardware_ril_samsung-ril/tree/power.c#n72 function which doesn't turn off the modem but asks it not to transmit by asking it to go in low power mode. This looks very similar to the AT command AT+CFUN.
108 42 Denis 'GNUtoo' Carikli
109
h3. Better implementation
110
111
The airplane mode could be implemented in another way where the modem is powered off. The advantage of using the airplane mode for that is that it's already implemented in the Android GUI.
112
113
We would also need to explain users that we implemented it this way, but that other Android distributions might have different implementations as their goal might differ. Doing again a full modem bootstrap will take longer than just asking the modem to go out of low power mode.
114 43 Denis 'GNUtoo' Carikli
115
To do that we would need to understand what exactly the kernel modem power off interface do in hardware, and look at the kernel APIs that could be used to do that.
116
117
On Replicant 9, at the time of writing a GPIO interface (/sys/devices/platform/xmm6262/modem_power) is available for that, but we would need to look deeper into it to understand what it does exactly at the hardware level. That interface may change when the modem drivers are modified, for instance during the work to mainline them.
118
119
On Samsung kernel, the interface is different but probably expose the same hardware controls but in a different way.
120
121
At this point, libsamsung-ipc will need to be modified to use such interfaces instead.
122
Libsamsung-ipc and libsamsung-ril might also need to be modified to take into account the fact that the modem needs to be re-bootstraped again.