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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
/*
* (C) Copyright 2010
* MediaTek <www.MediaTek.com>
*
* MTK GPU Extension Device
*
*/
#include "ged_base.h"
#include <asm/page.h>
#include <linux/version.h>
#include <linux/vmalloc.h>
#include <linux/slab.h>
#include <linux/sched.h>
#include <linux/interrupt.h>
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,38))
#ifndef AUTOCONF_INCLUDED
#include <linux/config.h>
#endif
#endif
#include <linux/uaccess.h>
unsigned long ged_copy_to_user(void __user *pvTo, const void *pvFrom, unsigned long ulBytes)
{
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,33))
if (access_ok(VERIFY_WRITE, pvTo, ulBytes))
{
return __copy_to_user(pvTo, pvFrom, ulBytes);
}
return ulBytes;
#else
return copy_to_user(pvTo, pvFrom, ulBytes);
#endif
}
unsigned long ged_copy_from_user(void *pvTo, const void __user *pvFrom, unsigned long ulBytes)
{
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,33))
if (access_ok(VERIFY_READ, pvFrom, ulBytes))
{
return __copy_from_user(pvTo, pvFrom, ulBytes);
}
return ulBytes;
#else
return copy_from_user(pvTo, pvFrom, ulBytes);
#endif
}
void* ged_alloc(int i32Size)
{
void *pvBuf;
if (i32Size <= PAGE_SIZE)
{
pvBuf = kmalloc(i32Size, GFP_KERNEL);
}
else
{
pvBuf = vmalloc(i32Size);
}
return pvBuf;
}
void ged_free(void* pvBuf, int i32Size)
{
if (pvBuf)
{
if (i32Size <= PAGE_SIZE)
{
kfree(pvBuf);
}
else
{
vfree(pvBuf);
}
}
}
long ged_get_pid(void)
{
if (in_interrupt())
{
return 0xffffffffL;
}
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,0))
return (long)current->pgrp;
#else
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,24))
return (long)task_tgid_nr(current);
#else
return (long)current->tgid;
#endif
#endif
}
|