Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp133753ybi; Tue, 18 Jun 2019 19:09:58 -0700 (PDT) X-Google-Smtp-Source: APXvYqyOMJh2ACH7WDN6vEmtl9dxAaW1Xt/uWc8Vv3FRjvkuBnSGl7DmkjGvW90/AUKRJ2m45OtJ X-Received: by 2002:a62:5cc6:: with SMTP id q189mr122832472pfb.114.1560910198212; Tue, 18 Jun 2019 19:09:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560910198; cv=none; d=google.com; s=arc-20160816; b=KiIyiis99LsVF2NKIdSNzigZvR+m0JjgkdC7PwlYY+iGp01Xa2eHMRP/s/pqtmgYZt 7XMHaFOjYBlTzSbjksUZJfgeGzzGxOfxnM2qK1aLYUWTCm2VkAdVyjIf8pw+4H8NPmOS V13AmJ4vfk1c2j00QG9Sn4QGiZpWb67WokL7S/IRWV4ojus+YQyg3/ZtMNE+YR3/2tGz zyQFXIRZarFWsPWN2l9LtJYqCQTXR16ncZ919ECLqOj6a+yTOrpxzJVhKre5F/kip1pc FPkEY9S6xUS9Cwq69PE+JTI6nt0tvC3ozBrzCykftutWGSEtNrpXfl7CVwcnB88hmcGW OiCQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:content-transfer-encoding :content-disposition:mime-version:message-id:subject:cc:to:from:date :dkim-signature; bh=s9lpMBH/IugmiFXNYI6ZpyhR++3sMpJb2daAAUrg87c=; b=HcSB3Id5c4O5b6B64wMN4gbhsJR8M9V0bxJPu8VGVpWFG+XSh6njs3XtuG1Pzu3ODq sikPPyf7IfNgsrYgp0d3LFRpgcWGHZbU9qErNr/O7K1A6plPAExAkK1Py31yzLvBX2uI T8eJNrHmro8kGUSonJEXvwMVol+d5UYIhprc8Hq6xZdieXWaTPOJnvH7JMuBfo9h7E8l 6Kcio2/t3Q56/DNlyGARlUicr6xl27RbGoSXK4wfR1JRNuOGBmAfKFrZf7HNc1a9abBP H5n7Bq8fpXQGHQ/5uBzrx7/TV2a+k0N/B8MwqLWrW5UMEY1F0DGAlkRJruG9mqQfXdy6 repw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=pWuu1Ni7; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o7si1716024pgp.316.2019.06.18.19.09.42; Tue, 18 Jun 2019 19:09:58 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=pWuu1Ni7; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726047AbfFSCIA (ORCPT + 99 others); Tue, 18 Jun 2019 22:08:00 -0400 Received: from mail-ed1-f67.google.com ([209.85.208.67]:39390 "EHLO mail-ed1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726037AbfFSCH7 (ORCPT ); Tue, 18 Jun 2019 22:07:59 -0400 Received: by mail-ed1-f67.google.com with SMTP id m10so24644600edv.6; Tue, 18 Jun 2019 19:07:58 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:mime-version:content-disposition :content-transfer-encoding:user-agent; bh=s9lpMBH/IugmiFXNYI6ZpyhR++3sMpJb2daAAUrg87c=; b=pWuu1Ni7Pj1W/hQq6vtS/AHazRgRHRM9Y7pAnxIHlPNPp6BXKMhcu6/Tn5/pJhbGQ5 vPGGQLKsfjVFADDj+ujB57FNC1EWIjbJTvto5xsdO4cvQVbAfVinkdDrBbRPrbdw9F+I jklYuAY0LP1WIV2QiiCA36FGAMYk+MswrcAPW/Sfze4f491rr9WEqVlAqgB6+dQEJddA IuCq61M1lW1DJKw84V3pP9YP41wIR/AuOw4qzzZyWaRfjXQbl6ps/M5QAILuNMM5cVTE ehUjrIf8MRNDvanyPP30lFjG79ieh+IhvWp7g9VERKAKow8gzilKfGkm8C5LTnWFkUbm c7Dg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:mime-version :content-disposition:content-transfer-encoding:user-agent; bh=s9lpMBH/IugmiFXNYI6ZpyhR++3sMpJb2daAAUrg87c=; b=JDzVKgyYP3iFF4mrk/DE8jFtHZFMTnGS/rMnmCu9J8YG2y3dm3hKLBHoVN4fE+Nbq1 ObDouB6cUsHO+D49BBpHRJ2YWMW4WhJ9SoO8nP5rLCHO/xvGiqdfRErGfpDmWb5dEWZ/ BKRQPZLSmqA/6bulzwGcuAYMUnhovNqQDbCzE/g6+hP1NVZ6w4IfaIdZjrBrYqCJd0wE 0wlwxs2H6c9Beo5kpc5qd1YNzjjVr4zaayZz+FWDUE3D+xe8kQxmGjI64Gh0nITiHwu9 b/CPFA6WvISstBw63p9ImgmUKnxUZweWF+Ir+bvnpD9Qn7KwlDRiJLaiForvewIul/rX kU3w== X-Gm-Message-State: APjAAAV1Qja+hAHyGwUWv9AFYrIRIloJAB7nCPrUVyNTSNyoHkpbiOAV fuB0Q95J4N2GmdL7IESS130= X-Received: by 2002:a17:906:2301:: with SMTP id l1mr54424834eja.92.1560910077820; Tue, 18 Jun 2019 19:07:57 -0700 (PDT) Received: from smtp.gmail.com ([187.121.151.146]) by smtp.gmail.com with ESMTPSA id k11sm1974837edq.54.2019.06.18.19.07.53 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Tue, 18 Jun 2019 19:07:57 -0700 (PDT) Date: Tue, 18 Jun 2019 23:07:50 -0300 From: Rodrigo Siqueira To: Maarten Lankhorst , Maxime Ripard , Sean Paul , David Airlie , Daniel Vetter Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, intel-gfx@lists.freedesktop.org Subject: [PATCH V4] drm/drm_vblank: Change EINVAL by the correct errno Message-ID: <20190619020750.swzerehjbvx6sbk2@smtp.gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit User-Agent: NeoMutt/20180716 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For historical reason, the function drm_wait_vblank_ioctl always return -EINVAL if something gets wrong. This scenario limits the flexibility for the userspace make detailed verification of the problem and take some action. In particular, the validation of “if (!dev->irq_enabled)” in the drm_wait_vblank_ioctl is responsible for checking if the driver support vblank or not. If the driver does not support VBlank, the function drm_wait_vblank_ioctl returns EINVAL which does not represent the real issue; this patch changes this behavior by return EOPNOTSUPP. Additionally, some operations are unsupported by this function, and returns EINVAL; this patch also changes the return value to EOPNOTSUPP in this case. Lastly, the function drm_wait_vblank_ioctl is invoked by libdrm, which is used by many compositors; because of this, it is important to check if this change breaks any compositor. In this sense, the following projects were examined: * Drm-hwcomposer * Kwin * Sway * Wlroots * Wayland-core * Weston * Xorg (67 different drivers) For each repository the verification happened in three steps: * Update the main branch * Look for any occurrence "drmWaitVBlank" with the command: git grep -n "drmWaitVBlank" * Look in the git history of the project with the command: git log -SdrmWaitVBlank Finally, none of the above projects validate the use of EINVAL which make safe, at least for these projects, to change the return values. Change since V3: - Return EINVAL for _DRM_VBLANK_SIGNAL (Daniel) Change since V2: Daniel Vetter and Chris Wilson - Replace ENOTTY by EOPNOTSUPP - Return EINVAL if the parameters are wrong Signed-off-by: Rodrigo Siqueira --- drivers/gpu/drm/drm_vblank.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/gpu/drm/drm_vblank.c b/drivers/gpu/drm/drm_vblank.c index 603ab105125d..bed233361614 100644 --- a/drivers/gpu/drm/drm_vblank.c +++ b/drivers/gpu/drm/drm_vblank.c @@ -1582,7 +1582,7 @@ int drm_wait_vblank_ioctl(struct drm_device *dev, void *data, unsigned int flags, pipe, high_pipe; if (!dev->irq_enabled) - return -EINVAL; + return -EOPNOTSUPP; if (vblwait->request.type & _DRM_VBLANK_SIGNAL) return -EINVAL; -- 2.21.0