From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933360AbbHLIxR (ORCPT ); Wed, 12 Aug 2015 04:53:17 -0400 Received: from mail-wi0-f178.google.com ([209.85.212.178]:34695 "EHLO mail-wi0-f178.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932365AbbHLIxN (ORCPT ); Wed, 12 Aug 2015 04:53:13 -0400 Date: Wed, 12 Aug 2015 09:53:09 +0100 From: Lee Jones To: Jassi Brar Cc: "linux-arm-kernel@lists.infradead.org" , Linux Kernel Mailing List , kernel@stlinux.com, Devicetree List Subject: Re: [PATCH v2 2/6] mailbox: dt-bindings: Add shared [driver <=> device tree] defines Message-ID: <20150812085309.GB18282@x1> References: <1437990272-23111-1-git-send-email-lee.jones@linaro.org> <1437990272-23111-3-git-send-email-lee.jones@linaro.org> <20150810082445.GA3249@x1> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 10 Aug 2015, Jassi Brar wrote: > On Mon, Aug 10, 2015 at 1:54 PM, Lee Jones wrote: > > On Mon, 10 Aug 2015, Jassi Brar wrote: > >> On Mon, Jul 27, 2015 at 3:14 PM, Lee Jones wrote: > >> > This header is currently only used for defines pertaining to data > >> > direction i.e. Rx, Tx or Loopback. > >> > > >> > Signed-off-by: Lee Jones > >> > --- > >> > include/dt-bindings/mailbox/mailbox.h | 14 ++++++++++++++ > >> > 1 file changed, 14 insertions(+) > >> > create mode 100644 include/dt-bindings/mailbox/mailbox.h > >> > > >> > diff --git a/include/dt-bindings/mailbox/mailbox.h b/include/dt-bindings/mailbox/mailbox.h > >> > new file mode 100644 > >> > index 0000000..82e929a > >> > --- /dev/null > >> > +++ b/include/dt-bindings/mailbox/mailbox.h > >> > @@ -0,0 +1,14 @@ > >> > +/* > >> > + * This program is free software; you can redistribute it and/or modify > >> > + * it under the terms of the GNU General Public License version 2 as > >> > + * published by the Free Software Foundation. > >> > + */ > >> > + > >> > +#ifndef __MAILBOX_CONTROLLER_DT_BINDINGS_H > >> > +#define __MAILBOX_CONTROLLER_DT_BINDINGS_H > >> > + > >> > +#define MBOX_TX 0x1 > >> > +#define MBOX_RX 0x2 > >> > +#define MBOX_LOOPBACK (MBOX_RX | MBOX_TX) > >> > + > >> Not sure I understand 'loopback'. Does it mean h/w has some > >> 'loopback' mode for testing purposes? Or it simply means the > >> controller can send as well as receive messages? > > > > 'loopback' allows firmware to conduct some early function tests. > > However, channels are simplex, so we provide protection against > > multiple allocation of single channel. By allocating a LOOPBACK > > channel we over-ride this protection and allow a single channel to be > > allocated twice, once for Rx and the other for Tx. > > > So basically hardware is half-duplex, not simplex. I think maybe you > should simply allow for RX and TX always. It should work. Just > handover any received data before send_data (reflecting the h/w > limitation). That way you don't need any such special flag. Unfortunately no, that's not correct. Only Mailbox 0 is half-duplex. The others are simplex (Rx only). Ideally I'd like to keep the LOOPBACK flag, as it's easier to figure out if what someone is attempting to do is actually valid. It is only ever used for 'loopback' testing anyway, so it's a perfectly reasonable description of the channel configuration. -- Lee Jones Linaro STMicroelectronics Landing Team Lead Linaro.org │ Open source software for ARM SoCs Follow Linaro: Facebook | Twitter | Blog