linux.cc revision 11383
16019Shines@cs.fsu.edu/*
210037SARM gem5 Developers * Copyright (c) 2011 ARM Limited
310037SARM gem5 Developers * All rights reserved
410037SARM gem5 Developers *
510037SARM gem5 Developers * The license below extends only to copyright in the software and shall
610037SARM gem5 Developers * not be construed as granting a license to any other intellectual
710037SARM gem5 Developers * property including but not limited to intellectual property relating
810037SARM gem5 Developers * to a hardware implementation of the functionality of the software
910037SARM gem5 Developers * licensed hereunder.  You may use the software subject to the license
1010037SARM gem5 Developers * terms below provided that you ensure that this notice is replicated
1110037SARM gem5 Developers * unmodified and in its entirety in all distributions of the software,
1210037SARM gem5 Developers * modified or unmodified, in source code or in binary form.
1310037SARM gem5 Developers *
146019Shines@cs.fsu.edu * Copyright (c) 2003-2005 The Regents of The University of Michigan
156019Shines@cs.fsu.edu * Copyright (c) 2007-2008 The Florida State University
166019Shines@cs.fsu.edu * All rights reserved.
176019Shines@cs.fsu.edu *
186019Shines@cs.fsu.edu * Redistribution and use in source and binary forms, with or without
196019Shines@cs.fsu.edu * modification, are permitted provided that the following conditions are
206019Shines@cs.fsu.edu * met: redistributions of source code must retain the above copyright
216019Shines@cs.fsu.edu * notice, this list of conditions and the following disclaimer;
226019Shines@cs.fsu.edu * redistributions in binary form must reproduce the above copyright
236019Shines@cs.fsu.edu * notice, this list of conditions and the following disclaimer in the
246019Shines@cs.fsu.edu * documentation and/or other materials provided with the distribution;
256019Shines@cs.fsu.edu * neither the name of the copyright holders nor the names of its
266019Shines@cs.fsu.edu * contributors may be used to endorse or promote products derived from
276019Shines@cs.fsu.edu * this software without specific prior written permission.
286019Shines@cs.fsu.edu *
296019Shines@cs.fsu.edu * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
306019Shines@cs.fsu.edu * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
316019Shines@cs.fsu.edu * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
326019Shines@cs.fsu.edu * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
336019Shines@cs.fsu.edu * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
346019Shines@cs.fsu.edu * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
356019Shines@cs.fsu.edu * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
366019Shines@cs.fsu.edu * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
376019Shines@cs.fsu.edu * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
386019Shines@cs.fsu.edu * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
396019Shines@cs.fsu.edu * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
406019Shines@cs.fsu.edu *
416019Shines@cs.fsu.edu * Authors: Stephen Hines
426019Shines@cs.fsu.edu */
436019Shines@cs.fsu.edu
4411383Sbrandon.potter@amd.com#include "arch/arm/linux/linux.hh"
4511383Sbrandon.potter@amd.com
468229Snate@binkert.org#include <fcntl.h>
4711383Sbrandon.potter@amd.com#include <sys/mman.h>
486019Shines@cs.fsu.edu
496019Shines@cs.fsu.edu// open(2) flags translation table
5011381Sbrandon.potter@amd.comSyscallFlagTransTable ArmLinux32::openFlagTable[] = {
516019Shines@cs.fsu.edu#ifdef _MSC_VER
5210037SARM gem5 Developers  { ArmLinux32::TGT_O_RDONLY,     _O_RDONLY },
5310037SARM gem5 Developers  { ArmLinux32::TGT_O_WRONLY,     _O_WRONLY },
5410037SARM gem5 Developers  { ArmLinux32::TGT_O_RDWR,       _O_RDWR },
5511382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_CREAT,      _O_CREAT },
5611382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_EXCL,       _O_EXCL },
5711382Sbrandon.potter@amd.com#ifdef _O_NOCTTY
5811382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_NOCTTY,     _O_NOCTTY },
5911382Sbrandon.potter@amd.com#endif
6011382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_TRUNC,      _O_TRUNC },
6110037SARM gem5 Developers  { ArmLinux32::TGT_O_APPEND,     _O_APPEND },
626019Shines@cs.fsu.edu#ifdef _O_NONBLOCK
6310037SARM gem5 Developers  { ArmLinux32::TGT_O_NONBLOCK,   _O_NONBLOCK },
646019Shines@cs.fsu.edu#endif
6511382Sbrandon.potter@amd.com#ifdef _O_DSYNC
6611382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_DSYNC,      _O_DSYNC },
6711382Sbrandon.potter@amd.com#endif
6811382Sbrandon.potter@amd.com  { ArmLinux32::TGT_FASYNC,       _O_ASYNC },
6911382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_DIRECT,     _O_DIRECT },
7011382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_LARGEFILE,  _O_LARGEFILE },
7111382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_DIRECTORY,  _O_DIRECTORY },
7211382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_NOFOLLOW,   _O_NOFOLLOW },
7311382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_NOATIME,    _O_NOATIME },
7411382Sbrandon.potter@amd.com#ifdef _O_CLOEXEC
7511382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_CLOEXEC,    _O_CLOEXEC },
766019Shines@cs.fsu.edu#endif
776019Shines@cs.fsu.edu#ifdef _O_SYNC
7810037SARM gem5 Developers  { ArmLinux32::TGT_O_SYNC,       _O_SYNC },
796019Shines@cs.fsu.edu#endif
8011382Sbrandon.potter@amd.com#ifdef _O_PATH
8111382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_PATH,       _O_PATH },
8211382Sbrandon.potter@amd.com#endif
836019Shines@cs.fsu.edu#else /* !_MSC_VER */
8410037SARM gem5 Developers  { ArmLinux32::TGT_O_RDONLY,     O_RDONLY },
8510037SARM gem5 Developers  { ArmLinux32::TGT_O_WRONLY,     O_WRONLY },
8610037SARM gem5 Developers  { ArmLinux32::TGT_O_RDWR,       O_RDWR },
8710037SARM gem5 Developers  { ArmLinux32::TGT_O_CREAT,      O_CREAT },
8810037SARM gem5 Developers  { ArmLinux32::TGT_O_EXCL,       O_EXCL },
8910037SARM gem5 Developers  { ArmLinux32::TGT_O_NOCTTY,     O_NOCTTY },
9010037SARM gem5 Developers  { ArmLinux32::TGT_O_TRUNC,      O_TRUNC },
9110037SARM gem5 Developers  { ArmLinux32::TGT_O_APPEND,     O_APPEND },
9210037SARM gem5 Developers  { ArmLinux32::TGT_O_NONBLOCK,   O_NONBLOCK },
9311382Sbrandon.potter@amd.com#ifdef O_DSYNC
9411382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_DSYNC,      O_DSYNC },
956019Shines@cs.fsu.edu#endif
9611382Sbrandon.potter@amd.com  { ArmLinux32::TGT_FASYNC,       O_ASYNC },
977441SAli.Saidi@ARM.com#ifdef O_DIRECT
9810037SARM gem5 Developers  { ArmLinux32::TGT_O_DIRECT,     O_DIRECT },
997441SAli.Saidi@ARM.com#endif
1007441SAli.Saidi@ARM.com#ifdef O_LARGEFILE
10110037SARM gem5 Developers  { ArmLinux32::TGT_O_LARGEFILE,  O_LARGEFILE },
1027441SAli.Saidi@ARM.com#endif
1037441SAli.Saidi@ARM.com#ifdef O_DIRECTORY
10410037SARM gem5 Developers  { ArmLinux32::TGT_O_DIRECTORY,  O_DIRECTORY },
1057441SAli.Saidi@ARM.com#endif
1067441SAli.Saidi@ARM.com#ifdef O_NOFOLLOW
10710037SARM gem5 Developers  { ArmLinux32::TGT_O_NOFOLLOW,   O_NOFOLLOW },
1087441SAli.Saidi@ARM.com#endif
10911382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_NOATIME,    O_NOATIME },
11011382Sbrandon.potter@amd.com#ifdef O_CLOEXEC
11111382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_CLOEXEC,    O_CLOEXEC },
11211382Sbrandon.potter@amd.com#endif
11311382Sbrandon.potter@amd.com#ifdef O_SYNC
11411382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_SYNC,       O_SYNC },
11511382Sbrandon.potter@amd.com#endif
11611382Sbrandon.potter@amd.com#ifdef O_PATH
11711382Sbrandon.potter@amd.com  { ArmLinux32::TGT_O_PATH,       O_PATH },
11811382Sbrandon.potter@amd.com#endif
1196019Shines@cs.fsu.edu#endif /* _MSC_VER */
1206019Shines@cs.fsu.edu};
1216019Shines@cs.fsu.edu
12210037SARM gem5 Developersconst int ArmLinux32::NUM_OPEN_FLAGS = sizeof(ArmLinux32::openFlagTable) /
12310037SARM gem5 Developers                                       sizeof(ArmLinux32::openFlagTable[0]);
1246019Shines@cs.fsu.edu
12511383Sbrandon.potter@amd.com// mmap(2) flags translation table
12611383Sbrandon.potter@amd.comSyscallFlagTransTable ArmLinux32::mmapFlagTable[] = {
12711383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_SHARED,     MAP_SHARED },
12811383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_PRIVATE,    MAP_PRIVATE },
12911383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_ANON,       MAP_ANON },
13011383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_DENYWRITE,  MAP_DENYWRITE },
13111383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_EXECUTABLE, MAP_EXECUTABLE },
13211383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_FILE,       MAP_FILE },
13311383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_GROWSDOWN,  MAP_GROWSDOWN },
13411383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_HUGETLB,    MAP_HUGETLB },
13511383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_LOCKED,     MAP_LOCKED },
13611383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_NONBLOCK,   MAP_NONBLOCK },
13711383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_NORESERVE,  MAP_NORESERVE },
13811383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_POPULATE,   MAP_POPULATE },
13911383Sbrandon.potter@amd.com#ifdef MAP_STACK
14011383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_STACK,      MAP_STACK },
14111383Sbrandon.potter@amd.com#endif
14211383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_ANONYMOUS,  MAP_ANONYMOUS },
14311383Sbrandon.potter@amd.com  { ArmLinux32::TGT_MAP_FIXED,      MAP_FIXED },
14411383Sbrandon.potter@amd.com};
14511383Sbrandon.potter@amd.com
14611383Sbrandon.potter@amd.comconst unsigned ArmLinux32::NUM_MMAP_FLAGS =
14711383Sbrandon.potter@amd.com        sizeof(ArmLinux32::mmapFlagTable) /
14811383Sbrandon.potter@amd.com        sizeof(ArmLinux32::mmapFlagTable[0]);
14911383Sbrandon.potter@amd.com
15010037SARM gem5 Developers// open(2) flags translation table
15111381Sbrandon.potter@amd.comSyscallFlagTransTable ArmLinux64::openFlagTable[] = {
15210037SARM gem5 Developers#ifdef _MSC_VER
15310037SARM gem5 Developers  { ArmLinux64::TGT_O_RDONLY,     _O_RDONLY },
15410037SARM gem5 Developers  { ArmLinux64::TGT_O_WRONLY,     _O_WRONLY },
15510037SARM gem5 Developers  { ArmLinux64::TGT_O_RDWR,       _O_RDWR },
15611382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_CREAT,      _O_CREAT },
15711382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_EXCL,       _O_EXCL },
15811382Sbrandon.potter@amd.com#ifdef _O_NOCTTY
15911382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_NOCTTY,     _O_NOCTTY },
16011382Sbrandon.potter@amd.com#endif
16111382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_TRUNC,      _O_TRUNC },
16210037SARM gem5 Developers  { ArmLinux64::TGT_O_APPEND,     _O_APPEND },
16310037SARM gem5 Developers#ifdef _O_NONBLOCK
16410037SARM gem5 Developers  { ArmLinux64::TGT_O_NONBLOCK,   _O_NONBLOCK },
16510037SARM gem5 Developers#endif
16611382Sbrandon.potter@amd.com#ifdef _O_DSYNC
16711382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_DSYNC,       _O_DSYNC },
16811382Sbrandon.potter@amd.com#endif
16911382Sbrandon.potter@amd.com  { ArmLinux64::TGT_FASYNC,       _O_ASYNC },
17011382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_DIRECT,     _O_DIRECT },
17111382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_LARGEFILE,  _O_LARGEFILE },
17211382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_DIRECTORY,  _O_DIRECTORY },
17311382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_NOFOLLOW,   _O_NOFOLLOW },
17411382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_NOATIME,    _O_NOATIME },
17511382Sbrandon.potter@amd.com#ifdef _O_CLOEXEC
17611382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_CLOEXEC,    _O_CLOEXEC },
17710037SARM gem5 Developers#endif
17810037SARM gem5 Developers#ifdef _O_SYNC
17910037SARM gem5 Developers  { ArmLinux64::TGT_O_SYNC,       _O_SYNC },
18010037SARM gem5 Developers#endif
18111382Sbrandon.potter@amd.com#ifdef _O_PATH
18211382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_PATH,       _O_PATH },
18311382Sbrandon.potter@amd.com#endif
18410037SARM gem5 Developers#else /* !_MSC_VER */
18510037SARM gem5 Developers  { ArmLinux64::TGT_O_RDONLY,     O_RDONLY },
18610037SARM gem5 Developers  { ArmLinux64::TGT_O_WRONLY,     O_WRONLY },
18710037SARM gem5 Developers  { ArmLinux64::TGT_O_RDWR,       O_RDWR },
18810037SARM gem5 Developers  { ArmLinux64::TGT_O_CREAT,      O_CREAT },
18910037SARM gem5 Developers  { ArmLinux64::TGT_O_EXCL,       O_EXCL },
19010037SARM gem5 Developers  { ArmLinux64::TGT_O_NOCTTY,     O_NOCTTY },
19110037SARM gem5 Developers  { ArmLinux64::TGT_O_TRUNC,      O_TRUNC },
19210037SARM gem5 Developers  { ArmLinux64::TGT_O_APPEND,     O_APPEND },
19310037SARM gem5 Developers  { ArmLinux64::TGT_O_NONBLOCK,   O_NONBLOCK },
19411382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_DSYNC,      O_DSYNC },
19510037SARM gem5 Developers#ifdef FASYNC
19611382Sbrandon.potter@amd.com  { ArmLinux64::TGT_FASYNC,       O_ASYNC },
19710037SARM gem5 Developers#endif
19810037SARM gem5 Developers#ifdef O_DIRECT
19910037SARM gem5 Developers  { ArmLinux64::TGT_O_DIRECT,     O_DIRECT },
20010037SARM gem5 Developers#endif
20110037SARM gem5 Developers#ifdef O_LARGEFILE
20210037SARM gem5 Developers  { ArmLinux64::TGT_O_LARGEFILE,  O_LARGEFILE },
20310037SARM gem5 Developers#endif
20410037SARM gem5 Developers#ifdef O_DIRECTORY
20510037SARM gem5 Developers  { ArmLinux64::TGT_O_DIRECTORY,  O_DIRECTORY },
20610037SARM gem5 Developers#endif
20710037SARM gem5 Developers#ifdef O_NOFOLLOW
20810037SARM gem5 Developers  { ArmLinux64::TGT_O_NOFOLLOW,   O_NOFOLLOW },
20910037SARM gem5 Developers#endif
21011382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_NOATIME,    O_NOATIME },
21111382Sbrandon.potter@amd.com#ifdef O_CLOEXEC
21211382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_CLOEXEC,    O_CLOEXEC },
21311382Sbrandon.potter@amd.com#endif
21411382Sbrandon.potter@amd.com#ifdef O_SYNC
21511382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_SYNC,       O_SYNC },
21611382Sbrandon.potter@amd.com#endif
21711382Sbrandon.potter@amd.com#ifdef O_PATH
21811382Sbrandon.potter@amd.com  { ArmLinux64::TGT_O_PATH,       O_PATH },
21911382Sbrandon.potter@amd.com#endif
22010037SARM gem5 Developers#endif /* _MSC_VER */
22110037SARM gem5 Developers};
22210037SARM gem5 Developers
22310037SARM gem5 Developersconst int ArmLinux64::NUM_OPEN_FLAGS = sizeof(ArmLinux64::openFlagTable) /
22410037SARM gem5 Developers                                       sizeof(ArmLinux64::openFlagTable[0]);
22510037SARM gem5 Developers
22611383Sbrandon.potter@amd.com// mmap(2) flags translation table
22711383Sbrandon.potter@amd.comSyscallFlagTransTable ArmLinux64::mmapFlagTable[] = {
22811383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_SHARED,     MAP_SHARED },
22911383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_PRIVATE,    MAP_PRIVATE },
23011383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_ANON,       MAP_ANON },
23111383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_DENYWRITE,  MAP_DENYWRITE },
23211383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_EXECUTABLE, MAP_EXECUTABLE },
23311383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_FILE,       MAP_FILE },
23411383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_GROWSDOWN,  MAP_GROWSDOWN },
23511383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_HUGETLB,    MAP_HUGETLB },
23611383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_LOCKED,     MAP_LOCKED },
23711383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_NONBLOCK,   MAP_NONBLOCK },
23811383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_NORESERVE,  MAP_NORESERVE },
23911383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_POPULATE,   MAP_POPULATE },
24011383Sbrandon.potter@amd.com#ifdef MAP_STACK
24111383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_STACK,      MAP_STACK },
24211383Sbrandon.potter@amd.com#endif
24311383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_ANONYMOUS,  MAP_ANONYMOUS },
24411383Sbrandon.potter@amd.com  { ArmLinux64::TGT_MAP_FIXED,      MAP_FIXED },
24511383Sbrandon.potter@amd.com};
24611383Sbrandon.potter@amd.com
24711383Sbrandon.potter@amd.comconst unsigned ArmLinux64::NUM_MMAP_FLAGS =
24811383Sbrandon.potter@amd.com        sizeof(ArmLinux64::mmapFlagTable) /
24911383Sbrandon.potter@amd.com        sizeof(ArmLinux64::mmapFlagTable[0]);
25011383Sbrandon.potter@amd.com
251