Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp4466859ybi; Tue, 11 Jun 2019 07:09:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqyfwQl9P5bq+gbLG6lf2w/cfIUbZmEjGdfE3R01IAhAX+cFI8ifSMBONsJTy4pRnUhPbc+g X-Received: by 2002:a17:902:d695:: with SMTP id v21mr60615979ply.342.1560262148672; Tue, 11 Jun 2019 07:09:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560262148; cv=none; d=google.com; s=arc-20160816; b=Otav/KoYJNnpVkvU4L4Yr2wm05chE8U0onw6NxuXMuXlhW5CTL9hL/2Rbe9Vi3slTs wSHhSFXVIbADJWIYAgKnfiNbC0kSHaohUwRvzLeWe4ojBeobD1bufiX+tZfqyRj0RgkS 9Kmm1L+DtIewUOY1CUWM+CzXU/kqqtoBVt5T6wFUSAdYVvQGhoC6ebmfLhJTaJwUccis JvuKzFmEExbPaFOIVpBZp6n+Mz3i3eJH3npMKX1r5Y2YkFhp3rG5Z5AyO3yrZGV3GdXg tc7a7aUJwoj/9fbn8VbzkYLp81X3wugf3gJ2H9KD8uVGIIvVu7iJSywG4SvNA6qFxSx3 rqHg== 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:date:message-id:from :references:cc:to:subject; bh=rqeNjmcn/7F8hbhmWtLQRUxFTcNOl7OgsdDIfsxTSN8=; b=wkHrmj65oYOSVta9e7mRjWa1aR8hTDSBuAK26NErvsGUeR7AoRexieJNgQpyWUhCdT h7cloVGmTH35uXrhGKIXEr6yaSWZWpHAxlLldgksl+jdsgYb/484XZdbmLPr1aK6b3Hm ACpgWxxAy346tb4el9FssAshINOLyq0mtKXDPavWTZcq9FXnBxMOIwVtMDxhldz8KGMe 6ryMdKdL2yIh4oJwm5p7GYMfOU+y4nn+W/XpzKsScaKH1Wc8XrNt56TAqL3lnmhzINAX OcOby5u7swR6CtDBSk6efuhGpi2XjKXr+JTKK7oW0qyFzOHRBWMxNciaSxKa9t2QN09P pnGQ== 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 i95si12765788plb.106.2019.06.11.07.08.53; Tue, 11 Jun 2019 07:09: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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389183AbfFKODD (ORCPT + 99 others); Tue, 11 Jun 2019 10:03:03 -0400 Received: from mx1.mailbox.org ([80.241.60.212]:18060 "EHLO mx1.mailbox.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387447AbfFKODC (ORCPT ); Tue, 11 Jun 2019 10:03:02 -0400 Received: from smtp2.mailbox.org (smtp2.mailbox.org [IPv6:2001:67c:2050:105:465:1:2:0]) (using TLSv1.2 with cipher ECDHE-RSA-CHACHA20-POLY1305 (256/256 bits)) (No client certificate requested) by mx1.mailbox.org (Postfix) with ESMTPS id 77BF551380; Tue, 11 Jun 2019 16:03:00 +0200 (CEST) X-Virus-Scanned: amavisd-new at heinlein-support.de Received: from smtp2.mailbox.org ([80.241.60.241]) by spamfilter02.heinlein-hosting.de (spamfilter02.heinlein-hosting.de [80.241.56.116]) (amavisd-new, port 10030) with ESMTP id paOZoJQ0fFI0; Tue, 11 Jun 2019 16:02:56 +0200 (CEST) Subject: Re: [PATCH 2/2 v5] tty/serial/8250: use mctrl_gpio helpers To: Andy Shevchenko Cc: linux-serial@vger.kernel.org, linux-kernel@vger.kernel.org, Yegor Yefremov , Mika Westerberg , Giulio Benetti , Greg Kroah-Hartman References: <20190611105603.4435-1-sr@denx.de> <20190611105603.4435-2-sr@denx.de> <20190611124415.GT9224@smile.fi.intel.com> From: Stefan Roese Message-ID: <85f0d39c-e5d8-320b-e611-d956630a629f@denx.de> Date: Tue, 11 Jun 2019 16:02:54 +0200 MIME-Version: 1.0 In-Reply-To: <20190611124415.GT9224@smile.fi.intel.com> 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 On 11.06.19 14:44, Andy Shevchenko wrote: > On Tue, Jun 11, 2019 at 12:56:03PM +0200, Stefan Roese wrote: >> From: Yegor Yefremov >> >> This patch permits the usage for GPIOs to control >> the CTS/RTS/DTR/DSR/DCD/RI signals. > >> static inline void serial8250_out_MCR(struct uart_8250_port *up, int value) >> { >> serial_out(up, UART_MCR, value); >> + >> + if (up->gpios) { >> + int mctrl_gpio = 0; >> + >> + if (value & UART_MCR_RTS) >> + mctrl_gpio |= TIOCM_RTS; >> + if (value & UART_MCR_DTR) >> + mctrl_gpio |= TIOCM_DTR; >> + >> + mctrl_gpio_set(up->gpios, mctrl_gpio); >> + } >> } >> >> static inline int serial8250_in_MCR(struct uart_8250_port *up) >> { >> - return serial_in(up, UART_MCR); >> + int mctrl; >> + >> + mctrl = serial_in(up, UART_MCR); >> + >> + if (up->gpios) { >> + int mctrl_gpio = 0; >> + >> + /* save current MCR values */ >> + if (mctrl & UART_MCR_RTS) >> + mctrl_gpio |= TIOCM_RTS; >> + if (mctrl & UART_MCR_DTR) >> + mctrl_gpio |= TIOCM_DTR; >> + >> + mctrl_gpio = mctrl_gpio_get_outputs(up->gpios, &mctrl_gpio); >> + if (mctrl_gpio & TIOCM_RTS) >> + mctrl |= UART_MCR_RTS; >> + else >> + mctrl &= ~UART_MCR_RTS; >> + >> + if (mctrl_gpio & TIOCM_DTR) >> + mctrl |= UART_MCR_DTR; >> + else >> + mctrl &= ~UART_MCR_DTR; >> + } >> + >> + return mctrl; >> } > > These are using OR logic with potentially volatile data. Shouldn't we mask > unused bits in UART_MCR in case of up->gpios != NULL? Sorry, I don't see, which bits you are referring to? Could you please be a bit more specific with the variable / macro meant (example)? >> + if (up->gpios == 0) > > This is type inconsistency with this check as far as I understand. > I guess you have to do either (up->gpios == NULL), or (!up->gpios). Ah, right. Thanks for spotting. Thanks, Stefan