Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp913190imm; Wed, 8 Aug 2018 07:48:43 -0700 (PDT) X-Google-Smtp-Source: AA+uWPzaT0r3WB+SQn6N706r47BxwxKD4duWn3ZesKYk6B/BG+MWkjXCQtjiJITCvBhxiKHYzTWP X-Received: by 2002:a62:5b85:: with SMTP id p127-v6mr3353505pfb.33.1533739723068; Wed, 08 Aug 2018 07:48:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533739723; cv=none; d=google.com; s=arc-20160816; b=xsYDr8nAQRzVWCMzFLV9YWBJK6ASoc6UfnBRhilXg9t7LqgShIvokaE2xpZzkVewBT K9k0E0Dway1rTqMs+j2GYpRcLTvd9EnoJq0JhQMxJ3+4UWQCulfseURj8PmQ2QPhjMJO DwqJPxc9YLeTw2B5ovGQH2tS5fgUTtVVcyRxbe2SVEPqFbzQsWIoi1/Io9uiGw0+WxJb DbGiGijd6To+w/djkqQ+idgOKmXWB5kbBMq7b9IHLOnEXg2NT1sTYXgXFaKmU2i2EYxT iJtZyBjlAcna0B3HGmbvIzQqAqvWDG+sWVI+BBnWtiT2zAVCbRg/eoS/cv39YrnWgc6D JliQ== 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:dkim-signature :arc-authentication-results; bh=7/0++2HKQ320Gf21vzV3aHGcewmPX1Ay2LZXtLOe/to=; b=tlqbtZLFTsU0XGI1fvSZ1Mvus0iQHNTgbWqZ+Ulopaa1Nx+yJY/BtnW8S6q1xIIa+P DDCj/tWapi/eVoKCPKq+EdsvTKZAlYIdFJFib55e0CnczectCgj3B8iqaHkGKOdR9tt7 UHzxcKuU3hqRXYbnPKx/pqgxSF+Ti5SsaWES03EIGJ0eiuTNd4/A1/6cNWBOPhrT7WuH Wf6yuDmFbBKryRic71ZTUv1T4PavhWaZjD1RZT8AkZVLmMSsiXurr3iyLBRRh8AUfjmk snXQ348Bqit1ELYNnjFbNdGUDiYO7mF3kkYlts1EEdxRZmgiGKgh0PvXtRVcO6oenjtJ rYHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@kapsi.fi header.s=20161220 header.b=mXmcQMXr; 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 q7-v6si3705238pll.142.2018.08.08.07.48.28; Wed, 08 Aug 2018 07:48:43 -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; dkim=fail header.i=@kapsi.fi header.s=20161220 header.b=mXmcQMXr; 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 S1729485AbeHHRG3 (ORCPT + 99 others); Wed, 8 Aug 2018 13:06:29 -0400 Received: from mail.kapsi.fi ([91.232.154.25]:45317 "EHLO mail.kapsi.fi" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728297AbeHHRG3 (ORCPT ); Wed, 8 Aug 2018 13:06:29 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=kapsi.fi; s=20161220; h=Content-Transfer-Encoding:Content-Type:In-Reply-To: MIME-Version:Date:Message-ID:From:References:Cc:To:Subject:Sender:Reply-To: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=7/0++2HKQ320Gf21vzV3aHGcewmPX1Ay2LZXtLOe/to=; b=mXmcQMXrCGvTS0ZH1IaJu1UsbM 0CST/4UqgQg308dXMOMZJLCWnlneuQ8leAmiw8gE+mtzTr84uKePx6CG8GhwkBIHb0bGfE5uQ75j2 4j+ZcUpMPLwRTVGPHAmH9ZNBDDSnhiUXKyAC0ljY+jdc3uZSPnebXyoCmzi1A2d6HKICnomfSAAlB BXd+EBdbGv8N+RVf/RBXvCfswKTA3km6Ghbuc6X9E0j6tCB3jBE6+ivxXyT6A9xzfIo9zxVrvbSBd ka0aUgZwS+aikaWXWVwds+mSws1pVJU2gjrcGLMpuBpiX7b8LjAi/tgZzschNs6SEvuZW7kHzTtjW cYz61Mmg==; Received: from dsl-hkibng22-54faa2-250.dhcp.inet.fi ([84.250.162.250]) by mail.kapsi.fi with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.89) (envelope-from ) id 1fnPjI-0002xn-1r; Wed, 08 Aug 2018 17:46:28 +0300 Subject: Re: [PATCH v3 3/8] mailbox: Add transmit done by blocking option To: Jassi Brar Cc: Mikko Perttunen , Greg KH , Thierry Reding , Jon Hunter , Devicetree List , linux-serial@vger.kernel.org, linux-tegra@vger.kernel.org, ", linux-arm-kernel"@lists.infradead.org, srv_heupstream , srv_heupstream , Linux Kernel Mailing List References: <20180702114033.15654-1-mperttunen@nvidia.com> <20180702114033.15654-4-mperttunen@nvidia.com> <907bac36-0c54-8f38-0f5e-f59196d414c6@kapsi.fi> From: Mikko Perttunen Message-ID: Date: Wed, 8 Aug 2018 17:46:27 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.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: 7bit X-SA-Exim-Connect-IP: 84.250.162.250 X-SA-Exim-Mail-From: cyndis@kapsi.fi X-SA-Exim-Scanned: No (on mail.kapsi.fi); SAEximRunCond expanded to false Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/08/2018 05:39 PM, Jassi Brar wrote: > On Wed, Aug 8, 2018 at 8:04 PM, Mikko Perttunen wrote: >> >> >> On 08/08/2018 05:10 PM, Jassi Brar wrote: >>> >>> On Wed, Aug 8, 2018 at 5:08 PM, Mikko Perttunen wrote: >>>> >>>> >>>> >>>> On 04.08.2018 13:45, Mikko Perttunen wrote: >>>>> >>>>> >>>>> On 08/03/2018 03:54 PM, Jassi Brar wrote: >>>>>> >>>>>> >>>>>> On Mon, Jul 2, 2018 at 5:10 PM, Mikko Perttunen >>>>>> wrote: >>>>>>> >>>>>>> >>>>>>> Add a new TXDONE option, TXDONE_BY_BLOCK. With this option, the >>>>>>> send_data function of the mailbox driver is expected to block until >>>>>>> the message has been sent. The new option is used with the Tegra >>>>>>> Combined UART driver to minimize unnecessary overhead when >>>>>>> transmitting >>>>>>> data. >>>>>>> >>>>>> 1) TXDONE_BY_BLOCK flag :- >>>>>> Have you tried setting the flag >>>>>> mbox_chan->mbox_client->tx_block >>>>>> ? >>>>> >>>>> >>>>> >>>>> No - I suppose I should have done that. I'm a bit concerned about >>>>> overhead >>>>> as send_data may be called thousands of times per second, so I tried to >>>>> make >>>>> it as close as possible to the downstream driver that just pokes the >>>>> mailbox >>>>> register directly. >>>> >>>> >>>> >>>> I tried using polling in the mailbox framework. Some printing is done >>>> from >>>> atomic context so it seems tx_block cannot be used - >>>> wait_for_completion_timeout understandably does not work in atomic >>>> context. >>>> I also tried without tx_block, in which case I got some horribly garbled >>>> output, but "Try increasing MBOX_TX_QUEUE_LEN" was readable there. >>>> >>>> Any opinions? >>>> >>> The problems arise because your hardware (SM) supports TXDONE_BY_POLL, >>> but your client drives it by TXDONE_BY_ACK because the older DB >>> channels are so. >>> >>> Please populate SM channels as a separate controller than DB. >>> The DB controller, as is, run by ACK method. >>> The SM controller should be run by polling, i.e, set txdone_poll = >>> true and the poll period small enough. The virtual tty client driver >>> should be able to safely set tx_block from appropriate context. >>> >> >> Sorry, I should have clarified that I already split up the controllers. The >> SM controller has txdone_poll = true. I didn't adjust txpoll_period so I >> guess it's zero. >> > Can you please share your code (controller and client) ? Maybe offline > if you wish. > I'll upload a git branch tomorrow -- I'm not at the machine with the code now. Mikko