summaryrefslogtreecommitdiff
path: root/zttranscode.c
diff options
context:
space:
mode:
authorkpfleming <kpfleming@5390a7c7-147a-4af0-8ec9-7488f05a26cb>2006-07-12 12:57:19 +0000
committerkpfleming <kpfleming@5390a7c7-147a-4af0-8ec9-7488f05a26cb>2006-07-12 12:57:19 +0000
commit5c22c7d7c47b830c1fc1102ef7447261c6a7be39 (patch)
tree64b6cc69ad67ec306fc64aa4e65ce0b86c9dbf38 /zttranscode.c
parent6b8045bf01673d2ffffcad80c0975ead4b8a2fc7 (diff)
use mmap API that is present in kernels < 2.6.10 when needed
fix address assignment for mmap in more recent kernels git-svn-id: http://svn.digium.com/svn/zaptel/trunk@1219 5390a7c7-147a-4af0-8ec9-7488f05a26cb
Diffstat (limited to 'zttranscode.c')
-rw-r--r--zttranscode.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/zttranscode.c b/zttranscode.c
index 08fac66..207b561 100644
--- a/zttranscode.c
+++ b/zttranscode.c
@@ -351,6 +351,7 @@ static int zt_tc_mmap(struct file *file, struct vm_area_struct *vma)
{
struct zt_transcoder_channel *ztc = file->private_data;
unsigned long physical;
+ int res;
if (!ztc)
return -EINVAL;
@@ -369,7 +370,12 @@ static int zt_tc_mmap(struct file *file, struct vm_area_struct *vma)
}
physical = (unsigned long) virt_to_phys(ztc->tch);
- if (remap_pfn_range(vma, vma->vm_start, physical >> PAGE_SHIFT, sizeof(struct zt_transcode_header), PAGE_SHARED)) {
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,10)
+ res = remap_pfn_range(vma, vma->vm_start, physical, sizeof(struct zt_transcode_header), PAGE_SHARED);
+#else
+ res = remap_page_range(vma, vma->vm_start, physical >> PAGE_SHIFT, sizeof(struct zt_transcode_header), PAGE_SHARED);
+#endif
+ if (res) {
if (debug)
printk("zttranscode: remap failed!\n");
return -EAGAIN;