Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1997694ybz; Sat, 2 May 2020 12:36:22 -0700 (PDT) X-Google-Smtp-Source: APiQypIpnoQxmdleXSBHqe0wWk/o4xmLb59OKPxy8t6Vn5JAN4SpaB5BqpbTn0PPhA7x46RkGk2b X-Received: by 2002:a17:906:558a:: with SMTP id y10mr8972008ejp.192.1588448182034; Sat, 02 May 2020 12:36:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588448182; cv=none; d=google.com; s=arc-20160816; b=PksHzvJaa7qAmt/sksNf0imk+z31Ptf1B/2CDsxiVjuAM0BbNsMHJb13R7AaR/zgai glG81+3hPbKnM2xsaZGh93imWUS3aE3lVZLrQ6T5Ft9vNJFCq86ZT9XAUBL+hUnoToTe Ln5XiaH0VO7i0N2/NPgElmyabxi6ixgYHMCaPgV7yfxNzk57hgE20RPA9gUaHZem4Ljm dOLHBsq7NQKwndjwOJxRW17ADPRMQuJGi2ZGYbo2KmHWIf2t/TLEYHReQZbBOqOIedWM EM4K4Fb+NSealqWpI29FOh+9X/3gJ7uMAqdtIBzCElHexAPIjMmQqSB4KH7Vtruxt4ep PzJg== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=TIL2KbMxRtnATvJqUzPTFDCNwLrdBpSmmIc1wV1dEHA=; b=vI1EHteNa31wZF8bsCO3POuRYMLC2M0w1GYS+Tab17Yuap5W3eXX4u2MXKweK6kl4s Xaq+6SlEOJODTbQ7+11/oJqD36gue6OagO6Cs4jMCYMaLsN3MmUeVhPyhc68YSacJhOj WPm/MVcH7np048qT+/UqYY4iSpj+PrjJAz1K4LQqpNSaB/CGBsq1FxM7AnTarUrmrs2S IWrivFww0fN47DFy1qMGOURw3X0+Q/ivDnPvAghvaqDEbHF3kousEKk7jz1xVO9f4uO/ z9onohXrEAJQFHP/h6l2dgORnvIis/P8AohNeHD6iPmwCIN7EoGW/kmRvXj5tiM2Ebso QXiA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=b4TQAU3l; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id 1si4024687ejx.68.2020.05.02.12.35.58; Sat, 02 May 2020 12:36:22 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=b4TQAU3l; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1728503AbgEBTbu (ORCPT + 99 others); Sat, 2 May 2020 15:31:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48756 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1728488AbgEBTbr (ORCPT ); Sat, 2 May 2020 15:31:47 -0400 Received: from mail-pj1-x1042.google.com (mail-pj1-x1042.google.com [IPv6:2607:f8b0:4864:20::1042]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9366DC061A0C for ; Sat, 2 May 2020 12:31:47 -0700 (PDT) Received: by mail-pj1-x1042.google.com with SMTP id ms17so1693316pjb.0 for ; Sat, 02 May 2020 12:31:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=TIL2KbMxRtnATvJqUzPTFDCNwLrdBpSmmIc1wV1dEHA=; b=b4TQAU3lmiD8PQG+dwxpbXSHwlgPMje9VEnlG+Q/yWnaPXzbs0+oWvYmWyh9wIevPh hkznabwuMxJkrTsq0vpbyApI+jsejbYLhfj4JnIG/l7FH5aS1bn+B0ypxAIZ+LZs4IP/ sh0wlwEQJ67L/Jp7OFw4xghqClyuUOd6sGPKj1SIAinSKZaANfpHRS1eELWe/DZ3iTWk nnC6CNSBJ2Le/CYvy1FQPX/Dp3eudXxq1UqepnRbMvp5e/9MjDPJOlACjGrBZ3nT/rvi u58TJt7z1vBVnh1wXZAHG8wI7Xij5SfUCBzKeP9XDiMkYE1vduykLcjPOu0L6DDTZO6p GARg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=TIL2KbMxRtnATvJqUzPTFDCNwLrdBpSmmIc1wV1dEHA=; b=YE4bYthN5yBez3CSBB/8FVMrY/UfH3XnnRzTivzLddJb1VxEgQYgsqVFOnt0SjcQ5/ 80NZIkfYVC79QExDOSIETZ0dxxZiJqKR0wOyFYrmIZgBXaYOjI8amT8CICZ/hSvpaZMz dA7kKfCgMx8YEvHt/rqc7ZmPZ3US3uWc8DgglviERWaviaNm8GBlDbHsOghxMarXJjBh jW5rESzSxah25I7QoeyXz7GHkQXJ1eyASOFIZV21vgLJyPWyQKJvz9COgto2ibwwMy2A 6hN1W4Uz3jpf0YVLjixGqRZ8vC5QEag7EIId/vh5Si/ILX2X5EN5xX5fTudsiLV+UE7N 2YnQ== X-Gm-Message-State: AGi0PuaNHOYY0V8tR+jXBNMr9C4YeBufMaBm+TOsxiSZ9m5cMz0LJkq1 FLBRqmiVjwV1tNTti1RZgrA= X-Received: by 2002:a17:90b:8c4:: with SMTP id ds4mr7545166pjb.133.1588447907181; Sat, 02 May 2020 12:31:47 -0700 (PDT) Received: from anarsoul-thinkpad.lan (216-71-213-236.dyn.novuscom.net. [216.71.213.236]) by smtp.gmail.com with ESMTPSA id 138sm5034358pfz.31.2020.05.02.12.31.46 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 02 May 2020 12:31:46 -0700 (PDT) From: Vasily Khoruzhick To: Jaroslav Kysela , Takashi Iwai , Thomas Gleixner , Pavel Machek , Allison Randal , alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org Cc: Vasily Khoruzhick Subject: [PATCH 2/2] ALSA: line6: Add poll callback for hwdep Date: Sat, 2 May 2020 12:31:20 -0700 Message-Id: <20200502193120.79115-3-anarsoul@gmail.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200502193120.79115-1-anarsoul@gmail.com> References: <20200502193120.79115-1-anarsoul@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org At least POD HD500 uses message-based communication, both sides can send messages. Add poll callback so application can wait for device messages without using busy loop. Signed-off-by: Vasily Khoruzhick --- sound/usb/line6/driver.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/sound/usb/line6/driver.c b/sound/usb/line6/driver.c index 86adf87d57f0..7629116f570e 100644 --- a/sound/usb/line6/driver.c +++ b/sound/usb/line6/driver.c @@ -630,11 +630,27 @@ line6_hwdep_write(struct snd_hwdep *hwdep, const char __user *data, long count, return rv; } +static __poll_t +line6_hwdep_poll(struct snd_hwdep *hwdep, struct file *file, poll_table *wait) +{ + __poll_t rv; + struct usb_line6 *line6 = hwdep->private_data; + + poll_wait(file, &line6->messages.wait_queue, wait); + + mutex_lock(&line6->messages.read_lock); + rv = kfifo_len(&line6->messages.fifo) == 0 ? 0 : EPOLLIN | EPOLLRDNORM; + mutex_unlock(&line6->messages.read_lock); + + return rv; +} + static const struct snd_hwdep_ops hwdep_ops = { .open = line6_hwdep_open, .release = line6_hwdep_release, .read = line6_hwdep_read, .write = line6_hwdep_write, + .poll = line6_hwdep_poll, }; /* Insert into circular buffer */ -- 2.26.2