Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753412Ab2JOQAL (ORCPT ); Mon, 15 Oct 2012 12:00:11 -0400 Received: from mailhub.sw.ru ([195.214.232.25]:48392 "EHLO relay.sw.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752639Ab2JOQAI (ORCPT ); Mon, 15 Oct 2012 12:00:08 -0400 Subject: [PATCH v6 00/10] IPC: checkpoint/restore in userspace enhancements To: akpm@linux-foundation.org From: Stanislav Kinsbursky Cc: catalin.marinas@arm.com, will.deacon@arm.com, dhowells@redhat.com, manfred@colorfullife.com, hughd@google.com, jmorris@namei.org, mtk.manpages@gmail.com, kosaki.motohiro@jp.fujitsu.com, paulmck@linux.vnet.ibm.com, sds@tycho.nsa.gov, devel@openvz.org, a.p.zijlstra@chello.nl, cmetcalf@tilera.com, linux-driver@qlogic.com, ron.mercer@qlogic.com, viro@zeniv.linux.org.uk, eparis@parisplace.org, tglx@linutronix.de, jitendra.kalsaria@qlogic.com, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-security-module@vger.kernel.org, ebiederm@xmission.com, casey@schaufler-ca.com Date: Mon, 15 Oct 2012 19:59:27 +0400 Message-ID: <20121015155800.28348.23561.stgit@localhost.localdomain> User-Agent: StGit/0.16 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3469 Lines: 81 v6: 1) rebased on 3.7-rc1 v5: 1) Several define-dependent compile bugs fixed 2) IPC message copy test updated 3) A couple of minor fixes. 4) Qlogic driver update: rename of its internal SEM_SET define into SEM_INIT (compile error). v4: 1) If MSG_COPY flag is specified, then "mtype" is not a type, but message number to copy. 2) MSG_SET_COPY logic for sys_msgctl() was removed. v3: 1) Copy messages to user-space under spinlock was replaced by allocation of dummy message before queue lock and then copy of desired message to the dummy one instead of unlinking it from queue list. I.e. the message queue copy logic was changed: messages can be retrived one by one (instead of receiving of the whole list at once). This patch set is aimed to provide additional functionality for all IPC objects, which is required for migration of these objects by user-space checkpoint/restore utils (CRIU). The main problem here was impossibility to set up object id. This patch set solves the problem in two steps: 1) Makes it possible to create new object (shared memory, semaphores set or messages queue) with ID, equal to passed key. 2) Makes it possible to change existent object key. Another problem was to peek messages from queues without deleting them. This was achived by introducing of new MSG_COPY flag for sys_msgrcv(). If MSG_COPY flag is set, then msgtyp is interpreted as message number. The following series implements... --- Stanislav Kinsbursky (10): ipc: remove forced assignment of selected message ipc: "use key as id" functionality for resource get system call introduced ipc: segment key change helper introduced ipc: add new SHM_SET command for sys_shmctl() call ipc: add new MSG_SET command for sys_msgctl() call glge driver: rename internal SEM_SET macro to SEM_INIT ipc: add new SEM_SET command for sys_semctl() call IPC: message queue receive cleanup IPC: message queue copy feature introduced test: IPC message queue copy feture test drivers/net/ethernet/qlogic/qlge/qlge.h | 4 drivers/net/ethernet/qlogic/qlge/qlge_main.c | 16 +- include/linux/msg.h | 5 - include/uapi/linux/ipc.h | 1 include/uapi/linux/msg.h | 2 include/uapi/linux/sem.h | 1 include/uapi/linux/shm.h | 1 ipc/compat.c | 45 +++-- ipc/msg.c | 116 +++++++++--- ipc/msgutil.c | 38 ++++ ipc/sem.c | 14 + ipc/shm.c | 17 +- ipc/util.c | 69 +++++++ ipc/util.h | 6 + security/selinux/hooks.c | 3 security/smack/smack_lsm.c | 3 tools/testing/selftests/ipc/Makefile | 28 +++ tools/testing/selftests/ipc/msgque.c | 251 ++++++++++++++++++++++++++ 18 files changed, 548 insertions(+), 72 deletions(-) create mode 100644 tools/testing/selftests/ipc/Makefile create mode 100644 tools/testing/selftests/ipc/msgque.c -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/