Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3370393imm; Mon, 13 Aug 2018 10:27:37 -0700 (PDT) X-Google-Smtp-Source: AA+uWPyWX3p7bCj4k8mIDRctOkcfyubXULv7ny+PCR9MKbLLoCKgwgu+K2lFYX6rE28vu6XA3NLb X-Received: by 2002:a17:902:9b93:: with SMTP id y19-v6mr13068716plp.113.1534181257444; Mon, 13 Aug 2018 10:27:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534181257; cv=none; d=google.com; s=arc-20160816; b=osyucqMQzgtEo6qfqvFdJbhHvBKzAaoNaVRl8rvRnEhZ5BTCm4JmyVdOZvuOl71lp3 0vJ7cgGEC3BZjL8am/l84WMiK83S1cT+2iI30RDBZnfFjTL0BLoUmecibn1btHyP24LQ l8sSU2dgJAFtXh9a+CkMq0UMv8MPiIpHKjKRpq5N3h5fjfFv5dCRs0I+QI3dZtxSQLPW uGyMq9JPtiVz3rnmrGrqFirfGf4mSPpjfwomAY7fwLBcuvM0XiGVSSsvRI1hxfx6ccxr tNImCCJYu1wbaaAJV4Fv2/NbTgWHbRZ8CoZV9B6RQ3IMpEO4k1csYGRgATC+VzsKaGn4 lJGQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=nAuuGfEBqUzGmffhMdinMiP0Bbawez3wjdM3P55HzJ4=; b=LgdRJfrj2BYLIqnnKSrn4XzPYWQTm7Ew1dwcoPXmi6Es7zFUfpdkhmVSDvVTjyfVey wtvnCTFBkWcvB+pR4a6vDQ86zmlkXGpPbFb8gsb7hJt8BmgGcFScbLuc06kL59aozDHv yLhomlO/GI3GegNx7gvk3oslJewtTyCbgPAjligQCHmyTMD99SNW5CuV6eV57zUDGKLk u8XvGO4CWfoIc9AH3X2ke4ergBewYUMtlCVLgJ6QqIDuUjms9PuTo1N7uiX5WPqrkVta 8LBb/2pRpXNMZgmbCSWl7C8SeizcgD+rs+mqTevKpyNqRU0PJFaqIw8kJkFYXLHQVxkG C7eA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qLWn8yQQ; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 62-v6si20279746pfu.79.2018.08.13.10.27.22; Mon, 13 Aug 2018 10:27:37 -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=pass header.i=@gmail.com header.s=20161025 header.b=qLWn8yQQ; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730022AbeHMTIh (ORCPT + 99 others); Mon, 13 Aug 2018 15:08:37 -0400 Received: from mail-wr1-f68.google.com ([209.85.221.68]:47031 "EHLO mail-wr1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728293AbeHMTIg (ORCPT ); Mon, 13 Aug 2018 15:08:36 -0400 Received: by mail-wr1-f68.google.com with SMTP id h14-v6so14771477wrw.13 for ; Mon, 13 Aug 2018 09:25:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=nAuuGfEBqUzGmffhMdinMiP0Bbawez3wjdM3P55HzJ4=; b=qLWn8yQQpQHDhlTrwDiT63XTpFGoHP3P80dXof5vykQDOCgp7lq2VolWRDDzCnA/1+ kB0E1TMqHs2lPHn+L0joY4b900PzTmPyVA7Dx3LrrvL8CsP7aM96iz73uJciAso8tDrw aafeaaaL8H/XdK/rsF7bAmHuWtg+7kwJCzsTi0qYhGIEI7g6Sq4xtTh7ucKB1HKpmWIG XEI5yh3mMLZgmwep29SayhYrovtmb3otjc19l1m3yB8UjK4WQ669xquX+m3m9Y43yEtO zlOtREBFUpg2oI9jg6m4QjffmVIsPeUfdvj89ZjqYo+0VpnNfbx3lY6+dkuShPhDWfuF K38Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=nAuuGfEBqUzGmffhMdinMiP0Bbawez3wjdM3P55HzJ4=; b=cgyhWX5SaxH7S85OPBqnMptqOEru638sdTr9+IJKA0joDUBzYqiWBUu0LWPmH4B4Dj QPBzJroTLSgZqmx2RBiNu/ApOsczhc8jGV3TKQ9rXV816390KxiHoKhMzOmkqafspjoO cnvhDYOhPYWSw4GZ09NCE8faEZQXgY6uqFLSv3YNBGQQyODsMBmS3yP5rVVRkTjJuiYx siCqzArrjGfsXtoDLefwR/O4qeAkqbQj8XHThXjYTKn5rQIeKsCAChCo3m5M7pQdaNsp G30nyvpYsRUVlJLVkLU6gGifecFcBfDiTLSf4jvm6ixrQX6yrhYgHrOV7+l7HQd1lcgf dOeg== X-Gm-Message-State: AOUpUlGFinTfe4lhsjRo2/ysltfHfppH8mpavsayEVtirNJtAA0X1MX/ NO9xG+Q5faovnze0sgoQ9ug= X-Received: by 2002:adf:8296:: with SMTP id 22-v6mr10689101wrc.252.1534177539595; Mon, 13 Aug 2018 09:25:39 -0700 (PDT) Received: from we.local.lc (athedsl-4536824.home.otenet.gr. [94.70.6.0]) by smtp.gmail.com with ESMTPSA id t198-v6sm17622264wmd.16.2018.08.13.09.25.38 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 13 Aug 2018 09:25:38 -0700 (PDT) From: Georgios Tsotsos To: Greg Kroah-Hartman Cc: Georgios Tsotsos , Aaro Koskinen , James Hogan , devel@driverdev.osuosl.org, linux-kernel@vger.kernel.org Subject: [PATCH] Staging: octeon-usb: Replaces CVMX_WAIT_FOR_FIELD32 macro with a function Date: Mon, 13 Aug 2018 19:25:29 +0300 Message-Id: <20180813162529.8969-1-tsotsos@gmail.com> X-Mailer: git-send-email 2.16.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Replaces CVMX_WAIT_FOR_FIELD32 macro with equivalent function. Signed-off-by: Georgios Tsotsos --- drivers/staging/octeon-usb/octeon-hcd.c | 56 +++++++++++++++++---------------- 1 file changed, 29 insertions(+), 27 deletions(-) diff --git a/drivers/staging/octeon-usb/octeon-hcd.c b/drivers/staging/octeon-usb/octeon-hcd.c index cff5e790b196..f188e19c6fc1 100644 --- a/drivers/staging/octeon-usb/octeon-hcd.c +++ b/drivers/staging/octeon-usb/octeon-hcd.c @@ -377,29 +377,6 @@ struct octeon_hcd { struct cvmx_usb_tx_fifo nonperiodic; }; -/* This macro spins on a register waiting for it to reach a condition. */ -#define CVMX_WAIT_FOR_FIELD32(address, _union, cond, timeout_usec) \ - ({int result; \ - do { \ - u64 done = cvmx_get_cycle() + (u64)timeout_usec * \ - octeon_get_clock_rate() / 1000000; \ - union _union c; \ - \ - while (1) { \ - c.u32 = cvmx_usb_read_csr32(usb, address); \ - \ - if (cond) { \ - result = 0; \ - break; \ - } else if (cvmx_get_cycle() > done) { \ - result = -1; \ - break; \ - } else \ - __delay(100); \ - } \ - } while (0); \ - result; }) - /* * This macro logically sets a single field in a CSR. It does the sequence * read, modify, and write @@ -593,6 +570,33 @@ static inline int cvmx_usb_get_data_pid(struct cvmx_usb_pipe *pipe) return 0; /* Data0 */ } +/* Loops through register until txfflsh or rxfflsh become zero.*/ +static int cvmx_wait_tx_rx(struct octeon_hcd *usb, int fflsh_type) +{ + int result; + u64 address = CVMX_USBCX_GRSTCTL(usb->index); + u64 done = cvmx_get_cycle() + 100 * + (u64)octeon_get_clock_rate / 1000000; + union cvmx_usbcx_grstctl c; + + while (1) { + c.u32 = cvmx_usb_read_csr32(usb, address); + if (fflsh_type == 0 && c.s.txfflsh == 0) { + result = 0; + break; + } else if (fflsh_type == 1 && c.s.rxfflsh == 0) { + result = 0; + break; + } else if (cvmx_get_cycle() > done) { + result = -1; + break; + } + + __delay(100); + } + return result; +} + static void cvmx_fifo_setup(struct octeon_hcd *usb) { union cvmx_usbcx_ghwcfg3 usbcx_ghwcfg3; @@ -634,12 +638,10 @@ static void cvmx_fifo_setup(struct octeon_hcd *usb) cvmx_usbcx_grstctl, txfnum, 0x10); USB_SET_FIELD32(CVMX_USBCX_GRSTCTL(usb->index), cvmx_usbcx_grstctl, txfflsh, 1); - CVMX_WAIT_FOR_FIELD32(CVMX_USBCX_GRSTCTL(usb->index), - cvmx_usbcx_grstctl, c.s.txfflsh == 0, 100); + cvmx_wait_tx_rx(usb, 0); USB_SET_FIELD32(CVMX_USBCX_GRSTCTL(usb->index), cvmx_usbcx_grstctl, rxfflsh, 1); - CVMX_WAIT_FOR_FIELD32(CVMX_USBCX_GRSTCTL(usb->index), - cvmx_usbcx_grstctl, c.s.rxfflsh == 0, 100); + cvmx_wait_tx_rx(usb, 1); } /** -- 2.16.4