h1. Disabling the Modem h2. Samsung-RIL devices On devices that use Samsung-RIL, Replicant's Airplane Mode trusts the modem to actually turn off its transmitters. This is undesirable, since the modem is running non-free firmware that is not trustworthy. However, since the modem's firmware is loaded by the CPU on boot, the modem will be nonfunctional if the CPU chooses not to load the modem firmware. This can be used to achieve a more trustworthy Airplane-Mode-like state. It should be noted that while this does reduce attack surface, there may still be ways for the modem to be activated (e.g. if the non-free bootloader running on the CPU sends a firmware to the modem). To disable the modem on Samsung-RIL devices, follow these steps: h3. Installation From your PC, clone the user-scripts repository:
git clone https://git.replicant.us/replicant/user-scripts.git -b replicant-6.0For the next steps, [[ADB]] needs to be set up and [[ADB#Accessing-root-shell|running as root]]. Connect the device to your PC. The scripts are in the @networking/modem@ folder. Run the setup script the folder to push the scripts to the device:
./setup.shThen disconnect the device. Make sure [[UsageNotes#Enabling-root-access|root access for apps]] is enabled. h3. Usage Open a [[UsageNotes#Terminal-emulator|terminal emulator]]. If the terminal is not running as root, you can gain root by running:
suNavigate to the @data/misc/modem@ directory and run one of the scripts:
bash disable_modem.shor
bash enable_modem.shDisabling the modem will reboot your device (the modem will be disabled when reboot completes). Enabling the modem does not require a reboot (it takes effect after a few seconds). h2. Other devices We don't yet have a way to disable the modem on other devices.