Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp2137042imm; Mon, 3 Sep 2018 20:39:59 -0700 (PDT) X-Google-Smtp-Source: ANB0VdYx5fZ03NEsS+AGThjP13Lo4vFIg6BV2JjV0YyfY37Noqufnwad6NGjiS87lWQ1ks42aYAr X-Received: by 2002:a17:902:25ab:: with SMTP id y40-v6mr30993265pla.120.1536032399237; Mon, 03 Sep 2018 20:39:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536032399; cv=none; d=google.com; s=arc-20160816; b=ve/B+tzbujeXX1w7PMw9gBkksv/JBn6IOUuhvxtmtty0F/F3OmUOO63Gs05G7Wk4WQ I9CCghEtBaQAcsShA6Y+QXGW6Y+NkWsnMblFZCwjmFehkdle4qukzGB52WcsCDBT7qB5 5j8Yyw+omIf+ayW4Kkva0JahlB9jjM4g2jbdcHfwQILTH0C+3hwGpdkoYMo9PxJc8dtf B3ucEoVMmkg8uYRo/OatTAynGfc/p/jOynKGC/3OezBy97XkSEkEgsExvI3QYaGhoqgY CoP1dwREsfmoxbEElGEMGteG8eKwcg6eKsFJoNtEzL9rrmOVgiZo+kn/14G3PmXcvGHm 1VSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:reply-to :arc-authentication-results; bh=O3WjxpTWbcMnnXc/SiL+Z86mdJRY3u0sZl6ooG9aoTc=; b=r3ZPdErAB5LZYqs5dLttEln5/I8OBnHl10bBIZn6ACQBd8jhG8L36QmhtSELhMXGeW Ex+jO3UdOuaONI7K8CyU/PJCx8zsKlWE4Ge7RtCUznHgp8Jn9YLQl2nyPESZJSIFXvNy DMUvAsFL60OTJMUuFo0a/MEeFIWmEY6nhO3Efje1vyASB9BhKCdvr+P2z7jvBXw9GcNZ Jt805DDo7EdzwpehPfnMspesEAt80WfiXNwo/BYHGzllbqvRPHepNehLrrtflWBqmWw1 G5ErPoIjlyxIRfDQ04MaJeHD2UXlgknNFym+2VDMak7yG2EvuB/EosFTVTgOiqqXqRaA RoNA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b2-v6si11817275pgk.379.2018.09.03.20.39.44; Mon, 03 Sep 2018 20:39:59 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726708AbeIDIBd (ORCPT + 99 others); Tue, 4 Sep 2018 04:01:33 -0400 Received: from smtp.infotech.no ([82.134.31.41]:58589 "EHLO smtp.infotech.no" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725995AbeIDIBd (ORCPT ); Tue, 4 Sep 2018 04:01:33 -0400 Received: from localhost (localhost [127.0.0.1]) by smtp.infotech.no (Postfix) with ESMTP id 1661B2041E3; Tue, 4 Sep 2018 05:38:25 +0200 (CEST) X-Virus-Scanned: by amavisd-new-2.6.6 (20110518) (Debian) at infotech.no Received: from smtp.infotech.no ([127.0.0.1]) by localhost (smtp.infotech.no [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id oCJqh9IzGCMh; Tue, 4 Sep 2018 05:38:23 +0200 (CEST) Received: from [192.168.16.56] (unknown [195.69.32.11]) by smtp.infotech.no (Postfix) with ESMTPA id 5B6E3204179; Tue, 4 Sep 2018 05:38:22 +0200 (CEST) Reply-To: dgilbert@interlog.com Subject: Re: Recent removal of bsg read/write support To: Michal Hocko Cc: Richard Weinberger , drorl@infinidat.com, LKML , linux-block@vger.kernel.org, linux-scsi@vger.kernel.org, Linus Torvalds , Christoph Hellwig , Jens Axboe References: <6b907fed-d83f-de75-bde4-11270a0b1b0b@interlog.com> <20180903122804.GA15074@dhcp22.suse.cz> From: Douglas Gilbert Message-ID: <731941f0-c80d-605a-2750-01c8d5ec4dd9@interlog.com> Date: Tue, 4 Sep 2018 05:38:21 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20180903122804.GA15074@dhcp22.suse.cz> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-CA Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2018-09-03 02:28 PM, Michal Hocko wrote: > On Sun 02-09-18 21:16:10, Douglas Gilbert wrote: >> On 2018-09-02 01:44 PM, Richard Weinberger wrote: >>> CC'ing relevant people. Otherwise your mail might get lost. >>> >>> On Sun, Sep 2, 2018 at 1:37 PM Dror Levin wrote: >>>> >>>> Note: I am not subscribed to LKML so please CC replies to this email. >>>> >>>> Hi, >>>> >>>> We have an internal tool that uses the bsg read/write interface to >>>> issue SCSI commands as part of a test suite for a storage device. >>>> >>>> After recently reading on LWN that this interface is to be removed we >>>> tried porting our code to use sg instead. However, that raises new >>>> issues - mainly getting ENOMEM over iSCSI for unknown reasons. >>>> >>>> Because of this we would like to continue using the bsg interface, >>>> even if some changes are required to meet security concerns. >>>> >>>> Is there any chance for this removal to be reverted? I saw it was >>>> already included in 4.19-rc1. >> >> Hi, >> Both bsg and sg are relatively thin shims over the same block layer >> pass-through calls. And neither driver will themselves generate ENOMEM >> unless the CPU is running low of memory. >> >> In my experience, the main reason for unexpected ENOMEMs *** is from >> blk_rq_map_user_iov() in block/blk_map.c called from both drivers. >> That is a particular resource shortage rather than memory in general. >> I do notice the blk_rq_map_user_iov() is/was called with GFP_KERNEL >> in bsg and GFP_ATOMIC by sg. That suggests when you call write() on >> a sg device and get ENOMEM, then wait a little (depends on your app) >> and try again. > > Well, what is the reason to use GFP_ATOMIC in the first place? I am not > familiar with the code so I might be easily wrong but sg_start_req which > calls blk_rq_map_user_iov resp. blk_rq_map_user with GFP_ATOMIC uses > mutex. It is a conditional usage so the sleeping context might depend > on the caller. But I guess it would be better to double check. It looks > suspicious to me. Of the hundreds of 'hacks' on the sg driver over the years, the most common is an expert arguing that GFP_ATOMIC should be changed to GFP_KERNEL. They usually get their way. That is followed around 6 to 9 months later by a sg user complaining about an unexpected broken app. So back it goes to GFP_ATOMIC. Welcome to the merry-go-round. Doug Gilbert