Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752999AbdI1Kzx (ORCPT ); Thu, 28 Sep 2017 06:55:53 -0400 Received: from mail-qt0-f194.google.com ([209.85.216.194]:51994 "EHLO mail-qt0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752970AbdI1Kzv (ORCPT ); Thu, 28 Sep 2017 06:55:51 -0400 X-Google-Smtp-Source: AOwi7QCi8NGMBXcOp4yDn3RX5zLgE38/a0kdY9pSSL/cf1fDJ9FfaVOC3f3Rgrh098V1bIGrv+vPiNwuekr2NP9OX0Q= MIME-Version: 1.0 In-Reply-To: References: <20170924200620.GA24368@avx2> <9bc11ace-d111-cdef-5280-8cdda027ae9a@gmail.com> <20170926190018.GA30898@avx2> From: Alexey Dobriyan Date: Thu, 28 Sep 2017 12:55:49 +0200 Message-ID: Subject: Re: [PATCH 1/2 v2] fdmap(2) To: mtk.manpages@gmail.com Cc: Andy Lutomirski , Andrew Morton , "linux-kernel@vger.kernel.org" , Linux API , Randy Dunlap , Thomas Gleixner , Djalal Harouni , Alexey Gladkov , Aliaksandr Patseyenak , Tatsiana Brouka Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2087 Lines: 74 On 9/28/17, Michael Kerrisk (man-pages) wrote: > On 27 September 2017 at 17:03, Andy Lutomirski wrote: >>> The idea is to start process. In ideal world, only bynary system calls >>> would exist and shells could emulate /proc/* same way bash implement >>> /dev/tcp >> >> Then start the process by doing it for real and making it obviously >> useful. We should not add a pair of vaguely useful, rather weak >> syscalls just to start a process of modernizing /proc. Before doing it for real it would be nice to have at least a nod from people in charge that syscalls which return binary information are OK. Otherwise some EIATF guy will just say "NAK /proc is fine, it always was fine". Or look from another angle: sched_setaffinity exists but there is no /proc counterpart, shells must use taskset(1) and world didn't end. > I concur. > > Alexey, you still have not wxplained who specifically needs this > right now, and how, precisely, they plan to use the new system calls. > It is all very arm-wavey so far. It is not if you read even example program in the original patch. Any program which queries information about file descriptors will benefit both in CPU and memory usage. void closefrom(int start) { int fd[1024]; int n; while ((n = fdmap(0, fd, sizeof(fd)/sizeof(fd[0]), start)) > 0) { unsigned int i; for (i = 0; i < n; i++) close(fd[i]); start = fd[n - 1] + 1; } } CRIU naturally to know everything about descriptors of target processes: It does: int predump_task_files(int pid) { struct dirent *de; DIR *fd_dir; int ret = -1; pr_info("Pre-dump fds for %d)\n", pid); fd_dir = opendir_proc(pid, "fd"); if (!fd_dir) return -1; while ((de = readdir(fd_dir))) { if (dir_dots(de)) continue; if (predump_one_fd(pid, atoi(de->d_name))) goto out; } ret = 0; out: closedir(fd_dir); return ret; } which is again inefficient.