Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp7219338rwb; Wed, 23 Nov 2022 03:58:02 -0800 (PST) X-Google-Smtp-Source: AA0mqf7N/UgjPUv1Tmfc0rQPUyCpk+rLExEUkD0S+uX+23Pt+uLCBp+wfF9VgXzmPIbtJIsT0hRr X-Received: by 2002:a05:6a00:330d:b0:56c:6bcc:cf0e with SMTP id cq13-20020a056a00330d00b0056c6bcccf0emr8772183pfb.64.1669204682383; Wed, 23 Nov 2022 03:58:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669204682; cv=none; d=google.com; s=arc-20160816; b=lJ2dSy4doP2OMWL/u7uM7ophAlPwFj/zwiPAgRNtgdAeaRsFDp2F/EBIfszgRfnnnv OtNPLL5NlzlGG7S3skC+SrUIOEqjGYTOEaWd8UD4UhZ1uDUSFAQt/VSRIu4QjPWxQqXF 2FLOOYepkzkfRYvklaWYABinwGaUDGhnoDT3KOopPq/V9JSGMTYfCO0muxuj6HghttXd +SyyDQ05xvdN0H35jLZalauBsqHZNhXuWTZS3tTAKg7Bxglff/qriV/ZkGxxOYPqnGmK 69ItITKf4SGWjCkmz6VH5Q6dSyFAUwIOZp0p63//ZXKqo32Ci2Iv5ZBExK5xvTWzPnuL vzQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=2eAF2IC7vqnoge/+amySehgAT/PdR6wjI591V/JkZKw=; b=M8XYDjDyHsbd1ZYDLVDDLOC9JQ0JSr/NaCG1B9ZxWbt8xi8Yt6lDQOo74F2RGmfyQn m0hAAO1+5rDEgXkkVEXgXdk2436fdDZ14lLaTKr9EOnHrD81MGYJeuiI7B6cMr0qEvYM alCqG6mq6MNpyU84OZMnBMd6gutRAbfAnGQmiO7Kd+hDD6cvs24ZTuY5RUggUEONlN9n Vr5NnR9NABVkIPF1GTXHOQpqgwI7XALS/G/An7QPn5ResbriacPxUkYsAyd3fPyFH6W/ nmVew/3vlC0sYON8lN3O2IaBKeNsJYEDKP/gK7UI4ZSsqmnrdO1Q/jN7XVAGmd7WKsaf DNIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20210112 header.b=mqkPGnUR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nu18-20020a17090b1b1200b0020b2101908asi1893046pjb.16.2022.11.23.03.57.51; Wed, 23 Nov 2022 03:58:02 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=fail header.i=@gmail.com header.s=20210112 header.b=mqkPGnUR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236581AbiKWL33 (ORCPT + 89 others); Wed, 23 Nov 2022 06:29:29 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35118 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237373AbiKWL3B (ORCPT ); Wed, 23 Nov 2022 06:29:01 -0500 Received: from mail-wr1-x429.google.com (mail-wr1-x429.google.com [IPv6:2a00:1450:4864:20::429]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8734CC74A for ; Wed, 23 Nov 2022 03:27:51 -0800 (PST) Received: by mail-wr1-x429.google.com with SMTP id x5so24862714wrt.7 for ; Wed, 23 Nov 2022 03:27:51 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:in-reply-to:disposition-notification-to :from:references:cc:to:content-language:subject:user-agent :mime-version:date:message-id:from:to:cc:subject:date:message-id :reply-to; bh=2eAF2IC7vqnoge/+amySehgAT/PdR6wjI591V/JkZKw=; b=mqkPGnURQu6LmZgVdJVI1eTMjCpOwtxipViWnRu62Kj6+By1LHxPM/CcIOY9rgIbG0 gvDSkV3glw6RtzuZKgtfnFOaIMPM4DoLAJsM+3JlkIz/VMTqHQz1E+wJWv/JviZBLOop ebqz8/N9VvJ1xeDL0L6xS2ruFlgRd5Vi+851xA8ySXTKCzrQdQE4rtMPRmXtpROR53Vg Cj20vvHK7JPvimrZZ+LCwpzXcVhRfL7zmfHx9xGM4DHHiwufDiNE0G7U8p6Ddllck7/3 dOsOokb+ikqB7hMW19ShTR2G+7abUeYRXoiELNHvO/B/x9uYugAhGKftHkThaTcCbeyY rNqg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:disposition-notification-to :from:references:cc:to:content-language:subject:user-agent :mime-version:date:message-id:x-gm-message-state:from:to:cc:subject :date:message-id:reply-to; bh=2eAF2IC7vqnoge/+amySehgAT/PdR6wjI591V/JkZKw=; b=alQoG7WU70SHkQ9Xhwt5+pQCOAj9kGyEnBLYZN4XtTUB+88MWAdQo/TxIGqfKJGn2T kTKjTVF6HPIrOCkPNp8l+mZqcrbQs73eCkfzZ7C52Gxw4J/TcQLFXG6BPM3ApUj5eYCq Q1MJStwSGOCn/L/dTwID+pYE1SQSBXNMcHXwEfzRNDUbJAIJEXlltMOmPqwg9xgDEXzy BAm1gpMPsmSlrmjMMNkgo48a0+XUfz4aGcMF5HrGSZsWpbDSBTIgUenxUVQKArtSWXhJ YuN85hf4fZKYAwbgilm86U5BXgQOtI658sziDk4TFILxoET4/xQ8tDamHD8Bwhg1H0Q4 zkOA== X-Gm-Message-State: ANoB5pkNW3+Fh4goQRYnhNXYibMqwynuy29cAuxIltRhc8gChry3Aja7 yioyBYq7SJRS24sjpMJuQxE= X-Received: by 2002:adf:e986:0:b0:241:8435:ea7e with SMTP id h6-20020adfe986000000b002418435ea7emr16118401wrm.103.1669202870010; Wed, 23 Nov 2022 03:27:50 -0800 (PST) Received: from ?IPV6:2001:1ae9:2f0:fa00:5962:fdfb:2a9a:17bd? (2001-1ae9-2f0-fa00-5962-fdfb-2a9a-17bd.ip6.tmcz.cz. [2001:1ae9:2f0:fa00:5962:fdfb:2a9a:17bd]) by smtp.gmail.com with ESMTPSA id k1-20020a5d6281000000b0022ae0965a8asm16358617wru.24.2022.11.23.03.27.49 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 23 Nov 2022 03:27:49 -0800 (PST) Message-ID: Date: Wed, 23 Nov 2022 12:27:48 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.2.2 Subject: Re: [PATCH 1/1] Fix kill(-1,s) returning 0 on 0 kills Content-Language: en-US To: Oleg Nesterov Cc: "Eric W. Biederman" , Kees Cook , Thomas Gleixner , Peter Zijlstra , Marco Elver , linux-kernel@vger.kernel.org References: <20221122161240.137570-1-pskocik@gmail.com> <20221122161240.137570-2-pskocik@gmail.com> <20221123103016.GA32207@redhat.com> From: Petr Skocik In-Reply-To: <20221123103016.GA32207@redhat.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.6 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, GB_FREEMAIL_DISPTO,NICE_REPLY_A,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE, SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/23/22 11:30, Oleg Nesterov wrote: > On 11/22, Petr Skocik wrote: >> --- a/kernel/signal.c >> +++ b/kernel/signal.c >> @@ -1600,20 +1600,18 @@ static int kill_something_info(int sig, struct kernel_siginfo *info, pid_t pid) >> ret = __kill_pgrp_info(sig, info, >> pid ? find_vpid(-pid) : task_pgrp(current)); >> } else { >> - int retval = 0, count = 0; >> struct task_struct * p; >> >> + ret = -ESRCH; >> for_each_process(p) { >> if (task_pid_vnr(p) > 1 && >> !same_thread_group(p, current)) { >> int err = group_send_sig_info(sig, info, p, >> PIDTYPE_MAX); >> - ++count; >> if (err != -EPERM) >> - retval = err; >> + ret = err; /*either all 0 or all -EINVAL*/ > The patch looks good to me, and it also simplifies the code. > > But I fail to understand the /*either all 0 or all -EINVAL*/ comment above.. > > Oleg. > Thanks. The comment is explained in my reply to Kees Cook: https://lkml.org/lkml/2022/11/22/1327. I felt like making it because without it to me it suspiciously looks like the `if ( err != -EPERM) ret = err;` (or `if ( err != -EPERM) retval = err;` in the original) could be masking a non-EPERM failure with a later success, but it isn't because in this context, all the non-EPERM return vals should either ALL be 0 or ALL be -EINVAL. The original code seems to make this assumption too, although implicitly. Perhaps this should be asserted somehow (WARN_ON?). If it couldn't be assumed, I'd imagine you'd want to guard against such masking         int retval = 0, count = 0;         struct task_struct * p;         for_each_process(p) {             if (task_pid_vnr(p) > 1 &&                     !same_thread_group(p, current)) {                 int err = group_send_sig_info(sig, info, p,                                   PIDTYPE_MAX);                 if (err != -EPERM){                     ++count;                     if ( err < 0 ) /*retval is 0 to start with and set to negatives only*/                         retval = err;                 }             }         }         ret = count ? retval : -ESRCH; Regards, Petr Skocik