Project

General

Profile

DataPartition » History » Version 12

Denis 'GNUtoo' Carikli, 10/28/2020 05:12 PM

1 1 Denis 'GNUtoo' Carikli
h1. DataPartition
2
3 2 Denis 'GNUtoo' Carikli
{{toc}}
4
5
h2. /!\ Warning: Draft
6
7
This article is in draft form and is being written:
8
* Everybody is welcome to contribute
9
* Some things might not be accurate yet, so beware before using the information contained in it.
10 1 Denis 'GNUtoo' Carikli
11 3 Denis 'GNUtoo' Carikli
h2. What does the data partition contains?
12
13 1 Denis 'GNUtoo' Carikli
It probably depends on the devices and the Android versions.
14
15 6 Denis 'GNUtoo' Carikli
On Replicant 6.0, it contains at least the application internal data: When various applications are installed, they have access to some storage where they can read and write data that is only visible to them and not to other applications. This is part of the [[ApplicationsSecurityModel|Android security model]] that doesn't trust applications even if they are fully free software. This has serious usability consequences for users as it makes backuping and restoring the application data way more complicated than it should be: this data is tied to the application signatures, so because of that it's not easily portable across different Replicant versions. When application signatures changes (like between Replicant 6.0 0003 and 6.0 0004), the data needs to be migrated from the old signatures to the new ones.
16 1 Denis 'GNUtoo' Carikli
17 5 Denis 'GNUtoo' Carikli
In addition, on some devices it also contains the users data. This location and external microSD cards is where users typically their files like Music, photos, etc. This data is made accessible to the users in various location through a mechanism called fuse. In Replicant 6, this data is stored in the media directory in the data partition. Unlike application data, this data is not tied to any Android version or application signatures, so it can be moved, backuped, restored relatively easily across different devices and operating systems. It uses a similar file permission system than with GNU/Linux (unix DAC + Selinux).
18 1 Denis 'GNUtoo' Carikli
19
Summarry:
20 11 Denis 'GNUtoo' Carikli
| Location                  | Content |
21 12 Denis 'GNUtoo' Carikli
| /data/system/packages.xml | Application and signing key, uid, etc mapping |
22
| /data/system/appops.xml   | Application permissions |
23 11 Denis 'GNUtoo' Carikli
| /data/?                   | Applications (internal) data |
24 7 Denis 'GNUtoo' Carikli
| Many:
25
* /data/media
26 11 Denis 'GNUtoo' Carikli
* /storage/emulated (fuse)  | User accessible storage to store music, photos, etc |
27 10 Denis 'GNUtoo' Carikli
28
h2. TODO
29
30 1 Denis 'GNUtoo' Carikli
Here's where the sdcard user accessible storage comes from:
31
32
/sdcard -> /storage/self/primary [1]
33
/storage/self/primary -> /mnt/user/0/primary [2]
34
/mnt/user/0/primary -> /storage/emulated/0 [3]
35
36 9 Denis 'GNUtoo' Carikli
<pre>
37
root@i9300:/ # readlink /sdcard                                                                                                                            
38
/mnt/user/0/primary
39
root@i9300:/ # readlink /storage/self/primary                                                                                                              
40
/mnt/user/0/primary
41
root@i9300:/ # readlink /mnt/user/0/primary                                                                                                                  
42
/storage/emulated/0
43
root@i9300:/ # mount | grep "/storage/emulated"                                                                                                              
44 1 Denis 'GNUtoo' Carikli
/dev/fuse on /storage/emulated type fuse (rw,nosuid,nodev,noexec,noatime,user_id=1023,group_id=1023,default_permissions,allow_other)</pre>
45
46
47
TODO:
48
* Explain that the user accessible storage is not always present
49
* Explain that it depends on the devices (GTA04)
50
51
h2. Concerns about the application internal data
52
53
TODO:
54
* Explain the issue about the Replicant version <-> application data