~ubuntu-branches/ubuntu/vivid/mozjs24/vivid

« back to all changes in this revision

Viewing changes to js/src/assembler/jit/ExecutableAllocatorPosix.cpp

  • Committer: Package Import Robot
  • Author(s): Tim Lunn
  • Date: 2014-02-11 21:55:34 UTC
  • Revision ID: package-import@ubuntu.com-20140211215534-m1zyq5aj59md3y07
Tags: upstream-24.2.0
ImportĀ upstreamĀ versionĀ 24.2.0

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright (C) 2008 Apple Inc. All rights reserved.
 
3
 *
 
4
 * Redistribution and use in source and binary forms, with or without
 
5
 * modification, are permitted provided that the following conditions
 
6
 * are met:
 
7
 * 1. Redistributions of source code must retain the above copyright
 
8
 *    notice, this list of conditions and the following disclaimer.
 
9
 * 2. Redistributions in binary form must reproduce the above copyright
 
10
 *    notice, this list of conditions and the following disclaimer in the
 
11
 *    documentation and/or other materials provided with the distribution.
 
12
 *
 
13
 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
 
14
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 
15
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 
16
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
 
17
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 
18
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 
19
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 
20
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 
21
 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
22
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 
23
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 
24
 */
 
25
 
 
26
#include "assembler/jit/ExecutableAllocator.h"
 
27
 
 
28
#if ENABLE_ASSEMBLER && WTF_OS_UNIX && !WTF_OS_SYMBIAN
 
29
 
 
30
#include <sys/mman.h>
 
31
#include <unistd.h>
 
32
 
 
33
#include "assembler/wtf/Assertions.h"
 
34
#include "assembler/wtf/VMTags.h"
 
35
 
 
36
namespace JSC {
 
37
 
 
38
size_t ExecutableAllocator::determinePageSize()
 
39
{
 
40
    return getpagesize();
 
41
}
 
42
 
 
43
ExecutablePool::Allocation ExecutableAllocator::systemAlloc(size_t n)
 
44
{
 
45
    void* allocation = mmap(NULL, n, INITIAL_PROTECTION_FLAGS, MAP_PRIVATE | MAP_ANON, VM_TAG_FOR_EXECUTABLEALLOCATOR_MEMORY, 0);
 
46
    if (allocation == MAP_FAILED)
 
47
        allocation = NULL;
 
48
    ExecutablePool::Allocation alloc = { reinterpret_cast<char*>(allocation), n };
 
49
    return alloc;
 
50
}
 
51
 
 
52
void ExecutableAllocator::systemRelease(const ExecutablePool::Allocation& alloc)
 
53
 
54
    int result = munmap(alloc.pages, alloc.size);
 
55
    ASSERT_UNUSED(result, !result);
 
56
}
 
57
 
 
58
#if WTF_ENABLE_ASSEMBLER_WX_EXCLUSIVE
 
59
void ExecutableAllocator::reprotectRegion(void* start, size_t size, ProtectionSetting setting)
 
60
{
 
61
    if (!pageSize)
 
62
        intializePageSize();
 
63
 
 
64
    // Calculate the start of the page containing this region,
 
65
    // and account for this extra memory within size.
 
66
    intptr_t startPtr = reinterpret_cast<intptr_t>(start);
 
67
    intptr_t pageStartPtr = startPtr & ~(pageSize - 1);
 
68
    void* pageStart = reinterpret_cast<void*>(pageStartPtr);
 
69
    size += (startPtr - pageStartPtr);
 
70
 
 
71
    // Round size up
 
72
    size += (pageSize - 1);
 
73
    size &= ~(pageSize - 1);
 
74
 
 
75
    mprotect(pageStart, size, (setting == Writable) ? PROTECTION_FLAGS_RW : PROTECTION_FLAGS_RX);
 
76
}
 
77
#endif
 
78
 
 
79
#if WTF_CPU_ARM_TRADITIONAL && WTF_OS_LINUX && WTF_COMPILER_RVCT
 
80
__asm void ExecutableAllocator::cacheFlush(void* code, size_t size)
 
81
{
 
82
    ARM
 
83
    push {r7}
 
84
    add r1, r1, r0
 
85
    mov r7, #0xf0000
 
86
    add r7, r7, #0x2
 
87
    mov r2, #0x0
 
88
    svc #0x0
 
89
    pop {r7}
 
90
    bx lr
 
91
}
 
92
#endif
 
93
 
 
94
}
 
95
 
 
96
#endif // HAVE(ASSEMBLER)