Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp1270124ybl; Thu, 22 Aug 2019 11:54:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqwmGngWn82tGLKZH/IzBAAEyD/JI5xEWvlVlxT8ALcbHjcVP/tGHYLo4VGVcC1DlEa5RCwX X-Received: by 2002:a17:90a:d592:: with SMTP id v18mr1122506pju.135.1566500048687; Thu, 22 Aug 2019 11:54:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566500048; cv=none; d=google.com; s=arc-20160816; b=iyr6fRdHk0aOkKpDDIm4/vg0F4ecYKOSfDfQCFwChQonc1qtSGHJr/quHkqDoS1WgQ BQq076P/hIuEf1LcZmVYtGNS47q3FxEBsGCKJmn9AtisVNn0VswE1usyG1RhK3Tkw0// /TJNkutvHZcDYqKi9xm33D5kguWm61G8Gop/Pt3ysF3yARIfYi9pHO9LZkXS45qvacyU oVS1lUpr1VKOxGpwvLfZ1f4xS5aMOrjVJf3/SG9JEr14VEOX3S00w2CcsWkbFYQiJFzi hxGfDczE0JvFzr1bl2DPU9f3FpMt9arXMNpU3Zh2O0I/SC5WHWS2HjS/jtHS/9O3ZEeI uF7Q== 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=faXASJSfv/pkaksUxCFpyTKz6EaQbVlfkdMYSEDI0As=; b=vWoEXJs5rc/DiRaunIQt8h2ApWQqxMsMGnL8gaCjZAWoxtm5Pl5dGjdAnF6ls/GPOM 0FCc97VxQiK0U+sf4e9Bn8LmMGAOxbLde0OrfaVHZDWYpFss/E6QNp/Fs5OdlUtp6/0+ IFmZqptaWTvBnIJdH/jL9WmhP3sktKYIqG0VolQftfHogMvZI84XL6ZMsNAoj/YEVZ/8 iC+bs2jszqXWAzzfHezWogZsWnUmOH35ubzNlv2+AuuN5F2Kei8b/rVqXlKvMHfMSj6i bkFWOxwFrYpOJgNnCsmEu9fddbWU1S7k1wMRF8/IzFdOnHaKAHUcRiLSXN2q1TFMdwtf P8Kg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y187si90715pgb.480.2019.08.22.11.53.53; Thu, 22 Aug 2019 11:54:08 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731698AbfHVNxL (ORCPT + 99 others); Thu, 22 Aug 2019 09:53:11 -0400 Received: from mga07.intel.com ([134.134.136.100]:24281 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731483AbfHVNxL (ORCPT ); Thu, 22 Aug 2019 09:53:11 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga105.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 22 Aug 2019 06:53:09 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.64,416,1559545200"; d="scan'208";a="203417795" Received: from linux.intel.com ([10.54.29.200]) by fmsmga004.fm.intel.com with ESMTP; 22 Aug 2019 06:53:09 -0700 Received: from tcwomach-mobl1.amr.corp.intel.com (unknown [10.255.34.51]) by linux.intel.com (Postfix) with ESMTP id ABF455803A5; Thu, 22 Aug 2019 06:53:06 -0700 (PDT) Subject: Re: [RFC PATCH 4/5] ASoC: SOF: Intel: hda: add SoundWire stream config/free callbacks To: Guennadi Liakhovetski Cc: alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org, tiwai@suse.de, broonie@kernel.org, vkoul@kernel.org, gregkh@linuxfoundation.org, jank@cadence.com, srinivas.kandagatla@linaro.org, slawomir.blauciak@intel.com, Bard liao , Rander Wang , Ranjani Sridharan , Liam Girdwood , Jaroslav Kysela , Takashi Iwai , Zhu Yingjiang , YueHaibing , Kai Vehmanen , Arnd Bergmann References: <20190821201720.17768-1-pierre-louis.bossart@linux.intel.com> <20190821201720.17768-5-pierre-louis.bossart@linux.intel.com> <20190822071835.GA30262@ubuntu> From: Pierre-Louis Bossart Message-ID: Date: Thu, 22 Aug 2019 08:53:06 -0500 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20190822071835.GA30262@ubuntu> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Thanks for the review Guennadi >> +static int sdw_config_stream(void *arg, void *s, void *dai, >> + void *params, int link_id, int alh_stream_id) > > I realise, that these function prototypes aren't being introduced by these > patches, but just wondering whether such overly generic prototype is really > a good idea here, whether some of those "void *" pointers could be given > real types. The first one could be "struct device *" etc. In this case the 'arg' parameter is actually a private 'struct snd_sof_dev', as shown below [1]. We probably want to keep this relatively opaque, this is a context that doesn't need to be exposed to the SoundWire code. The dai and params are indeed cases where we could use stronger types, they are snd_soc_dai and hw_params respectively. I don't recall why the existing code is this way, Vinod and Sanyog may have the history of this. > >> +{ >> + struct snd_sof_dev *sdev = arg; >> + struct snd_soc_dai *d = dai; [1] >> + struct sof_ipc_dai_config config; >> + struct sof_ipc_reply reply; >> + int ret; >> + u32 size = sizeof(config); >> + >> + memset(&config, 0, size); >> + config.hdr.size = size; >> + config.hdr.cmd = SOF_IPC_GLB_DAI_MSG | SOF_IPC_DAI_CONFIG; >> + config.type = SOF_DAI_INTEL_ALH; >> + config.dai_index = (link_id << 8) | (d->id); >> + config.alh.stream_id = alh_stream_id; > > Entirely up to you, in such cases I usually do something like > > + struct sof_ipc_dai_config config = { > + .type = SOF_DAI_INTEL_ALH, > + .hre = { > + .size = sizeof(config), > + .cmd = SOF_IPC_GLB_DAI_MSG | SOF_IPC_DAI_CONFIG, > + ... > > which then also avoids a memset(). But that's mostly a matter of personal > preference, since this is on stack, the compiler would probably internally > anyway translate the above initialisation to a memset() with all the > following assignments. I have no preference, so in this case I will go with consistency with existing code, which uses the suggested style for all IPCs. > >> + >> + /* send message to DSP */ >> + ret = sof_ipc_tx_message(sdev->ipc, >> + config.hdr.cmd, &config, size, &reply, >> + sizeof(reply)); >> + if (ret < 0) { >> + dev_err(sdev->dev, >> + "error: failed to set DAI hw_params for link %d dai->id %d ALH %d\n", > > Are readers really expected to understand what "dai->id" means? Wouldn't > "DAI ID" be friendlier, although I understand you - who might not know > what "x->y" stands for?.. ;-) I was trying to avoid a confusion here, we have config->dai_index which are shared concepts between topology and firmware, and dai->id which is shared between topology and machine driver (which refers to the dai in the dai_link which has its own .id). In topology files we have the three indices and of course after a couple of weeks I can't recall which one maps to what. I am afraid DAI ID might be confused with dai_index. If there are suggestions on this I am all ears, all I care about is avoiding ambiguity and having to ask Ranjani what index this really is :-)