From patchwork Fri Mar 17 10:05:58 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Horia_Geant=C4=83?= X-Patchwork-Id: 740228 Return-Path: X-Original-To: incoming-imx@patchwork.ozlabs.org Delivered-To: patchwork-incoming-imx@bilbo.ozlabs.org Received: from bombadil.infradead.org (bombadil.infradead.org [65.50.211.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 3vl1JN3VkTz9s1h for ; Fri, 17 Mar 2017 21:08:36 +1100 (AEDT) Authentication-Results: ozlabs.org; dkim=pass (2048-bit key; unprotected) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="KvoEQvld"; dkim-atps=neutral DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-ID:Date:Subject:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=X/CaspWYf+Q/Z9mCRU63kLsFveOorQsUNCmPs1O6Npw=; b=KvoEQvldLCQamy ts+P8fzlSohNppnz3EZNn82HFhaEbFRWSNAmBSfuTsyJAjWKH8XgLrqWWyWqThBJ/J6b6vmUpyju/ xrGjhW2w/kMjcqgoERburPHD8ntsqxXyGwJcXSuXtraxXq5SPuUTuT5SU4PdRrHby2qw7nkdq2T2u Zb34WREn2IRI++Ku9pTl+n943l9kjM1RQ++rJz2mxWyNniSU5d18J3g1jKc8zZDXq7trybQz24J4g KAISmYT8T/TvBC6FUvn0xD+wuFDdH4PWlDmtLhYddZQlg9tS06lNi77/6havd67HjfOsPyXMebnGF wHWydY5YCtQ2YpneuF5g==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.87 #1 (Red Hat Linux)) id 1cooo7-0002Y7-G1; Fri, 17 Mar 2017 10:08:27 +0000 Received: from mail-sn1nam01on0063.outbound.protection.outlook.com ([104.47.32.63] helo=NAM01-SN1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.87 #1 (Red Hat Linux)) id 1coomc-0001A1-Ag for linux-arm-kernel@lists.infradead.org; Fri, 17 Mar 2017 10:07:00 +0000 Received: from BN3PR0301CA0014.namprd03.prod.outlook.com (10.160.180.152) by BLUPR03MB183.namprd03.prod.outlook.com (10.255.212.149) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id 15.1.961.17; Fri, 17 Mar 2017 10:06:36 +0000 Received: from BN1AFFO11FD022.protection.gbl (2a01:111:f400:7c10::146) by BN3PR0301CA0014.outlook.office365.com (2a01:111:e400:4000::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.977.11 via Frontend Transport; Fri, 17 Mar 2017 10:06:36 +0000 Authentication-Results: spf=fail (sender IP is 192.88.168.50) smtp.mailfrom=nxp.com; nxp.com; dkim=none (message not signed) header.d=none;nxp.com; dmarc=fail action=none header.from=nxp.com; Received-SPF: Fail (protection.outlook.com: domain of nxp.com does not designate 192.88.168.50 as permitted sender) receiver=protection.outlook.com; client-ip=192.88.168.50; helo=tx30smr01.am.freescale.net; Received: from tx30smr01.am.freescale.net (192.88.168.50) by BN1AFFO11FD022.mail.protection.outlook.com (10.58.52.82) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.977.7 via Frontend Transport; Fri, 17 Mar 2017 10:06:36 +0000 Received: from enigma.ea.freescale.net (enigma.ea.freescale.net [10.171.77.120]) by tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id v2HA6O4L014594; Fri, 17 Mar 2017 03:06:33 -0700 From: =?UTF-8?q?Horia=20Geant=C4=83?= To: Herbert Xu , Scott Wood , Roy Pledge Subject: [PATCH 3/7] soc/qman: export non-programmable FQD fields query Date: Fri, 17 Mar 2017 12:05:58 +0200 Message-ID: <20170317100602.2837-4-horia.geanta@nxp.com> X-Mailer: git-send-email 2.12.0.264.gd6db3f216544 In-Reply-To: <20170317100602.2837-1-horia.geanta@nxp.com> References: <20170317100602.2837-1-horia.geanta@nxp.com> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-Matching-Connectors: 131342187967316755; (91ab9b29-cfa4-454e-5278-08d120cd25b8); () X-Forefront-Antispam-Report: CIP:192.88.168.50; IPV:NLI; CTRY:US; EFV:NLI; SFV:NSPM; SFS:(10009020)(6009001)(336005)(39860400002)(39450400003)(39380400002)(39400400002)(39410400002)(39840400002)(39850400002)(2980300002)(1109001)(1110001)(339900001)(199003)(189002)(9170700003)(54906002)(106466001)(53936002)(81166006)(5820100001)(38730400002)(8656002)(77096006)(5660300001)(105606002)(33646002)(47776003)(23676002)(50466002)(8676002)(85426001)(104016004)(1076002)(50226002)(8936002)(4326008)(76176999)(356003)(50986999)(305945005)(2906002)(7416002)(189998001)(6636002)(36756003)(6666003)(86362001)(2870700001)(2950100002); DIR:OUT; SFP:1101; SCL:1; SRVR:BLUPR03MB183; H:tx30smr01.am.freescale.net; FPR:; SPF:Fail; MLV:ovrnspm; A:1; MX:1; PTR:InfoDomainNonexistent; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BN1AFFO11FD022; 1:0ukHCx8rqZjNxissqc8h6uHqy12Fsioyq9LJ3M+RE5pTzZ0eMWJDIhIZ2sC9VfVvqPc59qbsF1+5Kwh03gy8xI1o8PuUJercBMjVl+OHICFu6s1M0D/k+Lb70xdRIb9QkO3ipjbIKBXXjTdrLOhNz4nEN/PXZYwmhXAstHymU7O5AY+v657fK9cZr0ttrQM/PmBIqSsVg6PYxyRge0O2Vx6d13THYDStc7vPTYkxaFZN64T+GQaZ41vboUs0mNNcguh7dQb/yDz6JxLkfGv2aj5d/mMpZpX4qlu5Ep3bDGL9Qv2+oT7xU/s3RMMVwJprAg3jL19J0mWDEZo+3ApOJ7Xyx72twL5SBSV9nXrLf8qw7inssFBw6pRbhls6D8Ym/v73Kq28tw5fH/v4Hww+pD8kQnODmIbOJhijI5WQD1zN8+6WJ+2WAENhSjCzY7wPGiSFvpNLCVFgnoPeyf6JmvLkLdSMoclj6zD2LnzQyxq+fked54Zea+wd3tBElMFf+cz7ChORK5S8zgPDTVR+OUmA++UbhqMkajPgJBo+Bv/qyZFMC3VksYLjr1c0Pb1eNZfn3FhC+ZF4FMMQm5lmKLOD4xOCrAGNaTfN93A+tFJDuEWVJ3pEdnXT9P84+NSxLxNoIziDmcJb0GjsBb/UoawjApF1rjRdJwSvMG5tnE6mMyY05ZWr0yT/hQ3uPPaVRab3q2+Xw2cKNBCZ7WsSdw== X-MS-Office365-Filtering-Correlation-Id: 7fb89a22-539e-402c-8313-08d46d1d4c47 X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001); SRVR:BLUPR03MB183; X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB183; 3:Cni7+LcmYg471tWAO/dw88Btx0L15AkUmY5STkHfaXtbVcrT/QF3qOvWaHZrbSIddmsYmb7F4iEp2NM7Z2uik6gnwekoQmgD2IknzWRvX0w3ipqdJ1pWTed/VYByhm1vDDj3ahiFiwAtdJQa/1EVpMrBuUyprAt53+V00vQVH+3Fh0tVmTPjPbr08b6JgZrTiTYt/dV8PMzpEm5DBkHNq6XMvJNwdK479Bp7yZS2taF1FsNoQE41NCK9DgTctzvzVkD0x0vdNKY0Fj4HoAcnkZusWcEyN8HfaeiZ33KWlNmJ12iOiZiDgKhB1SZVqQ87IdMfL4ILW5vFdsGRbUekNVRvgVMNaMw2jbtjQctkpfNkzhvFjGBpLH9GKaG4vzTw; 25:kyt2f/eOAW2r9/Mg8yJp0xkMgNKHlYCtZfns+xvy0a6SIPaJGku/HIDbGXtduwgPxeODhYsqnXzCWd65vcMs4IIIjYHi1WzfatJPsQ4o4y1dYs3smAXlMTsa9C7vf36USKSLiXm2ig2Qd+4WFKu3bP1mO8DQa6qerjRYBgZsBiCdJ7esEUdrMv3LwhzaheGUqRSK+yTIv9Ye2zQDDUabAJfHcj1wOg582kz40N4K77IKRBZTP8+lU98wcJ8ciyANSUNpSmPEAdcgThqDt3DhQZhtTj8XomCy3H9FFkZPF420aU3DHYD56rL7URe1tvycLE/fbcjTDJFUL266JiI0n1j9hPxEBAtbhe3UvOD1kgHTP1urqf85YZlAYA2vOsVUDVnm4qUPmb4m2nbklQ3DDSy4FyKPCG/nh+6z29hiwhDnE9iYHK9ZtYCvrhN5Oa7FRVNFwUGljZAZ51A+veWIHw== X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB183; 31:AreGY4FQ/q72l9LUXeSRy+Tck61ZwFOOkzqaT17wTyhQ3jiNJZ/73VgmJ6nUXSD8N0U10+SfxGUdy5L16i7j8oQlBEd11oAuK0cuiDbHUkmvjKoK2cInbrmUEbPr1YZlTd3CH5LTC29pwoDMN9EZbeUtLSm3d3+C7l64oNoAjLs8rya/OGZwSeNYFfhDyobQmhcFBdhDmPLF4cgjgncCNkTtw5AtbwfwVp6PaLV+Qvw6+oTKkF8CSRMzJipyT+JFtF+nOHLtUtU/y9mhAInh2g== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(185117386973197)(275809806118684); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6095060)(601004)(2401047)(13015025)(5005006)(8121501046)(13017025)(13018025)(13024025)(13023025)(3002001)(10201501046)(6055026)(6096035)(20161123556025)(20161123561025)(20161123559025)(20161123565025)(20161123563025); SRVR:BLUPR03MB183; BCL:0; PCL:0; RULEID:(400006); SRVR:BLUPR03MB183; X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB183; 4:1qjfsBC8/gJNHGsJtTEIfMZ/gVlVDIms4SaK+VWz47yNmWltDRFgRc/EQlvIaQab/bSuHc4JReBUbYKJOL4+tJu+Rr7eygJHj82kkiS13Syseo9WssRykTmstSTGGaIlbAMCCtEet0Qdh/jcRs+Ku2M2i/BoNz52/A9byguBx7ZhqmzQWoSrFPg2yTI/etwi4RXTmS3EBC1GOM+Gbm9m+NQ2u8qmGL744iq5WMkTDW786YTWF8DAAszMK8s+p9v/tbb4u1ixpu5EfiWzc6I74vG5lV2h0xh+Fs9UEL++wKFC9t0QCLZkP4/HkfMz9hlzJzZK2xHIUX62I36SnWdBsVzsd6Zld5fkBMu4qujGQ7gP0r9QNMHclNYtCvpr8fiNML9P5lYWa1ZIQvF3SL+Xw9EZwVRM2C3rh4U/maaYXNjrN5BsCMnRdi7dUV7LC1oZs44nJiwILcoDIs0WUkmel5h22UGFxC/GtwJ09Od0lt+vk5ZS7FqIBAGoWwlkNnkR84Lk7HPTBSWmCd6lI+CSWssz8eX8/GMUVyc8SinmmqpewbsTGPcikgcvPpaBlInTPo/Icw7lFdI4bBTz4dpRxj/PlhJzCW0ar01FXcGJNbiKSH84O3bnXGqUWr030IzT+h9SobjHuCoOjhWzOIUfLI3fD8aMY+9CWNHhrdmu1k8X+psjmLHKHPfLZrkLbR4BMXFJrxH2u0XiOWKPlBOaU9LXksVeIKNmLXe41xnEJ25D/baBc1QOGtzy23KwDDn9QlPxm4lRRsGzjhhFIv+5eQ== X-Forefront-PRVS: 0249EFCB0B X-Microsoft-Exchange-Diagnostics: =?utf-8?B?MTtCTFVQUjAzTUIxODM7MjM6cldvN24ycEx2a3VsNTNqL2szNCtiUTd1UkhB?= =?utf-8?B?MmRCRzVTQUI2MExPZklVT3Vma3pTbEdUMlFVVlZPQnNGWGdEQ1ljVE0xc2NI?= =?utf-8?B?VS9UbUNoYzhSSGpFcDYxakVkZDdTWEVwT3BpQzVYaEZjbTJPOUwxaXVCQVJ4?= =?utf-8?B?aE0yRTNLQ2dIQ2tOR3B1YVZxTUtrd0JsRjJVVHFDRHYrOGk4cmFDNTN4K0xZ?= =?utf-8?B?WDZWVG0wQUgxVXQwdDlOZVpPVDJJVTZtbXA4TkVlbDhXdFZDVTBwOFVEQXhs?= =?utf-8?B?aUtBZlVUUXplMGdvMEhST3JmK0paRnI0RittMC8wTTQ1eXpwT1pqSG0xTUdp?= =?utf-8?B?KzRhV3A3UzRlWnh0NmE3UWZ4YTRpbmFHUkRHZEdQa1F6b2lmZFJvc0YwaS8z?= =?utf-8?B?TVRVVVB3Y1BWZ0JyZkdnakVneUUzUU9KUGlpd3hISGRQZkF5OXB2eGNKQ1Mr?= =?utf-8?B?VHY2MFBTSEthMHl2U3FMVEpBT0dGK1lMb2lCbXJSYU5VcHh6ZUNLYk5jcllD?= =?utf-8?B?a3hBSGpod0FpT3FEMjFTM05DaVVFY3B1aWVCUXFsVVYxcWhIMm5ZNk9zcytU?= =?utf-8?B?RExYWXEwMzFyTEVlUGZIczRkaXNaR09oMGoycXc3cmRsRkNXUm5URlNjQnJ1?= =?utf-8?B?T0lNYlVEWHFwU05INEtaNTMvOE5CUis3elYwQVg5RnBRRHZzcXJXOFhXK2ZX?= =?utf-8?B?Mm8wLzJPYTF3YlBRQ1lwQ205OVF3RlF0S3UxVHVHZVI0NW9GZ1hGbEFpY29W?= =?utf-8?B?S3NJZ0FYNUNYaTQvZEwwNmJQUFBvSFRtdVE0R00yT3hKbkt0eTA2elhKZnpH?= =?utf-8?B?OGZiUXFYcHVJWVJuSEdhUVU5cW9NaGszZ1dldHlyL29Lc0JsQkJNWUlWblJM?= =?utf-8?B?NVZ4MjY1Q3pPWkVlYjZHcEtXSTJVMDNTZlFISERCTzBzR3ZmaSs1OWhaOTlx?= =?utf-8?B?ZmVaSEpCZkQ5SC9QRGV3OWw2a0xBa1hkNXJXckFWVDkrbVJqZlI1UFZDOUZk?= =?utf-8?B?ZUI4TEYwWWV5VkdEaVlpOTVUTjNraDV2RTc5dmpZWHB0RkJVYWMxSmdoYmNw?= =?utf-8?B?cTEwY3Foa0JITklwWWxnSGZlYUJ1S2UrVVZUbVBlUFVRN1ZUQUlDand1c3Mw?= =?utf-8?B?Yk5OcVU0bW1vY29vU2k5Znl1NFc5b1d1TENheWx4eDVVRVNsb05hZWpqWmxR?= =?utf-8?B?cmxmcDhMT3pGeE9ITktlOHRZeTB2MEpLUitVMjJ2Y29DM0JvbmZNdTZYRm04?= =?utf-8?B?NUtZMXhtUENhU2lvYWZHNTlzTi9RTTJweXRMQkloaEJZYnFyL2VZZzhsRlhR?= =?utf-8?B?NFY0RGZma0hQcFlzSjZFK2xpdWlNdlpPNTZYR3hhejFGRHRTS0lrTWN1QW9s?= =?utf-8?B?dXlNT2V3K0ZiQitIWXkzWW4zZXBkMnNqYW5zOFU2d00zKyt4RWc0L2V4djBP?= =?utf-8?B?cVFEbXFmZDlTQ3NKdFdNMUx1RWh2aUxkU1JiK1c0SUNmc1dXSlBvTlhvc3pI?= =?utf-8?B?Z0dBaFh5WU9zNzVDUkpoY2FkbG9KZ3B6OFR1aCs1T0hhSWtJVkNCUWhaUGs3?= =?utf-8?B?Z3hjRDA4RVA3QU5nck8yeThzdzRENjZmK0l4ZUJtUVp6RlptYW84SFowdENm?= =?utf-8?B?d1lpdWJKSDRIejZGaVdJR3lPRWJmSGlRZnlnYk4vUmlDekh2ejhmSVE9PQ==?= X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB183; 6:Gk8p5mD/q51BdnvchwtfUqTzkDfHlxqh+Uiwmh9AeMAEUFZfftKXcAx+ujqHX2+OMK7GtZjvnshuXfY0jg9GkSX5vHI2ecrcxY1IaBbbrifAAmajPNORKEsKwmU7Wt7k1jezhlvpNkG1kZUTkR0u9ioA0xaS/9aMlJ9ZENNC87XYC1jumBNHKm22qGFuKJzC5BYVzX8z0yw9/evIe64X+sjXwsKnmzMbPycgdpnZAWeeIR3yM26OXpLX57+nQDlfv0990d8htDp95qihgpofswxOXbNpf8LVtH/HLU+zWeBKXGmK8Mu8Ht7knBqkO6CgyhoUUF4Brktxhvhk3RFFQi1dEkOworXDSYII+h8PAOYR7XmTr0Wv64aeJtbtRjLZdr1uOMMuJg2H5VausathvqBTvCD/5ScdbZIqmOWOMlI=; 5:Z0CL+rBFfXisuxK31kbWiqZJneNgjwzVL/jjq7v0he4dTGmW7LHIDQihUOlEEwbiNDRF5cQxNs1jcQVhZbdz/sP6q6TAhe7dj6CF8GZ3J5khc/bBSNBuKsGo/CGlKNaeUB3HFzvN8qGrFBCHuRV3lyRGQJ2FqBV65w3V4/emNYinn0Hi81OmkIJwJQvCeyml; 24:ax/pFqzgvG3vWH3jYXNd332cIY2NdYnlxrQu1XV+K96T4i9nBlUnjSVdhXEtUYy7Zc4IMeMpCqDM9i5CLBxOJhFiFeiiViYMi+Lb7m7JlCw= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB183; 7:7+JmWe0bAR3Wlss0594uySvJI7G+9HGwftH8sr33bCXgn1tnr2+keAJGAAzlBojvKzUUe+J8TpkB+1G93hSuK6WSSMQNr+WMsPIrL6rqN6QfUCJPtdgDugPCvboKF342S6VppLXSw9fNIsS/hLdu9Zjhy9btDYZXKPqOigsiLbyjNC+dD04ylsC3rXFmwz6yf99Dre5EJp0O3yK9AQI2xXDtD1tbN0R0+AI1+foMyTzhQikGFfIyM3hE2W5OWcmKoWc49ogGU1/BgjjE5YnK4fen5IYRuwsWMIo1PGCzNeTvykCikui3VmuH0mS72PHkRdsjCCaabrf31689ZmKz8g== X-MS-Exchange-CrossTenant-OriginalArrivalTime: 17 Mar 2017 10:06:36.4508 (UTC) X-MS-Exchange-CrossTenant-Id: 5afe0b00-7697-4969-b663-5eab37d5f47e X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e; Ip=[192.88.168.50]; Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BLUPR03MB183 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20170317_030654_556160_59E29351 X-CRM114-Status: GOOD ( 13.16 ) X-Spam-Score: -4.7 (----) X-Spam-Report: SpamAssassin version 3.4.1 on bombadil.infradead.org summary: Content analysis details: (-4.7 points) pts rule name description ---- ---------------------- -------------------------------------------------- -0.0 RCVD_IN_DNSWL_NONE RBL: Sender listed at http://www.dnswl.org/, no trust [104.47.32.63 listed in list.dnswl.org] -2.8 RCVD_IN_MSPIKE_H2 RBL: Average reputation (+2) [104.47.32.63 listed in wl.mailspike.net] -0.0 SPF_PASS SPF: sender matches SPF record -0.0 SPF_HELO_PASS SPF: HELO matches SPF record -1.9 BAYES_00 BODY: Bayes spam probability is 0 to 1% [score: 0.0000] X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Claudiu Manoil , Cristian Stoica , Dan Douglass , linux-arm-kernel@lists.infradead.org, Vakul Garg , "David S. Miller" , Alexandru Porosanu , linux-crypto@vger.kernel.org Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+incoming-imx=patchwork.ozlabs.org@lists.infradead.org List-Id: linux-imx-kernel.lists.patchwork.ozlabs.org Export qman_query_fq_np() function and related structures. This will be needed in the caam/qi driver, where "queue empty" condition will be decided based on the frm_cnt. Signed-off-by: Horia Geantă --- drivers/soc/fsl/qbman/qman.c | 4 +-- drivers/soc/fsl/qbman/qman_priv.h | 61 ----------------------------------- include/soc/fsl/qman.h | 68 +++++++++++++++++++++++++++++++++++++++ 3 files changed, 70 insertions(+), 63 deletions(-) diff --git a/drivers/soc/fsl/qbman/qman.c b/drivers/soc/fsl/qbman/qman.c index 6f509f68085e..3d891db57ee6 100644 --- a/drivers/soc/fsl/qbman/qman.c +++ b/drivers/soc/fsl/qbman/qman.c @@ -2019,8 +2019,7 @@ int qman_query_fq(struct qman_fq *fq, struct qm_fqd *fqd) return ret; } -static int qman_query_fq_np(struct qman_fq *fq, - struct qm_mcr_queryfq_np *np) +int qman_query_fq_np(struct qman_fq *fq, struct qm_mcr_queryfq_np *np) { union qm_mc_command *mcc; union qm_mc_result *mcr; @@ -2046,6 +2045,7 @@ static int qman_query_fq_np(struct qman_fq *fq, put_affine_portal(); return ret; } +EXPORT_SYMBOL(qman_query_fq_np); static int qman_query_cgr(struct qman_cgr *cgr, struct qm_mcr_querycgr *cgrd) diff --git a/drivers/soc/fsl/qbman/qman_priv.h b/drivers/soc/fsl/qbman/qman_priv.h index 64781eff6974..22725bdc6f15 100644 --- a/drivers/soc/fsl/qbman/qman_priv.h +++ b/drivers/soc/fsl/qbman/qman_priv.h @@ -89,67 +89,6 @@ static inline u64 qm_mcr_querycgr_a_get64(const struct qm_mcr_querycgr *q) return ((u64)q->a_bcnt_hi << 32) | be32_to_cpu(q->a_bcnt_lo); } -/* "Query FQ Non-Programmable Fields" */ - -struct qm_mcr_queryfq_np { - u8 verb; - u8 result; - u8 __reserved1; - u8 state; /* QM_MCR_NP_STATE_*** */ - u32 fqd_link; /* 24-bit, _res2[24-31] */ - u16 odp_seq; /* 14-bit, _res3[14-15] */ - u16 orp_nesn; /* 14-bit, _res4[14-15] */ - u16 orp_ea_hseq; /* 15-bit, _res5[15] */ - u16 orp_ea_tseq; /* 15-bit, _res6[15] */ - u32 orp_ea_hptr; /* 24-bit, _res7[24-31] */ - u32 orp_ea_tptr; /* 24-bit, _res8[24-31] */ - u32 pfdr_hptr; /* 24-bit, _res9[24-31] */ - u32 pfdr_tptr; /* 24-bit, _res10[24-31] */ - u8 __reserved2[5]; - u8 is; /* 1-bit, _res12[1-7] */ - u16 ics_surp; - u32 byte_cnt; - u32 frm_cnt; /* 24-bit, _res13[24-31] */ - u32 __reserved3; - u16 ra1_sfdr; /* QM_MCR_NP_RA1_*** */ - u16 ra2_sfdr; /* QM_MCR_NP_RA2_*** */ - u16 __reserved4; - u16 od1_sfdr; /* QM_MCR_NP_OD1_*** */ - u16 od2_sfdr; /* QM_MCR_NP_OD2_*** */ - u16 od3_sfdr; /* QM_MCR_NP_OD3_*** */ -} __packed; - -#define QM_MCR_NP_STATE_FE 0x10 -#define QM_MCR_NP_STATE_R 0x08 -#define QM_MCR_NP_STATE_MASK 0x07 /* Reads FQD::STATE; */ -#define QM_MCR_NP_STATE_OOS 0x00 -#define QM_MCR_NP_STATE_RETIRED 0x01 -#define QM_MCR_NP_STATE_TEN_SCHED 0x02 -#define QM_MCR_NP_STATE_TRU_SCHED 0x03 -#define QM_MCR_NP_STATE_PARKED 0x04 -#define QM_MCR_NP_STATE_ACTIVE 0x05 -#define QM_MCR_NP_PTR_MASK 0x07ff /* for RA[12] & OD[123] */ -#define QM_MCR_NP_RA1_NRA(v) (((v) >> 14) & 0x3) /* FQD::NRA */ -#define QM_MCR_NP_RA2_IT(v) (((v) >> 14) & 0x1) /* FQD::IT */ -#define QM_MCR_NP_OD1_NOD(v) (((v) >> 14) & 0x3) /* FQD::NOD */ -#define QM_MCR_NP_OD3_NPC(v) (((v) >> 14) & 0x3) /* FQD::NPC */ - -enum qm_mcr_queryfq_np_masks { - qm_mcr_fqd_link_mask = BIT(24)-1, - qm_mcr_odp_seq_mask = BIT(14)-1, - qm_mcr_orp_nesn_mask = BIT(14)-1, - qm_mcr_orp_ea_hseq_mask = BIT(15)-1, - qm_mcr_orp_ea_tseq_mask = BIT(15)-1, - qm_mcr_orp_ea_hptr_mask = BIT(24)-1, - qm_mcr_orp_ea_tptr_mask = BIT(24)-1, - qm_mcr_pfdr_hptr_mask = BIT(24)-1, - qm_mcr_pfdr_tptr_mask = BIT(24)-1, - qm_mcr_is_mask = BIT(1)-1, - qm_mcr_frm_cnt_mask = BIT(24)-1, -}; -#define qm_mcr_np_get(np, field) \ - ((np)->field & (qm_mcr_##field##_mask)) - /* Congestion Groups */ /* diff --git a/include/soc/fsl/qman.h b/include/soc/fsl/qman.h index 10b549783ec5..0252c32f7421 100644 --- a/include/soc/fsl/qman.h +++ b/include/soc/fsl/qman.h @@ -811,6 +811,67 @@ struct qman_cgr { #define QMAN_VOLATILE_FLAG_WAIT_INT 0x00000002 /* if wait, interruptible? */ #define QMAN_VOLATILE_FLAG_FINISH 0x00000004 /* wait till VDQCR completes */ +/* "Query FQ Non-Programmable Fields" */ +struct qm_mcr_queryfq_np { + u8 verb; + u8 result; + u8 __reserved1; + u8 state; /* QM_MCR_NP_STATE_*** */ + u32 fqd_link; /* 24-bit, _res2[24-31] */ + u16 odp_seq; /* 14-bit, _res3[14-15] */ + u16 orp_nesn; /* 14-bit, _res4[14-15] */ + u16 orp_ea_hseq; /* 15-bit, _res5[15] */ + u16 orp_ea_tseq; /* 15-bit, _res6[15] */ + u32 orp_ea_hptr; /* 24-bit, _res7[24-31] */ + u32 orp_ea_tptr; /* 24-bit, _res8[24-31] */ + u32 pfdr_hptr; /* 24-bit, _res9[24-31] */ + u32 pfdr_tptr; /* 24-bit, _res10[24-31] */ + u8 __reserved2[5]; + u8 is; /* 1-bit, _res12[1-7] */ + u16 ics_surp; + u32 byte_cnt; + u32 frm_cnt; /* 24-bit, _res13[24-31] */ + u32 __reserved3; + u16 ra1_sfdr; /* QM_MCR_NP_RA1_*** */ + u16 ra2_sfdr; /* QM_MCR_NP_RA2_*** */ + u16 __reserved4; + u16 od1_sfdr; /* QM_MCR_NP_OD1_*** */ + u16 od2_sfdr; /* QM_MCR_NP_OD2_*** */ + u16 od3_sfdr; /* QM_MCR_NP_OD3_*** */ +} __packed; + +#define QM_MCR_NP_STATE_FE 0x10 +#define QM_MCR_NP_STATE_R 0x08 +#define QM_MCR_NP_STATE_MASK 0x07 /* Reads FQD::STATE; */ +#define QM_MCR_NP_STATE_OOS 0x00 +#define QM_MCR_NP_STATE_RETIRED 0x01 +#define QM_MCR_NP_STATE_TEN_SCHED 0x02 +#define QM_MCR_NP_STATE_TRU_SCHED 0x03 +#define QM_MCR_NP_STATE_PARKED 0x04 +#define QM_MCR_NP_STATE_ACTIVE 0x05 +#define QM_MCR_NP_PTR_MASK 0x07ff /* for RA[12] & OD[123] */ +#define QM_MCR_NP_RA1_NRA(v) (((v) >> 14) & 0x3) /* FQD::NRA */ +#define QM_MCR_NP_RA2_IT(v) (((v) >> 14) & 0x1) /* FQD::IT */ +#define QM_MCR_NP_OD1_NOD(v) (((v) >> 14) & 0x3) /* FQD::NOD */ +#define QM_MCR_NP_OD3_NPC(v) (((v) >> 14) & 0x3) /* FQD::NPC */ + +enum qm_mcr_queryfq_np_masks { + qm_mcr_fqd_link_mask = BIT(24) - 1, + qm_mcr_odp_seq_mask = BIT(14) - 1, + qm_mcr_orp_nesn_mask = BIT(14) - 1, + qm_mcr_orp_ea_hseq_mask = BIT(15) - 1, + qm_mcr_orp_ea_tseq_mask = BIT(15) - 1, + qm_mcr_orp_ea_hptr_mask = BIT(24) - 1, + qm_mcr_orp_ea_tptr_mask = BIT(24) - 1, + qm_mcr_pfdr_hptr_mask = BIT(24) - 1, + qm_mcr_pfdr_tptr_mask = BIT(24) - 1, + qm_mcr_is_mask = BIT(1) - 1, + qm_mcr_frm_cnt_mask = BIT(24) - 1, +}; + +#define qm_mcr_np_get(np, field) \ + ((np)->field & (qm_mcr_##field##_mask)) + /* Portal Management */ /** * qman_p_irqsource_add - add processing sources to be interrupt-driven @@ -1033,6 +1094,13 @@ int qman_alloc_fqid_range(u32 *result, u32 count); */ int qman_release_fqid(u32 fqid); +/** + * qman_query_fq_np - Queries non-programmable FQD fields + * @fq: the frame queue object to be queried + * @np: storage for the queried FQD fields + */ +int qman_query_fq_np(struct qman_fq *fq, struct qm_mcr_queryfq_np *np); + /* Pool-channel management */ /** * qman_alloc_pool_range - Allocate a contiguous range of pool-channel IDs