Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp3877187ybl; Mon, 26 Aug 2019 01:52:25 -0700 (PDT) X-Google-Smtp-Source: APXvYqzu3/S6hRivSOefx0MMOTwSWf4dVAIQ2SmK49qq+OzZy4ci7nDXmrYY1Cg5XhzGBBv7qUre X-Received: by 2002:a62:5207:: with SMTP id g7mr19290512pfb.152.1566809545212; Mon, 26 Aug 2019 01:52:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566809545; cv=none; d=google.com; s=arc-20160816; b=EQpgXYlasvMdjgvGUHN9sDP5XswFcunQZcBs5VjIOR9J2/18A+hx/BU83cnjUnat3E 0Xw/a3Ox0uCie88y6Mh8LFmDVu/UcAMpTmEI4vS8nqI64gsozced2pnk131coOTZsEuw jYQpgcge2e21fBRCaqK8vPWD51DbA+B66PpxjUV0b6QSJClcZVzF4gid0TJlG+vpPGTH Mue/NGctTDPZBMdCRKbRayENz5dGCnP47wdakeuZh4kXhgEVpFWBHilXnOtmtAW9K7Ta hmgCGU1po8FinoPh7laLEmNLbjJtM23+rb+Vc3QpM6X/gK8YdiVR/SncKmlORHIzlIa7 /IVw== 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; bh=GG61pWuu2lVC75gmcfEFGYQovxuFxr+K8y72BeJlj5I=; b=akFdsX1fZN1Mi8rdkNz6da4jeOmTNcQOpzuwMyUQOICLYkqZ19JmzaSGSuOkA2cxxQ wnfAuDm+ZL2ZH7gRSdaGVZCrDxFyik1fh5IXCyFj+UGEu0uC+GcvAER12RTa6bu3rHNo uOPRmMNNRNOWsYPd+SwpLawMYE+ormHhaxdE3vpdFqwnBt0CL/EFa/i/Md5F0U2AjbB5 q2lAfqjkplItQ9Z41qHzQ3fj/UFD0+BTbVbNekX1Mk+XuKjklHbnGvu/Rn+JI3gjxJMB 46beBdP6ul1u3QurXCmRGNxD72FqvRE4vchgcdS4hBttX+ZeFf+3BsAmH7cUIzAsveJW Gc+Q== 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 k192si8527743pge.222.2019.08.26.01.52.09; Mon, 26 Aug 2019 01:52:25 -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 S1730782AbfHZImG (ORCPT + 99 others); Mon, 26 Aug 2019 04:42:06 -0400 Received: from www1102.sakura.ne.jp ([219.94.129.142]:22408 "EHLO www1102.sakura.ne.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729614AbfHZImF (ORCPT ); Mon, 26 Aug 2019 04:42:05 -0400 Received: from fsav104.sakura.ne.jp (fsav104.sakura.ne.jp [27.133.134.231]) by www1102.sakura.ne.jp (8.15.2/8.15.2) with ESMTP id x7Q8fk0Z012652; Mon, 26 Aug 2019 17:41:46 +0900 (JST) (envelope-from katsuhiro@katsuster.net) Received: from www1102.sakura.ne.jp (219.94.129.142) by fsav104.sakura.ne.jp (F-Secure/fsigk_smtp/530/fsav104.sakura.ne.jp); Mon, 26 Aug 2019 17:41:46 +0900 (JST) X-Virus-Status: clean(F-Secure/fsigk_smtp/530/fsav104.sakura.ne.jp) Received: from [192.168.1.2] (118.153.231.153.ap.dti.ne.jp [153.231.153.118]) (authenticated bits=0) by www1102.sakura.ne.jp (8.15.2/8.15.2) with ESMTPSA id x7Q8fj9d012648 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NO); Mon, 26 Aug 2019 17:41:45 +0900 (JST) (envelope-from katsuhiro@katsuster.net) Subject: Re: [PATCH] ASoC: es8316: limit headphone mixer volume To: Daniel Drake , Hans de Goede Cc: Mark Brown , David Yang , alsa-devel@alsa-project.org, Linux Kernel References: <20190824210426.16218-1-katsuhiro@katsuster.net> <943932bf-2042-2a69-c705-b8e090e96377@redhat.com> From: Katsuhiro Suzuki Message-ID: Date: Mon, 26 Aug 2019 17:41:45 +0900 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello Daniel, On 2019/08/26 11:53, Daniel Drake wrote: > On Mon, Aug 26, 2019 at 1:38 AM Hans de Goede wrote: >> On 24-08-19 23:04, Katsuhiro Suzuki wrote: >>> This patch limits Headphone mixer volume to 4 from 7. >>> Because output sound suddenly becomes very loudly with many noise if >>> set volume over 4. > > That sounds like something that should be limited in UCM. > >> Higher then 4 not working matches my experience, see this comment from >> the UCM file: alsa-lib/src/conf/ucm/codecs/es8316/EnableSeq.conf : >> >> # Set HP mixer vol to -6 dB (4/7) louder does not work >> cset "name='Headphone Mixer Volume' 4" > > What does "does not work" mean more precisely? > > I checked the spec, there is indeed something wrong in the kernel driver here. > The db scale is not a simple scale as the kernel source suggests. > > Instead it is: > 0000 – -12dB > 0001 – -10.5dB > 0010 – -9dB > 0011 – -7.5dB > 0100 – -6dB > 1000 – -4.5dB > 1001 – -3dB > 1010 – -1.5dB > 1011 – 0dB > > So perhaps we can fix the kernel to follow this table and then use UCM > to limit the volume if its too high on a given platform? > Thank you very important information. So you mean value 5, 6, 7 are illegal settings for ES8316. Correct codes are static const SNDRV_CTL_TLVD_DECLARE_DB_RANGE(hpmixer_gain_tlv, 0, 4, TLV_DB_SCALE_ITEM(-1200, 150, 0), 8, 11, TLV_DB_SCALE_ITEM(-450, 150, 0), ); and... SOC_DOUBLE_TLV("Headphone Mixer Volume", ES8316_HPMIX_VOL, 0, 4, 15, 0, hpmixer_gain_tlv), Is my understanding correct? If so I'll test it on my board (RockPro64) and re-send patch. BTW, do you know how to get ES8316 I2C registers spec? I want to see it for understanding current code, but I cannot find... > Thanks > Daniel > > Best Regards, Katsuhiro Suzuki