• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2012 Linux Test Project, Inc.
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of version 2 of the GNU General Public
6  * License as published by the Free Software Foundation.
7  *
8  * This program is distributed in the hope that it would be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
11  *
12  * Further, this software is distributed without any warranty that it
13  * is free of the rightful claim of any third person regarding
14  * infringement or the like.  Any license provided herein, whether
15  * implied or otherwise, applies only to this software file.  Patent
16  * licenses, if any, provided herein do not apply to combinations of
17  * this program with other software, or any other product whatsoever.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22  * 02110-1301, USA.
23  */
24 
25 #ifndef _PROCESS_VM_H_
26 #define _PROCESS_VM_H_
27 
28 #include <sys/types.h>
29 #include <sys/ipc.h>
30 #include <sys/sem.h>
31 #include <sys/syscall.h>
32 #include <sys/uio.h>
33 #include <unistd.h>
34 #include "lapi/semun.h"
35 
test_process_vm_readv(pid_t pid,const struct iovec * lvec,unsigned long liovcnt,const struct iovec * rvec,unsigned long riovcnt,unsigned long flags)36 static inline ssize_t test_process_vm_readv(pid_t pid,
37 		const struct iovec *lvec, unsigned long liovcnt,
38 		const struct iovec *rvec, unsigned long riovcnt,
39 		unsigned long flags)
40 {
41 #if defined(__NR_process_vm_readv)
42 	return syscall(__NR_process_vm_readv, pid, lvec, liovcnt,
43 			rvec, riovcnt, flags);
44 #else
45 	return syscall(-1);
46 #endif
47 }
48 
test_process_vm_writev(pid_t pid,const struct iovec * lvec,unsigned long liovcnt,const struct iovec * rvec,unsigned long riovcnt,unsigned long flags)49 static inline ssize_t test_process_vm_writev(pid_t pid,
50 		const struct iovec *lvec, unsigned long liovcnt,
51 		const struct iovec *rvec, unsigned long riovcnt,
52 		unsigned long flags)
53 {
54 #if defined(__NR_process_vm_writev)
55 	return syscall(__NR_process_vm_writev, pid, lvec, liovcnt,
56 			rvec, riovcnt, flags);
57 #else
58 	return syscall(-1);
59 #endif
60 }
61 
safe_semop(int id,unsigned short num,short op)62 void safe_semop(int id, unsigned short num, short op)
63 {
64 	int ret;
65 	struct sembuf sem_op;
66 	sem_op.sem_num = num,
67 	sem_op.sem_op = op,
68 	sem_op.sem_flg = 0;
69 
70 	do {
71 		ret = semop(id, &sem_op, 1);
72 	} while (ret == -1 && errno == EINTR);
73 	if (ret == -1)
74 		tst_brkm(TBROK|TERRNO, NULL, "semop(%d, (%d, %d)) failed",
75 			id, num, op);
76 }
77 
init_sem(int num)78 int init_sem(int num)
79 {
80 	int id, i;
81 	union semun u;
82 	if ((id = semget(IPC_PRIVATE, num, IPC_CREAT|S_IRWXU)) == -1)
83 		tst_brkm(TBROK|TERRNO, NULL, "Couldn't allocate semaphore");
84 
85 	for (i = 0; i < num; i++) {
86 		u.val = 0;
87 		if (semctl(id, 0, SETVAL, u) == -1)
88 			tst_brkm(TBROK|TERRNO, NULL,
89 				"Couldn't initialize sem %d value", i);
90 	}
91 	return id;
92 }
93 
clean_sem(int id)94 void clean_sem(int id)
95 {
96 	if (semctl(id, 0, IPC_RMID) == -1)
97 		tst_brkm(TBROK|TERRNO, NULL, "Couldn't remove sem");
98 }
99 
100 #endif /* _PROCESS_VM_H_ */
101