From mboxrd@z Thu Jan 1 00:00:00 1970 From: Mika Westerberg Subject: Re: [PATCH v5 02/18] platform/x86: intel_scu_ipc: Log more information if SCU IPC command fails Date: Wed, 12 Feb 2020 13:36:49 +0200 Message-ID: <20200212113649.GV2667@lahna.fi.intel.com> References: <20200211132603.73509-1-mika.westerberg@linux.intel.com> <20200211132603.73509-3-mika.westerberg@linux.intel.com> <20200211154138.GE10400@smile.fi.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <20200211154138.GE10400@smile.fi.intel.com> Sender: linux-kernel-owner@vger.kernel.org To: Andy Shevchenko Cc: Darren Hart , Lee Jones , Greg Kroah-Hartman , Thomas Gleixner , Ingo Molnar , Borislav Petkov , "H . Peter Anvin" , x86@kernel.org, Zha Qipeng , "David E . Box" , Guenter Roeck , Heikki Krogerus , Wim Van Sebroeck , platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org List-Id: platform-driver-x86.vger.kernel.org On Tue, Feb 11, 2020 at 05:41:38PM +0200, Andy Shevchenko wrote: > On Tue, Feb 11, 2020 at 04:25:47PM +0300, Mika Westerberg wrote: > > Currently we only log an error if the command times out which makes it > > hard to figure out the failing command. This changes the driver to log > > command and subcommand with the error code which should make debugging > > easier. This also allows us to simplify the callers as they don't need > > to log these errors themselves. > > > > Thanks, my comments below. > > ... > > > scu = ipcdev; > > - ipc_command(scu, sub << 12 | cmd); > > + cmdval = sub << 12 | cmd; > > + ipc_command(scu, cmdval); > > err = intel_scu_ipc_check_status(scu); > > > + if (err) > > + dev_err(&scu->dev, "IPC command %#x failed with %d\n", cmdval, > > + err); > > We may move it out of the mutex, right? Also, please keep it one line. Yup. > > mutex_unlock(&ipclock); > > return err; > > ... > > > mutex_lock(&ipclock); > > > + cmdval = (inlen << 16) | (sub << 12) | cmd; > > + ipc_command(scu, cmdval); > > err = intel_scu_ipc_check_status(scu); > > - > > - if (!err) { > > + if (err) { > > + dev_err(&scu->dev, "IPC command %#x failed with %d\n", cmdval, > > + err); > > + } else { > > for (i = 0; i < outlen; i++) > > *out++ = ipc_data_readl(scu, 4 * i); > > } > > It's not visible in this context but it looks like above applies here as well. You mean move outside of the lock? This one calls ipc_data_readl() which should be under the lock.