From patchwork Mon Jun 12 15:37:22 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Aisheng Dong X-Patchwork-Id: 9781705 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id A491360352 for ; Mon, 12 Jun 2017 15:39:10 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 9375727F82 for ; Mon, 12 Jun 2017 15:39:10 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 882962853D; Mon, 12 Jun 2017 15:39:10 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.9 required=2.0 tests=BAD_ENC_HEADER,BAYES_00, DKIM_SIGNED,DKIM_VALID autolearn=ham version=3.3.1 Received: from bombadil.infradead.org (bombadil.infradead.org [65.50.211.133]) (using TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id C31BF27F82 for ; Mon, 12 Jun 2017 15:39:09 +0000 (UTC) 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=A0ul0Hy6zjBR4AGbvvCfHjw4GKNugRSUbqMf38nPVCs=; b=FLS2BNeRcpTl1n IM8gaU8P9x7nD9hxnLcnYTVb+kAvXGQ2kq+xWLKlvFoJKjy4cL+wW2YTWc7LCIYZRZflgT7+0RQet 0YElySDESbbWK/OT7FfbHSy8gC7SwAZ8ul1wq2Ros96nRahDmBTj8csTfY4evCthR7n9nvy1o575H MGQt+BN2v41jK7O6f7g5U6DzHAfnSNLcv6YQ3gzQ8bH4RLj0A4VhVIhOJGfn8tnJott7acuEsOBL0 vd3OUugQyfmsxbRl4UAiJgT7yI+hr01eyrkzcfoGq8zLmX4VhAsPts/SP89sK5r9Eywx37YGaNfcz E7l3TkuvXlQseIjASstg==; 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 1dKRQq-0002cy-Qc; Mon, 12 Jun 2017 15:39:08 +0000 Received: from mail-sn1nam01on0606.outbound.protection.outlook.com ([2a01:111:f400:fe40::606] helo=NAM01-SN1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.87 #1 (Red Hat Linux)) id 1dKRQl-0002WW-6z for linux-arm-kernel@lists.infradead.org; Mon, 12 Jun 2017 15:39:06 +0000 Received: from BLUPR0301CA0006.namprd03.prod.outlook.com (10.162.113.144) by BLUPR03MB166.namprd03.prod.outlook.com (10.255.212.142) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1143.10; Mon, 12 Jun 2017 15:37:25 +0000 Received: from BY2FFO11FD010.protection.gbl (2a01:111:f400:7c0c::116) by BLUPR0301CA0006.outlook.office365.com (2a01:111:e400:5259::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1157.12 via Frontend Transport; Mon, 12 Jun 2017 15:37:25 +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 BY2FFO11FD010.mail.protection.outlook.com (10.1.14.74) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1143.11 via Frontend Transport; Mon, 12 Jun 2017 15:37:25 +0000 Received: from b29396-OptiPlex-7040.ap.freescale.net (b29396-OptiPlex-7040.ap.freescale.net [10.192.242.182]) by tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id v5CFbFsA000563; Mon, 12 Jun 2017 08:37:20 -0700 From: Dong Aisheng To: Subject: [PATCH V3 1/7] tty: serial: lpuart: introduce lpuart_soc_data to represent SoC property Date: Mon, 12 Jun 2017 23:37:22 +0800 Message-ID: <1497281848-12995-2-git-send-email-aisheng.dong@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1497281848-12995-1-git-send-email-aisheng.dong@nxp.com> References: <1497281848-12995-1-git-send-email-aisheng.dong@nxp.com> X-EOPAttributedMessage: 0 X-Matching-Connectors: 131417554453839329; (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)(39850400002)(39860400002)(39840400002)(39380400002)(39450400003)(39410400002)(39400400002)(2980300002)(1110001)(1109001)(339900001)(189002)(54534003)(199003)(9170700003)(54906002)(86362001)(85426001)(2351001)(81166006)(2950100002)(4326008)(50226002)(36756003)(8676002)(356003)(47776003)(106466001)(53936002)(189998001)(39060400002)(33646002)(8656002)(305945005)(7416002)(2906002)(498600001)(50986999)(5660300001)(110136004)(8936002)(50466002)(76176999)(48376002)(6916009)(105606002)(5003940100001)(77096006)(104016004)(38730400002); DIR:OUT; SFP:1101; SCL:1; SRVR:BLUPR03MB166; H:tx30smr01.am.freescale.net; FPR:; SPF:Fail; MLV:ovrnspm; MX:1; A:1; PTR:InfoDomainNonexistent; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BY2FFO11FD010; 1:gdDKQG/noTIV2FiojZ1ghTS9Q1ZQSf2giWZR5ig7rmUKIQuyFySEpfTKYJclQzje2FOxqSFOiNWjR17NpfDpP/irKrdhCylvv7c1KPKaag8fca+qjX8xL/ckLMWeHka6KBHchT90aWqWPd3M4FM+WrsJ/WzVP4Ah6rYdZr1aqK+YU/U4FS32Xog1ymZ/5hHEwAwyUgq0fueF07IfaLkWTjH1LiEqVULGvoDigX46zkhqYQurqTab32XR+uUti0PEmZnRED0lotwakvsmwn+6Zgui4qORIUMs2IMBqmcXFNFWxADTKoTYx6U/rT2O2zUs09zebj0nqJuhYRy84r1NkU6I/puz1KthvmCMFCuilpeH7aoaAmCHHIwWuq+WHdyl2baT4tg2by9IyW8ldbXjwdc09xjkQMNqCa6g1FIvgof2xs9BQRvxsrUU9pXmCdWHmBS42lDx6TvRhVQlJHPvgNPzgD53ScY4wosNLoxIBpvaHx0jY0b0/Ak0BvNzpC9iElhTealtCSJmVvDwiMVuF01Th31tultfz1GbKUjoQTDmC8O58JDqW2ZFPAiQFGnrp/ZzfVyxlvzyO3/8TAglTdRaviDKTpjzqrPrwQxIKZREKVHAzaHJtnQf53Yi0mChwArQ6fSb8k07NGjtAoNGBfSqRbQ+m/xO2WZ0E4He3+i6yBH6PF81lk2t0zbuqNu3 MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: BLUPR03MB166: X-MS-Office365-Filtering-Correlation-Id: d3b8f808-121c-4819-5c81-08d4b1a8eced X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(201703131430075)(201703131517081); SRVR:BLUPR03MB166; X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB166; 3:ox+/TGakDKcRuFA1W6Z94gNS4zGr3pfS11ALo5rpCKndIMLHpxgKacuUsQbNDeDGitPE4B5ldF28R8ZzEw7FeSdpP5VX6tfd1sC9kYQDnmmG5Sg4K4RjOn3bVxLTofoYZAA9WAwvXs3IJEWj9MB5Q1NEoxTzSXJa2Cc6jhEF6UylzE6Z53HF/4rv2NQs8jbzl0vmxyH0ABMxAlNAzX7xVw2YxI9pAf+amcSx5g+ddg3kDrWQkCMAWQMWdrDfD8K0pMUuiPDlFv9g5Quu537irvyB16IjfdnOEOoe2vs8wUT9i1SUONZgE2tOxY6QX7L9F582/4qi4r9Tq25NGSDWY5qMhWbavKOdWb55VflXicNV8WTKCh14bzaMTjZqkt7ACUPVxthJyULPQxaIDvx7GDhhGc1hX+2ozL3A+s/r4CJlJCksVns5GqMS8tNZxeB4; 25:HSHlKLGw1i6jmS6HVbKhegJl4p4uPvef+ptqoREHESecdx7SOEgRGOoUKDvlDV6B/1/wjB8V7Ivid28GveprI/XgzYpTncizR7kWp/EnzCocUlTmmGP7LLpMf1vdAMYrsrQoZxujrtzrsY3AAlCtoVanrYqOnKKGyOt4UOz5/+ITb0Hb8Qe+YkP6dIG7Wyj99k+wjZ4sfm0xV4lwY+7zmRB0TSPdSMPP5CGeifHaWEgc6o3fzk3UMW/pxiAl6DWwWCaHVgGd4Z8lPUO+X0M9mWSoofuMzD6xjfIAC4GwL/UF35n/NQBA7hr0etYCp8Ow/AGwgz1Rp+63AMJlQYmh8OvjD5uaeyqTA+5VTS+/QYfC0ZqlZZUuP8fBLGweeaIfFcfp0R9pUN3xJmH6Dv6dxxrU3WD0wF6A2TP2DdmteFvmeHILkNpFqy4ZqYXy4W8MOQB9RL/YZjlxPdmvV1oh9cgvknVxoN9xYMJiNRGiw/I= X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB166; 31:J5kR7edl34NLXv8LzcpN/4PPyuLrD0MI8Dj2NdGTjLs4Si16m1yeKWeqHVmmqpPUs0rM/O4waW40Lr9Jo4bHQC+DryUwmPgnJSiXLPZIa0DYrrNp08QlFI/A2W1XpXaRGXB0GIBUsz/lmQegdNUCkGb5N+KU71m9DYqQxvTZemHPjs58cwF3F5CFGlKT1xjxXSEcpdNzTP/cHuzFtm7JDH983qpW4eEtts/Nk2kD4eQS6ITf3Yluyr+dYnHSrzE3VyCkiuyCPBc7e6UYqN+h/w== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(185117386973197); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6095135)(601004)(2401047)(13018025)(13016025)(8121501046)(5005006)(93006095)(93001095)(3002001)(100000703101)(100105400095)(10201501046)(6055026)(6096035)(201703131430075)(201703131441075)(201703131448075)(201703131433075)(201703161259150)(20161123559100)(20161123556025)(20161123561025)(20161123563025)(20161123565025)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:BLUPR03MB166; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(400006)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:BLUPR03MB166; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BLUPR03MB166; 4:kcKgIAOp7B5E199WLb8b7A18h14oN5hdBzpo3AKjBpR?= =?us-ascii?Q?tobVkl67uDbtMXqv6vZR15jrdN/+iF4ek3tLpoTZVhMDi4N1Q1C7O17hBkxv?= =?us-ascii?Q?yOlVxOETTX7UFjJ4QV2Mj/A7mlGGCO9cDLYR7jZhRLzxprpiF+asN55NPQWy?= =?us-ascii?Q?m6pvY5znYm20TN2Wi26ZkaddAnqpl0lLudtWIc9p2oW/XcVvamDDk9yBobVa?= =?us-ascii?Q?uvmDjoFIPkfvHue4QPTID6rsswmTIGDSlPAfGw3uBQAwAuGVXgslQ6C3wRZq?= =?us-ascii?Q?EBP/Z4ZK9BsTIpiYElxZF9EyfMxqyZuK2ZlgBcAuJVvTiv8INIUyvuR8sWo+?= =?us-ascii?Q?qB1qNbDyip8OOuocnp6czdWWHDPS4HUlUOBU1eRfuFzeN9jpnn/UkBSfieeA?= =?us-ascii?Q?qDXW4arp9qM0OE74T1y4935I9XERutpHmCjI017D3ak/DO6saxkS87KLoM1j?= =?us-ascii?Q?OKUGX2UMHK/19YJYUf92JKPZHHV4vFgq3DCFRXk9n9lLPOB4rPkbGQDBGogc?= =?us-ascii?Q?Utj/Z9S6IXr9Hj1uNUW+1AchIJqgpeVfz8HIgfYLxhArXhSjCiyxdHMGUyn1?= =?us-ascii?Q?HovcIv5kCpLGd9/cyTs83eX2DosRpQFIPKUOjxCWbS7dw5uOjtWQU1qv4TnL?= =?us-ascii?Q?386+k8cdDP3ShD8b7Rc4gy9MomDORl33nSym/TQr/2yfDOpSoMPHn2M5iroe?= =?us-ascii?Q?qDCZRRzgQAOiZDzLca6tMxVSvwQa+pWG+sTySiI+LkVvutl+tXxO/4sKd8bJ?= =?us-ascii?Q?flcXMjXSODdLy8jbp/Hjyshna2a9HCfsnsgJMijPs2G0jHC9y3gXDYJx/DVF?= =?us-ascii?Q?pjo3Xfxlayp6f4zJJl1omvoYBvuxrABqUC70U45QJSTmBuZqR3j6DX8NG0Bi?= =?us-ascii?Q?MpvAIeUaxD25FUXD+sulom2Xk4gOjsEOs4fBQ1yBPljKnN5Z/lgwwaFnA4X6?= =?us-ascii?Q?/EkA/65Qn/qqpvGYA5yN3TMBcpdeFGe5M7wYgVjWV9HI1ffLcar1x3GNRiEP?= =?us-ascii?Q?nk2RrgFe6OmxrxVldBsoQSOUm+0MIdPIeYrw4/O+YBbm+9FV+lfaa/M/YeIP?= =?us-ascii?Q?wZCJoGVS8Ar9P0mqR00xgiiruF5ieoqpCB+fAm6mKuzysiv02Gqf1Dhh/qSa?= =?us-ascii?Q?rWK2dKpAnXfW2S4IBJheBsMLxZ8fO0+3sH/7dlf9KJTepHIsCBv4l67LrIAd?= =?us-ascii?Q?qRPomyBx9KN0hJiCUgrWWnV11lIXj0/1M5jCX0Mr0C5cERMYMluyr1wiFywm?= =?us-ascii?Q?iD+0QFW4cM+Jbzgw6Z2Qn7vu1RF4KF8bbevKs?= X-Forefront-PRVS: 03361FCC43 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BLUPR03MB166; 23:nCfeOSzhAU0Wg6UBKADYsbF/7UX2xVB0ogAqe/JQWG?= =?us-ascii?Q?KLf5tjbx4W6af0dOXUSWjgAUr9pvHD4CD4ePN/6LR+seYvIgRO0IWQmlaz1m?= =?us-ascii?Q?rfF7yiBCMdsxFCIHMIQ8/LJh08fnbtzW22VxAm7QJc9iKiPtSxMcQxEZrG/L?= =?us-ascii?Q?2AofC1pylrzKxPV9cMTP7xjalVNJTwdPVl7J9NCKNZsmqqZDrAARFDcH8/1L?= =?us-ascii?Q?wwzvKEzrBbOm+oFRT0T+wRy3aBA0AZW76YvAQ/lnvNIsXRrbypPxu5IHy1Ht?= =?us-ascii?Q?mGQTNVdIxqqZTH4PynNNLXrz2rGzVJYitbOQ7nETKSM5Sqx7YbeFUi9lZHLx?= =?us-ascii?Q?Rhy+dKnYUCuzOAnU++RMuEKW/ZwR+oFzXEqeC/v2bFTSJoMSiDTbYJbdNw9/?= =?us-ascii?Q?Pi1M1eRhxtKzYyhvuQryYa7RgIPMlT3fmsHVSZ+jy/ZltOYZkIh/o7n80sgR?= =?us-ascii?Q?Z6eYZeIX16liaGoddrD3St3meFipg2Z7q5YjN0WYJYUbProdsDWZ+bLqrIdv?= =?us-ascii?Q?umiQzj/cDzwCC5fhFIPyRp/nqlnrTwARnEPWeU8bcNMrAKzAJAtZShfN7o0k?= =?us-ascii?Q?10DKki4IqfoMHGEp8u6+9DKHIwrky/oVLc48xt9FoQAeFn+BMIfTZSMetQoU?= =?us-ascii?Q?1fUAPbSjQY+ZZ7ETCyH3rZLF/6hEoMOe15mEoHI1I3btP4uPQHaw2gH3jDpy?= =?us-ascii?Q?XnXIouFCRUXLACBOK05LnxVbq5JLyjH0NfrsYy3qJXE5DjUMF/g/SDu5oWAG?= =?us-ascii?Q?MwUUa/2SYeUdktlVDgyI2LtpB//gFThAIe3i3VeCy862IzXak84vkA/1mnlJ?= =?us-ascii?Q?QzyyeA48FI8fgy/EwSbRl7w5fg6nOd1SZYo7vhV7n7IMLCQnWoXcMXCMBGGV?= =?us-ascii?Q?Ifw5DDxmZZ9kn88RApPncu8IRHaWdB424DIYysKlnZhOTtgIULMgbWAbF4Ll?= =?us-ascii?Q?msCdA0/vfldMKxF+70WCuyA1mP4KDjpcdhjo1Ky64ypMauTr+F0Ypwd4AUjW?= =?us-ascii?Q?mZA0GD9QSYJWLHs9s8llB0O3QKXaDMgwby10KuYq6ps0xm6LI8Po31hd+ARx?= =?us-ascii?Q?E++gWHqR5nIdIC19hS/zwBzC/Y8kh12UZBS+f4DlDvCf2+iSWbcR6AKZKEfK?= =?us-ascii?Q?kROxkBbWpuYD0doV90UN368GTW2K8kzQgvsAwQ6fJhcTRbejc+syQX7VM1uh?= =?us-ascii?Q?MG6kIptjyq7DPExX+RqCbH+IcU+lGmZKUXCExi5rygs7CPNCueiaq0MMiqK6?= =?us-ascii?Q?QF7afNngU+PpWYYRYD2aCg7qnX69uNOEMVrEQRP0fB8IaZnp5WWHseGeFyww?= =?us-ascii?Q?=3D=3D?= X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB166; 6:XqxL+fdnwLpgQhRgPfq7w3zrYmgPK+bz2MYHkpttsEjSkfXdCuZWEv48pKTdDV4jEckhekCXZFUwH1Q4sDNgW4mhez3PAJ/Jpp1rRDoENdT0f1IYHGuur3cVeRFbTlqhFtQ0TtX07gbcf+EfMBvLOrj8uUsc9a34wd2+b6x66oTpbMlNMEUCZOVHpXU0hql+PMpmVUqNHeaishWXjiodiNv1wfkKSf2wxaQa269c1ckelsjiCmzTMfoZ2S2u0qXoNU706T9nmxq08728TgI9T9hBvcbIFK4SIh7nE2ApAY2NtLyzmOYW1OAtRRn65abaLVKaZ46lx6uBPulKqkHAO7K1VjPI7JaZiBmB23KDGa7GJABnSnSNGehdQl9aSDEJj8qO624Dgu3MI6uWdcdNgVJi1evqHPUl6IFNTX/fSc5SG3IJZur5bZI6o4qA4BzPdnGe8ebk16PLCqwoql45Lj+rf7MtXHzR4DsNiDidClkc7al6d7bQ935HTyQ2FabjNDeEp+tMSf/F7Kr3zW8bqw== X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB166; 5:UYbDBhdpPD7WELVGsMvt5Zcm8fLPBhWCKs6S+3NYzcctXimrg6siCZir7BZyShMy9HZjEHpi/KCKtk5Xw3HF64pxRoPnyGSsB0txVKbSkUzYJQivHwm3990fVFRot9FhUJ19JyVt+qwS+kFZGu0kdto60adgzjYVCbA+EQiP6/a/dZfHJ22YPGTCONZU+M/6bSddBIXdpCdjTVIXS6xaSwMPLq/At3yJUVDOZn1JcOnSgA+KeE6M2tzf9C9RrsjMwVn+IVin7amk6JponuckZx7yDNxr9rAbtqslkRFYDzbKPIfGAgzOkRxF9x9b8Arw0uPFlUg2cluXYJMcJMh1T71R0mMOZNlNONlNBTAbx/0hJduSI4tZeThdZw3H3YRst1+18bUn/EnHlS9IhygqQUPOmzfi/JhVBYjoMv8KVgyHP+9a2wI5pO1XDHzMKwfqJVDaFa/GDaqA0Bz+0r45xoXn74WdLWvUEXqWtpketiob+kDsvKcRVLWQdsnYxKmCP7xFt/NZk7tA6h/s4n4HnA==; 24:JKZexB3mPsXS+AZXZt3oM5g2A8BWSRWcGREFC9sP+Qrhtp/WQpkw93rHAG8rFbVcElriWvsCU9NUt4ra52lbyJts6wPKvgarlfqTyK4x5kk= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; BLUPR03MB166; 7:OL2t2i3UXZ8H089eGZOeg8M94EhKdxQOZFq/J/XQHR9qWLC+04gGrXJRMi+bZFlT39KB9hzvPYs2ZLZJMFWwb7dbpoqjSG8RDalshIZfW4CVF3KoYRFrGMezuuIOEQvbr13HSh4UqIcPxcNI5hVw5V1+DRNMXbUxyccwwljUGTc3peH3V5X5Fb7coNU54jnIfvxng9+guaXvZ5aXx5g02FdE1UCequ7lUqANsLufHWyTwJuQ5OMG8oXYojX8XsQnjEGoyIyZf3JHQDFyQqhoJTJhuU4m8qLdRSV2bg8CFwoHrwxbMfQhZMFaaHKVKQ6CcZ6Tf8Iw4YQU8mYJ8Khb7w== X-MS-Exchange-CrossTenant-OriginalArrivalTime: 12 Jun 2017 15:37:25.1343 (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: BLUPR03MB166 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20170612_083903_446066_213A8F33 X-CRM114-Status: GOOD ( 15.26 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: nikita.yoush@cogentembedded.com, Dong Aisheng , fugang.duan@nxp.com, dongas86@gmail.com, gregkh@linuxfoundation.org, yangbo.lu@nxp.com, linux-kernel@vger.kernel.org, stefan@agner.ch, andy.shevchenko@gmail.com, Mingkai.Hu@nxp.com, jslaby@suse.com, linux-arm-kernel@lists.infradead.org Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org X-Virus-Scanned: ClamAV using ClamSMTP This is used to dynamically check the SoC specific lpuart properies. Currently only the iotype is added, it functions the same as before. With this, new chips with different iotype will be more easily added. Cc: Greg Kroah-Hartman Cc: Jiri Slaby Cc: Stefan Agner Cc: Mingkai Hu Cc: Yangbo Lu Cc: Fugang Duan Signed-off-by: Dong Aisheng --- ChangeLog: v2->v3: * use standard iotype flags instead of private is_32 member v1->v2: * make all soc_data const --- drivers/tty/serial/fsl_lpuart.c | 48 ++++++++++++++++++++++++----------------- 1 file changed, 28 insertions(+), 20 deletions(-) diff --git a/drivers/tty/serial/fsl_lpuart.c b/drivers/tty/serial/fsl_lpuart.c index 15df1ba7..4daabc6 100644 --- a/drivers/tty/serial/fsl_lpuart.c +++ b/drivers/tty/serial/fsl_lpuart.c @@ -236,7 +236,6 @@ struct lpuart_port { struct clk *clk; unsigned int txfifo_size; unsigned int rxfifo_size; - bool lpuart32; bool lpuart_dma_tx_use; bool lpuart_dma_rx_use; @@ -258,13 +257,22 @@ struct lpuart_port { wait_queue_head_t dma_wait; }; +struct lpuart_soc_data { + char iotype; +}; + +static const struct lpuart_soc_data vf_data = { + .iotype = UPIO_MEM, +}; + +static const struct lpuart_soc_data ls_data = { + .iotype = UPIO_MEM32BE, + +}; + static const struct of_device_id lpuart_dt_ids[] = { - { - .compatible = "fsl,vf610-lpuart", - }, - { - .compatible = "fsl,ls1021a-lpuart", - }, + { .compatible = "fsl,vf610-lpuart", .data = &vf_data, }, + { .compatible = "fsl,ls1021a-lpuart", .data = &ls_data, }, { /* sentinel */ } }; MODULE_DEVICE_TABLE(of, lpuart_dt_ids); @@ -593,7 +601,7 @@ static irqreturn_t lpuart_txint(int irq, void *dev_id) spin_lock_irqsave(&sport->port.lock, flags); if (sport->port.x_char) { - if (sport->lpuart32) + if (sport->port.iotype & UPIO_MEM32BE) lpuart32_write(sport->port.x_char, sport->port.membase + UARTDATA); else writeb(sport->port.x_char, sport->port.membase + UARTDR); @@ -601,14 +609,14 @@ static irqreturn_t lpuart_txint(int irq, void *dev_id) } if (uart_circ_empty(xmit) || uart_tx_stopped(&sport->port)) { - if (sport->lpuart32) + if (sport->port.iotype & UPIO_MEM32BE) lpuart32_stop_tx(&sport->port); else lpuart_stop_tx(&sport->port); goto out; } - if (sport->lpuart32) + if (sport->port.iotype & UPIO_MEM32BE) lpuart32_transmit_buffer(sport); else lpuart_transmit_buffer(sport); @@ -1881,12 +1889,12 @@ static int __init lpuart_console_setup(struct console *co, char *options) if (options) uart_parse_options(options, &baud, &parity, &bits, &flow); else - if (sport->lpuart32) + if (sport->port.iotype & UPIO_MEM32BE) lpuart32_console_get_options(sport, &baud, &parity, &bits); else lpuart_console_get_options(sport, &baud, &parity, &bits); - if (sport->lpuart32) + if (sport->port.iotype & UPIO_MEM32BE) lpuart32_setup_watermark(sport); else lpuart_setup_watermark(sport); @@ -1971,6 +1979,9 @@ static struct uart_driver lpuart_reg = { static int lpuart_probe(struct platform_device *pdev) { + const struct of_device_id *of_id = of_match_device(lpuart_dt_ids, + &pdev->dev); + const struct lpuart_soc_data *sdata = of_id->data; struct device_node *np = pdev->dev.of_node; struct lpuart_port *sport; struct resource *res; @@ -1988,8 +1999,6 @@ static int lpuart_probe(struct platform_device *pdev) return ret; } sport->port.line = ret; - sport->lpuart32 = of_device_is_compatible(np, "fsl,ls1021a-lpuart"); - res = platform_get_resource(pdev, IORESOURCE_MEM, 0); sport->port.membase = devm_ioremap_resource(&pdev->dev, res); if (IS_ERR(sport->port.membase)) @@ -1998,15 +2007,14 @@ static int lpuart_probe(struct platform_device *pdev) sport->port.mapbase = res->start; sport->port.dev = &pdev->dev; sport->port.type = PORT_LPUART; - sport->port.iotype = UPIO_MEM; ret = platform_get_irq(pdev, 0); if (ret < 0) { dev_err(&pdev->dev, "cannot obtain irq\n"); return ret; } sport->port.irq = ret; - - if (sport->lpuart32) + sport->port.iotype = sdata->iotype; + if (sport->port.iotype & UPIO_MEM32BE) sport->port.ops = &lpuart32_pops; else sport->port.ops = &lpuart_pops; @@ -2033,7 +2041,7 @@ static int lpuart_probe(struct platform_device *pdev) platform_set_drvdata(pdev, &sport->port); - if (sport->lpuart32) + if (sport->port.iotype & UPIO_MEM32BE) lpuart_reg.cons = LPUART32_CONSOLE; else lpuart_reg.cons = LPUART_CONSOLE; @@ -2086,7 +2094,7 @@ static int lpuart_suspend(struct device *dev) struct lpuart_port *sport = dev_get_drvdata(dev); unsigned long temp; - if (sport->lpuart32) { + if (sport->port.iotype & UPIO_MEM32BE) { /* disable Rx/Tx and interrupts */ temp = lpuart32_read(sport->port.membase + UARTCTRL); temp &= ~(UARTCTRL_TE | UARTCTRL_TIE | UARTCTRL_TCIE); @@ -2137,7 +2145,7 @@ static int lpuart_resume(struct device *dev) if (sport->port.suspended && !sport->port.irq_wake) clk_prepare_enable(sport->clk); - if (sport->lpuart32) { + if (sport->port.iotype & UPIO_MEM32BE) { lpuart32_setup_watermark(sport); temp = lpuart32_read(sport->port.membase + UARTCTRL); temp |= (UARTCTRL_RIE | UARTCTRL_TIE | UARTCTRL_RE |