From patchwork Thu Jul 6 12:08:49 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Anton Nefedov X-Patchwork-Id: 9828087 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 8EEE9602BD for ; Thu, 6 Jul 2017 12:11:17 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 7B23528645 for ; Thu, 6 Jul 2017 12:11:17 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 6F2FE28653; Thu, 6 Jul 2017 12:11:17 +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=-6.8 required=2.0 tests=BAD_ENC_HEADER,BAYES_00, DKIM_SIGNED, RCVD_IN_DNSWL_HI, T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) (using TLSv1 with cipher AES256-SHA (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 8817B2864F for ; Thu, 6 Jul 2017 12:11:15 +0000 (UTC) Received: from localhost ([::1]:51150 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dT5co-0005Kj-JH for patchwork-qemu-devel@patchwork.kernel.org; Thu, 06 Jul 2017 08:11:14 -0400 Received: from eggs.gnu.org ([2001:4830:134:3::10]:35782) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dT5bQ-0005IQ-42 for qemu-devel@nongnu.org; Thu, 06 Jul 2017 08:09:52 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1dT5bL-0004eV-Uy for qemu-devel@nongnu.org; Thu, 06 Jul 2017 08:09:48 -0400 Received: from mail-db5eur01on0099.outbound.protection.outlook.com ([104.47.2.99]:56053 helo=EUR01-DB5-obe.outbound.protection.outlook.com) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1dT5bL-0004eA-Ao for qemu-devel@nongnu.org; Thu, 06 Jul 2017 08:09:43 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=virtuozzo.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=cNtUkD4rBOUOFU9lAq9mxSoqMXowHn+3dfpVPhlwx0s=; b=TjyNDWQBtR0+GrV6lrhJ6YoYdUnLnDsL63RulK+6Ypj2s9KWqCsOBsi7aUirSTxaUXT280UCjVG8na+0gOUyxwnCpfTH6DoTV1fRXxf9MjSuCvNjWCjlzLbSJd3VfR2iqr6E18MfVyaWTxzzKIrTPb+t/gADn9r4EFtmAC57BZY= Authentication-Results: nongnu.org; dkim=none (message not signed) header.d=none; nongnu.org; dmarc=none action=none header.from=virtuozzo.com; Received: from xantnef-ws.sw.ru (195.214.232.6) by AM5PR0801MB1985.eurprd08.prod.outlook.com (2603:10a6:203:4b::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1240.13; Thu, 6 Jul 2017 12:09:34 +0000 From: Anton Nefedov To: qemu-devel@nongnu.org Date: Thu, 6 Jul 2017 15:08:49 +0300 Message-ID: <1499342940-56739-3-git-send-email-anton.nefedov@virtuozzo.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1499342940-56739-1-git-send-email-anton.nefedov@virtuozzo.com> References: <1499342940-56739-1-git-send-email-anton.nefedov@virtuozzo.com> MIME-Version: 1.0 X-Originating-IP: [195.214.232.6] X-ClientProxiedBy: HK2PR02CA0118.apcprd02.prod.outlook.com (2a01:111:e400:79aa::44) To AM5PR0801MB1985.eurprd08.prod.outlook.com (2603:10a6:203:4b::12) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 08cb672f-14dd-4eaa-7cd9-08d4c467e0af X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(300000500095)(300135000095)(300000501095)(300135300095)(22001)(300000502095)(300135100095)(300000503095)(300135400095)(201703131423075)(201703031133081)(300000504095)(300135200095)(300000505095)(300135600095)(300000506095)(300135500095); SRVR:AM5PR0801MB1985; X-Microsoft-Exchange-Diagnostics: 1; AM5PR0801MB1985; 3:+xiEtcsP3FXjeongUgPmGZKF3SxyEiivmZIOAtZFGSVx7RGZnuW5OPTgigUTssr90YejEbY/wINVJrLJFB94T8RPbC1QHqnc6AXtjmsNZHaETUTY2uAd1c2DUSon8tIZHob5QXCU3T0jQUrj8IJ3mKBCG1tBkOgynzUK9pjQgQNvPxaY1FVlubOzxOaFbTk+AeUe+Hls/ukTY/H+xhgXc4t+u2ASBr93glGo1heDLQfCZbNIrXsam/eG+iIVc+zDUL4mXV3mCqL1xKGcYl0ZNrpt+PxHpBWOZtmW1AMw6Sfd3rT/I0R9eOHvsy41pBFL6nzHFvVa7agDIAsmfMnVSjdO0NlG0hBxdzBCrXiU+7UlzLhKGO9+HV/0Knyc7OPnitYbp8GI2vQStYroOgm4TdgpyLH7NvKhhlddoPAhFYV+gsLvmCBWkut0/ndwiy5QYzWxfHA/L+9p6QUgrcCvj90T7APq+FGcO7eIoEmP27YCo4F5uvxh3OgZdxtVn+goXgxbewpVcNfBnDI4X1u8+xdlbh5LU0HCWnISE+UNrawxjhhLLbWKF5vlXBrC2do3IPNYDzePMEsR7meiB6oxpPH7wPThFs73MHBnAftoRFGzRdlYW+wrg8uE3pKSv+L90hi3uyp4mPBUSzUcn0eUZgvJifdQVUQeAkVXQK1ZjdoVWjwk9jRtBCo2SbMAXCx3Jo9t8HscjC2x72Q9caSuL0492i7p79bbT1ijpDjs/HS1wb09+SZiAYZhVYONTFZS X-MS-TrafficTypeDiagnostic: AM5PR0801MB1985: X-Microsoft-Exchange-Diagnostics: 1; AM5PR0801MB1985; 25:7AP80h/txJfDQMJZbjtF61hb1SOy9UK8syFjMql/GU6nr9N4YsX1xTN7E6i62nzRG6DcdTVRHgIsNd1SjdxmUNQosxk6pCYqBYvKRebSeTi07RCMsHtL37trE7oixseI+1LDZg4M1H1IxhbUIWVYhNLqA5lt2PV79+6pfBokXGINnf5K32KJX0G0vjpyakad9an339coEK5vDxlcAfKtAlt+c1607wfYhEglyTZ/3K1JVxFTB+T67nnYO5W4ESO/a/BgbhW/HbOMr0TkZtCExjHnphZQ/hs2SKfo3qWa7BMNviKXhTGM0gcGiAvtRMCiD+FGKbIo6/zwfbycRuBubsx/UG5Pz0Pd5+Tp6fG68Em6JQU2qUZBmlUTzF8ggt+9R0N9Xd59uzRu6eDzEQVV4FewgqXnOf64vxeDQ+ftoWnvqizgeQEMbYa5sG+0qSvopY59ZUSNmeDhSXUTbWF2Sg22jleSk4R7JLH5PiE/izO9Qt6ipteZyRvn2YBKLXCyhFTHM82vgNbwm4Xf+FCSIy7o4qXzpMxrmNGCaE0BNIqYZwfhG+cb8ZiZp8f1EpqFVL6YwfoUkXB060dEM85vrigMXAh2d4nttkU9e+1EiEBMnaRNcz1ClAuXleVYIXCyhpUImwgmY6ADYVL8rNp+u7i9z0RfzlzFYWI2GkTKzBFaqwMzV1Et2+0t+F92IJuCISdskhsvbaHru9cQAKxz4pExrMAplHlBNpPwJGwVqgnh620w+VfaSHR0VcjuHsINvpWAHDOA9iKa9lfyGanPHRRKnNvO5swPagjNuEueAPhaGI36V6NZBiVwzJg0EmF9uRhYgfWvKwEaBoUFenM4Yjpvzd9vcfzuxU00CaovydUMPZKt3umNZv39VLm1SwvlhhDxF5PK5NOIKc7X4a8qhHUuGN00NqNBDZD0O5RJt3s= X-Microsoft-Exchange-Diagnostics: 1; AM5PR0801MB1985; 31:uhhlYMobHkej4PvL28oFFj0Y/gPvIGWwfew2xeOWy2hfvhhU9Er7WO0v25XWgNMlIDdvR+lqRVwjRFv/v2dTVlq6KJOcEuqE3AeFfvxky87NxM96Sx1Yaj5H3ewDrw6uUpIcEA5JGuSMT1cp+ZJ7axha+1YV0ZwmYkmJ74s9HRJGujPI0eBJCR+CLlWXu2ggwwWcb8y+JY+p4yigOVqpY+SGKa5fG6E5GOFYr7XWo5kqCSHa1IEsrZSAAWkg40idwO31hfeFfL4DjwtLaH5STjGbsTNswJVxZfCFrK5v8+JtsvPttNm8/MykrxR68v89nIri/aqJDKRVk5cMtRFwWC4eFyp6rHoFvTOPIiSpDE0bQqyPlFLGDmaIlGrqQrp63JudqzTedEC4A0mPnnmAVRftO+IEabIT6YbSZITxGNhgaIwh9oOzcg5vlF4gqiBG2+8Vc6E9y2tJPJxIN5+xCqq4BSGTTWKH+Kust8r4sxxyEWdxkOuX71hvtZu9Sa77O3/fCEDHSgLBzpbClNbGQL5mdENL4VL0vFKFLOugepdTp50xOBdYGwgGmOBtN5XxanvUCO9nlMPjsnOuOG7hJD3XqRBNY2lg7TxThlMI5JysY+L+UfltZd0lyNK0NhERi33vT8B5/Mv1deMS7u/whrMizkE+q5caC1WW3ZrtpBk= X-Microsoft-Exchange-Diagnostics: 1; AM5PR0801MB1985; 20:IFvMIkuVR/9sZQ50AsdabeFqdtLGtU9aiDyYDvF8NZZ8c2K4QQvL0SDd46Jrp3PIx1yYJG7+4CIgoX8W8FgHH2UsNb3501ShGXBmLGzqqplTFZWqAV03eM51lAE1oMG926wyrXhpIoj+2DAaaaSQ+fY7uwAgWWDaF0KlUque/BE/Wo+j4GqA9RjmLBBHiqjbTVVJoNuoTtsN7GZlas9EFGHq0BGRgegNppG5PGJsd3vxRe8J0JZFhQaM7xFFhAXqTrFplMRH3tkt9dLMHF8RDTXYUny1rCIy0/uMWSeMDEwz3zUHdkCOD+92S86CQWhX5PW160WDvBlDW2Y/JOoF9uy57gi9vhRpufxivHGRVz0P3/Nh5X6eDKxDYoCt9FBhDKNWA3GAh3QKlHOJNoLCFB5zdkYL4dxPnDf5QMoYRqA= X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(158342451672863)(236129657087228); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(601004)(2401047)(2017060910047)(5005006)(8121501046)(100000703101)(100105400095)(93006095)(93001095)(10201501046)(3002001)(6041248)(20161123560025)(20161123555025)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123562025)(20161123564025)(20161123558100)(6072148)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:AM5PR0801MB1985; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:AM5PR0801MB1985; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; AM5PR0801MB1985; 4:EmFRacu8mF+t9y/nsRLhJyiGlO4XWKfP564gPfdJ?= =?us-ascii?Q?xbvcPjWfPDNTtqq5kZVt496rgonSl9H42OIyLg/RT5eJaOt1wh262DfkAIZd?= =?us-ascii?Q?sgwtz5/qU+j9AiVV0yOG+vkxtkVrxtM5LZSscISSB2yIWy8GmeYfjuy00QKp?= =?us-ascii?Q?94nVdxYAJehNJWTiowSracxJJSqQe3JJ5Y/e4fj7yeZQU9IuWU0nmJx3V4dh?= =?us-ascii?Q?4O5ALpius8leUYGstzo6QbqvD2qGGSDCVRXDY/Q/It7CVwuLb5s4fY9QP9R3?= =?us-ascii?Q?2JaUAnUeGmzl6FbJzIIbZmkLNB66gq71gM+kh5TcqOO9zF3LhpNq7ALHpSM+?= =?us-ascii?Q?hywlmYYh7WM0YGXBQ0X9oYAD+6KjW9Q01sTMe1oCB2CtE3soufl//cgIbZiF?= =?us-ascii?Q?mLBB27KcppUmMr70QjqtxHLJfMbqPSPRUvk1bSVi+0TVeJR9u0FT34/9iUxn?= =?us-ascii?Q?5dWXx3JCpOnKvSvDc1eB089iIRiGJjip7SJMDwWITcXOJqjt6S4MWzOA1L/N?= =?us-ascii?Q?G7G1W5IsfHEtf5JJxa1GBKuJIKjsg1gbERQJdGW/j0M9II4wDaGzHOuV9CFt?= =?us-ascii?Q?qNJifvXkn7hfKoW8f1urFjHnGiSmiuDRSpV3MWD6sSkaZ81jfnf4ZsfqXZ/R?= =?us-ascii?Q?UFE7vZPEHa/85hNHoxXpKaQmZaVO1DQJRngjBe57aUahZJTkOLqhmHLhXq6h?= =?us-ascii?Q?DI3rio9BZ9CXz0YF0/Vo9/Ah5r8YCoVM01Ynbd2sE09fCYsGT9RYpXBOYRYl?= =?us-ascii?Q?v89PvEJrb2fnvS+XhBSUi91+f034cnILZbyKAeHcfCuzmGFe7KR0cwlBsdYK?= =?us-ascii?Q?alHuJrBmrTeA493CgDCnl2RDSb1OcM1sJbViEjvVLYM07ndn5Q+J7op087CH?= =?us-ascii?Q?VE9Hpw72xOEG6w2qeoyyTvlrcWkdTLP53nAHn7TGN/tZ7XrnyJhPKWtPSszD?= =?us-ascii?Q?IsBwNuamAE/8saAM64tkvuDOa2XLzriUPjHyNBEsLXZQyQIGTaCQpKML63r7?= =?us-ascii?Q?yDsH18xZ0PrMh90wRdjiD+2ZG/HgjKwW8cAKJTqA0ihxZw/WjanegsSzCpft?= =?us-ascii?Q?OPvq53Zqe1cJRPcbWqgZ4SNTt6b9hhRvKHhQ7ot/bnX1FrGNDLvQvkhSjUgx?= =?us-ascii?Q?Qq6EIQWTLvAyaqa7IxfAMVPdwTYXAb3IWFT9sJkUicszzUsyAaO6NUNxCxmS?= =?us-ascii?Q?C3YHO7AhBBIMx4XTNM5i7KRO0I7AiR3hwF0WNU0/N39usbRoGlCGP3Mrm837?= =?us-ascii?Q?v3GjWAihBphLoLpc0D4=3D?= X-Forefront-PRVS: 03607C04F0 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10019020)(4630300001)(6009001)(39450400003)(39400400002)(39840400002)(39410400002)(2870700001)(81166006)(8676002)(36756003)(2351001)(23676002)(50226002)(575784001)(25786009)(86362001)(50466002)(305945005)(478600001)(5660300001)(189998001)(6116002)(3846002)(7736002)(4326008)(107886003)(38730400002)(5890100001)(66066001)(110136004)(47776003)(2950100002)(53936002)(6666003)(53946003)(76176999)(6506006)(6512007)(2361001)(6916009)(33646002)(50986999)(42186005)(6486002)(2906002)(53416004); DIR:OUT; SFP:1102; SCL:1; SRVR:AM5PR0801MB1985; H:xantnef-ws.sw.ru; FPR:; SPF:None; MLV:sfv; LANG:en; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; AM5PR0801MB1985; 23:tEORvK1FtbdLAinnvxVEgQhQZeUjvqxPv7P9SQX?= =?us-ascii?Q?vVQ6ZnuZjshetaHxjI0qH9xuKPiVqmotr/omdhEekDbYUUvh/phNNdlY5pr6?= =?us-ascii?Q?/zWOD9mBt/S3bkQOoqjbG4N3xQRV//Y48rlru4YMR3jlUt7PqAUAjEAz1JCN?= =?us-ascii?Q?IqHrCKxMRZ9AMPiOs+rStC9ZK5Eqm0KCVm9Z5qjIw6cUf/S4Mzs4isHDkPQ4?= =?us-ascii?Q?gUE5S81cVQcFnd3iEwrL+mLQ4fnSOx6igEMRyiq16JhaXtnDE/OUWewF5XPG?= =?us-ascii?Q?xr2epcYWol7Wh4ILHU0Xe3izwKKcKd52G+tYGadqzzxV9c9NC9Z+xUj53R6e?= =?us-ascii?Q?kHeqqgIuUu0Umu0ffd69xnF0d27mnDSU85+ZLs/eZKQeQPbUQlH7j1utqZn0?= =?us-ascii?Q?zm+NPz+U3RGpiI8UEbian5xfPXk7AU5cdsXLUxn1K0hqLW2GC9kqfoLi8Y+h?= =?us-ascii?Q?WXS3m8pZPT6emkOpnCYPGr5BSO6uQME8+i1vouJzwumhOcpEMeBEWyBT3RNg?= =?us-ascii?Q?kRp6ehxiZWFl53zYhhF7qh/HQvrYfp8uBGPtkx26sJm/F8ZJHKtbUyWlMTww?= =?us-ascii?Q?9LKX7ua2Jy5tfAWhPZm/iejtUigWqSqJGsRWaBJOjDDMHOFQzQmrd92SyuVs?= =?us-ascii?Q?5A2w1ZV1NcXKMe1ILQbxsN9aMICqZMwrPtVtHisvuVvTHXcHIvoB8WLJO/zM?= =?us-ascii?Q?y8qKUdsKL3yTcv5mzA57+xu9J1YSuJo+mYQxbFHJgZ4XTXvVBFVK1EeQ55MD?= =?us-ascii?Q?d6/klQ1FwiPDHcqMSgh2hzQ5tfiVL5T+65vArS8Wt1lV1sDs9T65zoyptY4k?= =?us-ascii?Q?RrxdMCOb/KxWFQV2r4Jf0YMbl6pSUbn3/kSbAhxzWL0bmn04rUpEuXSbNymc?= =?us-ascii?Q?lriGkL/Nlaz7a4NJA02cQxxvtE1w/2oEOxNWq59VdaMQZbgr0MDNbwzATaF1?= =?us-ascii?Q?CKEZVgD54S2+R3YrPqQNp9yceloKmomLdiUZ3cFttLmJcJbyNETLcSuDZUBq?= =?us-ascii?Q?40Oq6t0jV1gI73tucB++ukGFeeFon2hikig7Qjb22pyLxFz+Ov8SpkyrQaAK?= =?us-ascii?Q?WHUN1sGcfwYowhzJTTwoTWW8aiHu1CnXtHTo/frmspHd4RUKCQGEkXxGMKYv?= =?us-ascii?Q?LnGzgsJqq7yuvgeapmDNTetrV/FJODSFL?= X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; AM5PR0801MB1985; 6:ZbIw7ymcP6v+PQPCObp0XIvAw52nnAWTJyu+za3t?= =?us-ascii?Q?wPMyRtTz6n3xc4uZijA/i8hlBiZn9iQGI0gjdFj12xUTjDC4/RIDHhdPV8QU?= =?us-ascii?Q?nbNOK/JvDufhjW+xTOvGvDHnkt+1/VUOl1mtYcaGPuHqxOb80qmK7LHcoXp/?= =?us-ascii?Q?ceGp9kfCiAvV70+DlQ2v1CuAWMienE5WV0mqJHriBND8VhwgZq0E8KBMr1WI?= =?us-ascii?Q?ub64QBFC04009keAVqMHcSESDoZOrCfBVfVrj/ag1KZvqJ6Y/Gkzp/Dp6XHB?= =?us-ascii?Q?XlOOOaEONOyvumZDRrfNEDtP4QYMZrwIXdkZfF9JznjrjF56n58ljRZpqkjp?= =?us-ascii?Q?Sc56QLyAxmUV//88sBh4OnNy1M8GEkrhLY7MIsPUzqQ//c1Uk+QbEsM5BpwS?= =?us-ascii?Q?hwTc53oBUM+T0mQa5V7G9HoobceaVBFrFoR6sLJXUCPkGQVoKd8/zQpuDmYW?= =?us-ascii?Q?I6KLySegr3Ku5A0HEHeGEwNuJCaIZnGlo3WwBQDF/rsfrtvwLHuYY3TIcCUd?= =?us-ascii?Q?0rT0CxO/uGqAk5WRt5jPcQHGhukVGab1D7a3UA611DkzTHPRVopkD8C9/vrq?= =?us-ascii?Q?1dDhRfV4LZhYUw/9DBIT5RYsunFiw8+lLvs4P1sFbhLl1y3CxnnYkCgZwwHj?= =?us-ascii?Q?wONCfj9urkbZoLL/nBY6nU8VPdkcOCZMi83S2lBczzyY1BX8DpH8ASgysR6K?= =?us-ascii?Q?daSraB5f/yGfJ9wbgK/aNeXVAUiZeYGotJGCjx3ah6ymSbm/D+MkeYuEcYgi?= =?us-ascii?Q?URfY78o0o90sTbEBUTs7dKxg91gioaI5xK6uQKGZjftbYtdUlV0JZriRBMJL?= =?us-ascii?Q?SGs2sYfJ/vz2TLPAe5gzi8a+dd8oZpmB3ZyVlZZa/GIs2GdLwA2WpBeu+aXA?= =?us-ascii?Q?D356AUJQZvvDk2olZhM8OLoQDWo8hpLm4ulZMumtTAvpAnp2NUFS2hVK01uH?= =?us-ascii?Q?jrIi/BVyTYlFlpMykC77O5qrE2MIRTN3JXEE0Kz9UKp6tnB+iYNUR1N2FHgs?= =?us-ascii?Q?jGU=3D?= X-Microsoft-Exchange-Diagnostics: 1; AM5PR0801MB1985; 5:4gvEH0gxvHzYFF42DSCLakUGJ3X93fhYF4hvcw8DpGSa7o+dIsyr6DK+37ZJ8lRjj8Uo3Ts6uJPmAa61xKJN+fxsz7cFVG0TQA40WSHtyjqLQ+y4/cwaWji8qL6BeZMFZBkvQ/Lq0fcxlJ2xJaPI/7OibjPInKl3mmIss4nHq0ygdhAavAAv3USdhaQycitu9qa439PPTydSA5ROrZKpI2ZvpAsskuJIaYgSbL5KGKNQbEgDmdQJ8kwpZpAy6kGX+cExxxkeFlPvb3xGeAwiWw+ZRBm5Uml7+/9IdvIbuawQtYj6qnHXqU+x3EzVWm4rNbTIId/CjgueQDU82GHbq1JSPLogy4Ebx44pmHfiObPs5yu4ljxHhsejkXoZyC/3jngYTfu8eEYNt9qKZ2uiTMq0iY2cc26WUN1lDgxMXWnkM6wq7MfPe5JQ2syGwnZaxO9+v+6VQV0YUkgAFxDDMtoGWRpjAQ/EBfodffVKDhot+2P4cEa+gl5OrcNm/Q0B; 24:6+tX7qdXCbkU1AW1tsbSt0I07kNLg6BXEmhhVnNvmn1XsuU2trfHVd+2rdMmOIp82ObtLyEYsxZJQE0pzfPMHXnmx8TfUwAyqymvVwyuPfM= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; AM5PR0801MB1985; 7:dvIsLAGOlr3S4guD8J7rXQ1Uo++Zy2dKsPTwSVzRf2yLEVCJ7qN7O5LNA1u5tXnVYBn4saitqZJuPtivIR98DWMJIxR9YRL7d7wN75Gu8Lwjw9B9hFsC71qjSubd10i6np102bdAsH6o/vW2ylWf1W08u7ZfCK0FxANm01DWH7ZlNECzsCUQSLm/sGL0OQslOLZppok2ZWX1uqi0gfzT7IxdB1CFv2GhHDfg7sb2bS9ZY7K+NYZN+W+rujng3HNRu3FfwUzNjjKZSDyNIUex3+VRvk6JwbBGr7Xw2zIb8E1yMNq9yuRu+ILUCqtpDFKnPK6uM4S3uSIQVQoGR7C4UReQ2Coprc1PxRNy4r1cRAAbvD5F+lmdM1es+I150O1fIMm7lqgXYGid9ktWcv4j+D4AF7HtQPhmwB+29Rc/zE29PbqbABvP4AQSfN1xep4W7OMAAbc4ACgX1CaRY2acyGiUfyumjik4cfyuwIf+5YZaRqtu4ZecC7UblFH08aZVvPbor7U+/CXBgT+opgCW4coSdMv0Sp/UnShsGuhlsVbil4SPAk5fW+pJcJ1yc7ioXmpkrHyyGWid5DIMzdNjz79RXc/+RwUxyOS+1AcPg6Jpr1SSyoNZco8DsIYFsKBDIHeXrsVANitJKb3M0Cuoc9u8MAWx12h0jYWoUz5MOn+h+iHqMEAcuo/j9LAK1jJXu1y2l0f4NzyP6CwSx1OTKPNzz3aJ0xBmOVSyXdFqMF7d1e4iz8n6P84cAeESck8jfuNcQi3lCO58Pi2uR95Z2Djn7kY63OwqOEj/m/uweYI= X-Microsoft-Exchange-Diagnostics: 1; AM5PR0801MB1985; 20:bXGUkSYDqpZWB9B8wcsHoY9yKnUWUhgDIt0j6WTGe+j2+I3Jd57XOY7S4Umj8Ez08KFPI4bZFWIqxH1ZqwTP8lSR+5Mzni3j+08M87qP7yvwf8V6Zh9MOoEhctMgL1N4dlgO5wmywxWp1V6Ad4HMVtNbrP22CRxXvVmK9HGmMVY= X-OriginatorOrg: virtuozzo.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 06 Jul 2017 12:09:34.7604 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM5PR0801MB1985 X-detected-operating-system: by eggs.gnu.org: Windows 7 or 8 [fuzzy] X-Received-From: 104.47.2.99 Subject: [Qemu-devel] [PATCH v6 02/13] char: add backend hotswap handler X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Anton Nefedov , den@virtuozzo.com, amit@kernel.org, mst@redhat.com, marcandre.lureau@redhat.com, pbonzini@redhat.com Errors-To: qemu-devel-bounces+patchwork-qemu-devel=patchwork.kernel.org@nongnu.org Sender: "Qemu-devel" X-Virus-Scanned: ClamAV using ClamSMTP Frontends should have an interface to setup the handler of a backend change. The interface will be used in the next commits Signed-off-by: Anton Nefedov Reviewed-by: Vladimir Sementsov-Ogievskiy Reviewed-by: Marc-André Lureau --- include/chardev/char-fe.h | 5 +++++ backends/rng-egd.c | 2 +- chardev/char-fe.c | 4 +++- chardev/char-mux.c | 1 + gdbstub.c | 2 +- hw/arm/pxa2xx.c | 3 ++- hw/arm/strongarm.c | 2 +- hw/char/bcm2835_aux.c | 2 +- hw/char/cadence_uart.c | 2 +- hw/char/debugcon.c | 2 +- hw/char/digic-uart.c | 2 +- hw/char/escc.c | 2 +- hw/char/etraxfs_ser.c | 2 +- hw/char/exynos4210_uart.c | 2 +- hw/char/grlib_apbuart.c | 2 +- hw/char/imx_serial.c | 2 +- hw/char/ipoctal232.c | 2 +- hw/char/lm32_juart.c | 2 +- hw/char/lm32_uart.c | 2 +- hw/char/mcf_uart.c | 2 +- hw/char/milkymist-uart.c | 2 +- hw/char/pl011.c | 2 +- hw/char/sclpconsole-lm.c | 2 +- hw/char/sclpconsole.c | 2 +- hw/char/serial.c | 2 +- hw/char/sh_serial.c | 2 +- hw/char/spapr_vty.c | 2 +- hw/char/stm32f2xx_usart.c | 3 ++- hw/char/terminal3270.c | 2 +- hw/char/virtio-console.c | 4 ++-- hw/char/xen_console.c | 2 +- hw/char/xilinx_uartlite.c | 2 +- hw/ipmi/ipmi_bmc_extern.c | 2 +- hw/mips/boston.c | 2 +- hw/mips/mips_malta.c | 2 +- hw/misc/ivshmem.c | 2 +- hw/usb/ccid-card-passthru.c | 2 +- hw/usb/dev-serial.c | 2 +- hw/usb/redirect.c | 2 +- monitor.c | 4 ++-- net/colo-compare.c | 10 ++++++---- net/filter-mirror.c | 6 +++--- net/slirp.c | 2 +- net/vhost-user.c | 7 ++++--- qtest.c | 2 +- tests/test-char.c | 14 ++++++++++---- tests/vhost-user-test.c | 2 +- 47 files changed, 76 insertions(+), 57 deletions(-) diff --git a/include/chardev/char-fe.h b/include/chardev/char-fe.h index 2cbb262..9f38060 100644 --- a/include/chardev/char-fe.h +++ b/include/chardev/char-fe.h @@ -4,6 +4,7 @@ #include "chardev/char.h" typedef void IOEventHandler(void *opaque, int event); +typedef int BackendChangeHandler(void *opaque); /* This is the backend as seen by frontend, the actual backend is * Chardev */ @@ -12,6 +13,7 @@ struct CharBackend { IOEventHandler *chr_event; IOCanReadHandler *chr_can_read; IOReadHandler *chr_read; + BackendChangeHandler *chr_be_change; void *opaque; int tag; int fe_open; @@ -54,6 +56,8 @@ Chardev *qemu_chr_fe_get_driver(CharBackend *be); * receive * @fd_read: callback to receive data from char * @fd_event: event callback + * @be_change: backend change callback; passing NULL means hot backend change + * is not supported and will not be attempted * @opaque: an opaque pointer for the callbacks * @context: a main loop context or NULL for the default * @set_open: whether to call qemu_chr_fe_set_open() implicitely when @@ -68,6 +72,7 @@ void qemu_chr_fe_set_handlers(CharBackend *b, IOCanReadHandler *fd_can_read, IOReadHandler *fd_read, IOEventHandler *fd_event, + BackendChangeHandler *be_change, void *opaque, GMainContext *context, bool set_open); diff --git a/backends/rng-egd.c b/backends/rng-egd.c index e7ce2ca..d2b9ce6 100644 --- a/backends/rng-egd.c +++ b/backends/rng-egd.c @@ -106,7 +106,7 @@ static void rng_egd_opened(RngBackend *b, Error **errp) /* FIXME we should resubmit pending requests when the CDS reconnects. */ qemu_chr_fe_set_handlers(&s->chr, rng_egd_chr_can_read, - rng_egd_chr_read, NULL, s, NULL, true); + rng_egd_chr_read, NULL, NULL, s, NULL, true); } static void rng_egd_set_chardev(Object *obj, const char *value, Error **errp) diff --git a/chardev/char-fe.c b/chardev/char-fe.c index 3f90f05..7054863 100644 --- a/chardev/char-fe.c +++ b/chardev/char-fe.c @@ -216,7 +216,7 @@ void qemu_chr_fe_deinit(CharBackend *b, bool del) assert(b); if (b->chr) { - qemu_chr_fe_set_handlers(b, NULL, NULL, NULL, NULL, NULL, true); + qemu_chr_fe_set_handlers(b, NULL, NULL, NULL, NULL, NULL, NULL, true); if (b->chr->be == b) { b->chr->be = NULL; } @@ -235,6 +235,7 @@ void qemu_chr_fe_set_handlers(CharBackend *b, IOCanReadHandler *fd_can_read, IOReadHandler *fd_read, IOEventHandler *fd_event, + BackendChangeHandler *be_change, void *opaque, GMainContext *context, bool set_open) @@ -258,6 +259,7 @@ void qemu_chr_fe_set_handlers(CharBackend *b, b->chr_can_read = fd_can_read; b->chr_read = fd_read; b->chr_event = fd_event; + b->chr_be_change = be_change; b->opaque = opaque; if (cc->chr_update_read_handler) { cc->chr_update_read_handler(s, context); diff --git a/chardev/char-mux.c b/chardev/char-mux.c index 08570b9..4cda5e7 100644 --- a/chardev/char-mux.c +++ b/chardev/char-mux.c @@ -278,6 +278,7 @@ void mux_chr_set_handlers(Chardev *chr, GMainContext *context) mux_chr_can_read, mux_chr_read, mux_chr_event, + NULL, chr, context, true); } diff --git a/gdbstub.c b/gdbstub.c index ec4e4b2..e561244 100644 --- a/gdbstub.c +++ b/gdbstub.c @@ -2003,7 +2003,7 @@ int gdbserver_start(const char *device) if (chr) { qemu_chr_fe_init(&s->chr, chr, &error_abort); qemu_chr_fe_set_handlers(&s->chr, gdb_chr_can_receive, gdb_chr_receive, - gdb_chr_event, NULL, NULL, true); + gdb_chr_event, NULL, NULL, NULL, true); } s->state = chr ? RS_IDLE : RS_INACTIVE; s->mon_chr = mon_chr; diff --git a/hw/arm/pxa2xx.c b/hw/arm/pxa2xx.c index 629e6c6..731ed08 100644 --- a/hw/arm/pxa2xx.c +++ b/hw/arm/pxa2xx.c @@ -1970,7 +1970,8 @@ static void pxa2xx_fir_realize(DeviceState *dev, Error **errp) PXA2xxFIrState *s = PXA2XX_FIR(dev); qemu_chr_fe_set_handlers(&s->chr, pxa2xx_fir_is_empty, - pxa2xx_fir_rx, pxa2xx_fir_event, s, NULL, true); + pxa2xx_fir_rx, pxa2xx_fir_event, NULL, s, NULL, + true); } static bool pxa2xx_fir_vmstate_validate(void *opaque, int version_id) diff --git a/hw/arm/strongarm.c b/hw/arm/strongarm.c index 7683edc..1fa082c 100644 --- a/hw/arm/strongarm.c +++ b/hw/arm/strongarm.c @@ -1247,7 +1247,7 @@ static void strongarm_uart_realize(DeviceState *dev, Error **errp) strongarm_uart_can_receive, strongarm_uart_receive, strongarm_uart_event, - s, NULL, true); + NULL, s, NULL, true); } static void strongarm_uart_reset(DeviceState *dev) diff --git a/hw/char/bcm2835_aux.c b/hw/char/bcm2835_aux.c index 4d46ad6..370dc7e 100644 --- a/hw/char/bcm2835_aux.c +++ b/hw/char/bcm2835_aux.c @@ -279,7 +279,7 @@ static void bcm2835_aux_realize(DeviceState *dev, Error **errp) BCM2835AuxState *s = BCM2835_AUX(dev); qemu_chr_fe_set_handlers(&s->chr, bcm2835_aux_can_receive, - bcm2835_aux_receive, NULL, s, NULL, true); + bcm2835_aux_receive, NULL, NULL, s, NULL, true); } static Property bcm2835_aux_props[] = { diff --git a/hw/char/cadence_uart.c b/hw/char/cadence_uart.c index 4a2c124..3a9335c 100644 --- a/hw/char/cadence_uart.c +++ b/hw/char/cadence_uart.c @@ -485,7 +485,7 @@ static void cadence_uart_realize(DeviceState *dev, Error **errp) fifo_trigger_update, s); qemu_chr_fe_set_handlers(&s->chr, uart_can_receive, uart_receive, - uart_event, s, NULL, true); + uart_event, NULL, s, NULL, true); } static void cadence_uart_init(Object *obj) diff --git a/hw/char/debugcon.c b/hw/char/debugcon.c index 762e3d8..9b56fb8 100644 --- a/hw/char/debugcon.c +++ b/hw/char/debugcon.c @@ -92,7 +92,7 @@ static void debugcon_realize_core(DebugconState *s, Error **errp) return; } - qemu_chr_fe_set_handlers(&s->chr, NULL, NULL, NULL, s, NULL, true); + qemu_chr_fe_set_handlers(&s->chr, NULL, NULL, NULL, NULL, s, NULL, true); } static void debugcon_isa_realizefn(DeviceState *dev, Error **errp) diff --git a/hw/char/digic-uart.c b/hw/char/digic-uart.c index 34306e1..6ebcb87 100644 --- a/hw/char/digic-uart.c +++ b/hw/char/digic-uart.c @@ -146,7 +146,7 @@ static void digic_uart_realize(DeviceState *dev, Error **errp) DigicUartState *s = DIGIC_UART(dev); qemu_chr_fe_set_handlers(&s->chr, uart_can_rx, uart_rx, - uart_event, s, NULL, true); + uart_event, NULL, s, NULL, true); } static void digic_uart_init(Object *obj) diff --git a/hw/char/escc.c b/hw/char/escc.c index 3f78763..3546df3 100644 --- a/hw/char/escc.c +++ b/hw/char/escc.c @@ -1016,7 +1016,7 @@ static void escc_realize(DeviceState *dev, Error **errp) if (qemu_chr_fe_get_driver(&s->chn[i].chr)) { s->chn[i].clock = s->frequency / 2; qemu_chr_fe_set_handlers(&s->chn[i].chr, serial_can_receive, - serial_receive1, serial_event, + serial_receive1, serial_event, NULL, &s->chn[i], NULL, true); } } diff --git a/hw/char/etraxfs_ser.c b/hw/char/etraxfs_ser.c index c1fba9f..a184026 100644 --- a/hw/char/etraxfs_ser.c +++ b/hw/char/etraxfs_ser.c @@ -233,7 +233,7 @@ static void etraxfs_ser_realize(DeviceState *dev, Error **errp) qemu_chr_fe_set_handlers(&s->chr, serial_can_receive, serial_receive, - serial_event, s, NULL, true); + serial_event, NULL, s, NULL, true); } static void etraxfs_ser_class_init(ObjectClass *klass, void *data) diff --git a/hw/char/exynos4210_uart.c b/hw/char/exynos4210_uart.c index b51d44a..a84d2c3 100644 --- a/hw/char/exynos4210_uart.c +++ b/hw/char/exynos4210_uart.c @@ -645,7 +645,7 @@ static void exynos4210_uart_realize(DeviceState *dev, Error **errp) qemu_chr_fe_set_handlers(&s->chr, exynos4210_uart_can_receive, exynos4210_uart_receive, exynos4210_uart_event, - s, NULL, true); + NULL, s, NULL, true); } static Property exynos4210_uart_properties[] = { diff --git a/hw/char/grlib_apbuart.c b/hw/char/grlib_apbuart.c index 32d98ed..12d0c99 100644 --- a/hw/char/grlib_apbuart.c +++ b/hw/char/grlib_apbuart.c @@ -247,7 +247,7 @@ static int grlib_apbuart_init(SysBusDevice *dev) grlib_apbuart_can_receive, grlib_apbuart_receive, grlib_apbuart_event, - uart, NULL, true); + NULL, uart, NULL, true); sysbus_init_irq(dev, &uart->irq); diff --git a/hw/char/imx_serial.c b/hw/char/imx_serial.c index af25030..70405cc 100644 --- a/hw/char/imx_serial.c +++ b/hw/char/imx_serial.c @@ -315,7 +315,7 @@ static void imx_serial_realize(DeviceState *dev, Error **errp) DPRINTF("char dev for uart: %p\n", qemu_chr_fe_get_driver(&s->chr)); qemu_chr_fe_set_handlers(&s->chr, imx_can_receive, imx_receive, - imx_event, s, NULL, true); + imx_event, NULL, s, NULL, true); } static void imx_serial_init(Object *obj) diff --git a/hw/char/ipoctal232.c b/hw/char/ipoctal232.c index 337a3e56..cc8c8dc 100644 --- a/hw/char/ipoctal232.c +++ b/hw/char/ipoctal232.c @@ -545,7 +545,7 @@ static void ipoctal_realize(DeviceState *dev, Error **errp) if (qemu_chr_fe_get_driver(&ch->dev)) { qemu_chr_fe_set_handlers(&ch->dev, hostdev_can_receive, hostdev_receive, hostdev_event, - ch, NULL, true); + NULL, ch, NULL, true); DPRINTF("Redirecting channel %u to %s\n", i, ch->dev->label); } else { DPRINTF("Could not redirect channel %u, no chardev set\n", i); diff --git a/hw/char/lm32_juart.c b/hw/char/lm32_juart.c index 3948dcd..d75c835 100644 --- a/hw/char/lm32_juart.c +++ b/hw/char/lm32_juart.c @@ -119,7 +119,7 @@ static void lm32_juart_realize(DeviceState *dev, Error **errp) LM32JuartState *s = LM32_JUART(dev); qemu_chr_fe_set_handlers(&s->chr, juart_can_rx, juart_rx, - juart_event, s, NULL, true); + juart_event, NULL, s, NULL, true); } static const VMStateDescription vmstate_lm32_juart = { diff --git a/hw/char/lm32_uart.c b/hw/char/lm32_uart.c index cff8c38..c4a3b9b 100644 --- a/hw/char/lm32_uart.c +++ b/hw/char/lm32_uart.c @@ -266,7 +266,7 @@ static void lm32_uart_realize(DeviceState *dev, Error **errp) LM32UartState *s = LM32_UART(dev); qemu_chr_fe_set_handlers(&s->chr, uart_can_rx, uart_rx, - uart_event, s, NULL, true); + uart_event, NULL, s, NULL, true); } static const VMStateDescription vmstate_lm32_uart = { diff --git a/hw/char/mcf_uart.c b/hw/char/mcf_uart.c index fe12ad5..56fa402 100644 --- a/hw/char/mcf_uart.c +++ b/hw/char/mcf_uart.c @@ -305,7 +305,7 @@ static void mcf_uart_realize(DeviceState *dev, Error **errp) mcf_uart_state *s = MCF_UART(dev); qemu_chr_fe_set_handlers(&s->chr, mcf_uart_can_receive, mcf_uart_receive, - mcf_uart_event, s, NULL, true); + mcf_uart_event, NULL, s, NULL, true); } static Property mcf_uart_properties[] = { diff --git a/hw/char/milkymist-uart.c b/hw/char/milkymist-uart.c index e19d0f6..548ee27 100644 --- a/hw/char/milkymist-uart.c +++ b/hw/char/milkymist-uart.c @@ -199,7 +199,7 @@ static void milkymist_uart_realize(DeviceState *dev, Error **errp) MilkymistUartState *s = MILKYMIST_UART(dev); qemu_chr_fe_set_handlers(&s->chr, uart_can_rx, uart_rx, - uart_event, s, NULL, true); + uart_event, NULL, s, NULL, true); } static void milkymist_uart_init(Object *obj) diff --git a/hw/char/pl011.c b/hw/char/pl011.c index 33802f0..2aa277f 100644 --- a/hw/char/pl011.c +++ b/hw/char/pl011.c @@ -329,7 +329,7 @@ static void pl011_realize(DeviceState *dev, Error **errp) PL011State *s = PL011(dev); qemu_chr_fe_set_handlers(&s->chr, pl011_can_receive, pl011_receive, - pl011_event, s, NULL, true); + pl011_event, NULL, s, NULL, true); } static void pl011_class_init(ObjectClass *oc, void *data) diff --git a/hw/char/sclpconsole-lm.c b/hw/char/sclpconsole-lm.c index 1b15046..741c641 100644 --- a/hw/char/sclpconsole-lm.c +++ b/hw/char/sclpconsole-lm.c @@ -313,7 +313,7 @@ static int console_init(SCLPEvent *event) console_available = true; qemu_chr_fe_set_handlers(&scon->chr, chr_can_read, - chr_read, NULL, scon, NULL, true); + chr_read, NULL, NULL, scon, NULL, true); return 0; } diff --git a/hw/char/sclpconsole.c b/hw/char/sclpconsole.c index 4a107a2..a92baa8 100644 --- a/hw/char/sclpconsole.c +++ b/hw/char/sclpconsole.c @@ -228,7 +228,7 @@ static int console_init(SCLPEvent *event) } console_available = true; qemu_chr_fe_set_handlers(&scon->chr, chr_can_read, - chr_read, NULL, scon, NULL, true); + chr_read, NULL, NULL, scon, NULL, true); return 0; } diff --git a/hw/char/serial.c b/hw/char/serial.c index e1f1250..ab14ca4 100644 --- a/hw/char/serial.c +++ b/hw/char/serial.c @@ -897,7 +897,7 @@ void serial_realize_core(SerialState *s, Error **errp) qemu_register_reset(serial_reset, s); qemu_chr_fe_set_handlers(&s->chr, serial_can_receive1, serial_receive1, - serial_event, s, NULL, true); + serial_event, NULL, s, NULL, true); fifo8_create(&s->recv_fifo, UART_FIFO_LENGTH); fifo8_create(&s->xmit_fifo, UART_FIFO_LENGTH); serial_reset(s); diff --git a/hw/char/sh_serial.c b/hw/char/sh_serial.c index ca9816d..ad043bd 100644 --- a/hw/char/sh_serial.c +++ b/hw/char/sh_serial.c @@ -400,7 +400,7 @@ void sh_serial_init(MemoryRegion *sysmem, qemu_chr_fe_init(&s->chr, chr, &error_abort); qemu_chr_fe_set_handlers(&s->chr, sh_serial_can_receive1, sh_serial_receive1, - sh_serial_event, s, NULL, true); + sh_serial_event, NULL, s, NULL, true); } s->eri = eri_source; diff --git a/hw/char/spapr_vty.c b/hw/char/spapr_vty.c index 8f02f3a..ddd1b00 100644 --- a/hw/char/spapr_vty.c +++ b/hw/char/spapr_vty.c @@ -84,7 +84,7 @@ static void spapr_vty_realize(VIOsPAPRDevice *sdev, Error **errp) } qemu_chr_fe_set_handlers(&dev->chardev, vty_can_receive, - vty_receive, NULL, dev, NULL, true); + vty_receive, NULL, NULL, dev, NULL, true); } /* Forward declaration */ diff --git a/hw/char/stm32f2xx_usart.c b/hw/char/stm32f2xx_usart.c index 59872e6..268e435 100644 --- a/hw/char/stm32f2xx_usart.c +++ b/hw/char/stm32f2xx_usart.c @@ -207,7 +207,8 @@ static void stm32f2xx_usart_realize(DeviceState *dev, Error **errp) STM32F2XXUsartState *s = STM32F2XX_USART(dev); qemu_chr_fe_set_handlers(&s->chr, stm32f2xx_usart_can_receive, - stm32f2xx_usart_receive, NULL, s, NULL, true); + stm32f2xx_usart_receive, NULL, NULL, + s, NULL, true); } static void stm32f2xx_usart_class_init(ObjectClass *klass, void *data) diff --git a/hw/char/terminal3270.c b/hw/char/terminal3270.c index 7b10a04..5adf95b 100644 --- a/hw/char/terminal3270.c +++ b/hw/char/terminal3270.c @@ -179,7 +179,7 @@ static void terminal_init(EmulatedCcw3270Device *dev, Error **errp) } terminal_available = true; qemu_chr_fe_set_handlers(&t->chr, terminal_can_read, - terminal_read, chr_event, t, NULL, true); + terminal_read, chr_event, NULL, t, NULL, true); } static int read_payload_3270(EmulatedCcw3270Device *dev, uint32_t cda, diff --git a/hw/char/virtio-console.c b/hw/char/virtio-console.c index 0cb1668..afb4949 100644 --- a/hw/char/virtio-console.c +++ b/hw/char/virtio-console.c @@ -188,11 +188,11 @@ static void virtconsole_realize(DeviceState *dev, Error **errp) */ if (k->is_console) { qemu_chr_fe_set_handlers(&vcon->chr, chr_can_read, chr_read, - NULL, vcon, NULL, true); + NULL, NULL, vcon, NULL, true); virtio_serial_open(port); } else { qemu_chr_fe_set_handlers(&vcon->chr, chr_can_read, chr_read, - chr_event, vcon, NULL, false); + chr_event, NULL, vcon, NULL, false); } } } diff --git a/hw/char/xen_console.c b/hw/char/xen_console.c index f9af8ca..c4e8c72 100644 --- a/hw/char/xen_console.c +++ b/hw/char/xen_console.c @@ -246,7 +246,7 @@ static int con_initialise(struct XenDevice *xendev) xen_be_bind_evtchn(&con->xendev); qemu_chr_fe_set_handlers(&con->chr, xencons_can_receive, - xencons_receive, NULL, con, NULL, true); + xencons_receive, NULL, NULL, con, NULL, true); xen_pv_printf(xendev, 1, "ring mfn %d, remote port %d, local port %d, limit %zd\n", diff --git a/hw/char/xilinx_uartlite.c b/hw/char/xilinx_uartlite.c index 71ed2fc..2a8bc1e 100644 --- a/hw/char/xilinx_uartlite.c +++ b/hw/char/xilinx_uartlite.c @@ -212,7 +212,7 @@ static void xilinx_uartlite_realize(DeviceState *dev, Error **errp) XilinxUARTLite *s = XILINX_UARTLITE(dev); qemu_chr_fe_set_handlers(&s->chr, uart_can_rx, uart_rx, - uart_event, s, NULL, true); + uart_event, NULL, s, NULL, true); } static void xilinx_uartlite_init(Object *obj) diff --git a/hw/ipmi/ipmi_bmc_extern.c b/hw/ipmi/ipmi_bmc_extern.c index 329b03e..182de58 100644 --- a/hw/ipmi/ipmi_bmc_extern.c +++ b/hw/ipmi/ipmi_bmc_extern.c @@ -453,7 +453,7 @@ static void ipmi_bmc_extern_realize(DeviceState *dev, Error **errp) } qemu_chr_fe_set_handlers(&ibe->chr, can_receive, receive, - chr_event, ibe, NULL, true); + chr_event, NULL, ibe, NULL, true); } static int ipmi_bmc_extern_post_migrate(void *opaque, int version_id) diff --git a/hw/mips/boston.c b/hw/mips/boston.c index a4677f7..146be2a 100644 --- a/hw/mips/boston.c +++ b/hw/mips/boston.c @@ -533,7 +533,7 @@ static void boston_mach_init(MachineState *machine) chr = qemu_chr_new("lcd", "vc:320x240"); qemu_chr_fe_init(&s->lcd_display, chr, NULL); qemu_chr_fe_set_handlers(&s->lcd_display, NULL, NULL, - boston_lcd_event, s, NULL, true); + boston_lcd_event, NULL, s, NULL, true); ahci = pci_create_simple_multifunction(&PCI_BRIDGE(&pcie2->root)->sec_bus, PCI_DEVFN(0, 0), diff --git a/hw/mips/mips_malta.c b/hw/mips/mips_malta.c index 95cdabb..1bb6f89 100644 --- a/hw/mips/mips_malta.c +++ b/hw/mips/mips_malta.c @@ -570,7 +570,7 @@ static MaltaFPGAState *malta_fpga_init(MemoryRegion *address_space, chr = qemu_chr_new("fpga", "vc:320x200"); qemu_chr_fe_init(&s->display, chr, NULL); qemu_chr_fe_set_handlers(&s->display, NULL, NULL, - malta_fgpa_display_event, s, NULL, true); + malta_fgpa_display_event, NULL, s, NULL, true); s->uart = serial_mm_init(address_space, base + 0x900, 3, uart_irq, 230400, uart_chr, DEVICE_NATIVE_ENDIAN); diff --git a/hw/misc/ivshmem.c b/hw/misc/ivshmem.c index 2f0819d..a857e50 100644 --- a/hw/misc/ivshmem.c +++ b/hw/misc/ivshmem.c @@ -894,7 +894,7 @@ static void ivshmem_common_realize(PCIDevice *dev, Error **errp) } qemu_chr_fe_set_handlers(&s->server_chr, ivshmem_can_receive, - ivshmem_read, NULL, s, NULL, true); + ivshmem_read, NULL, NULL, s, NULL, true); if (ivshmem_setup_interrupts(s, errp) < 0) { error_prepend(errp, "Failed to initialize interrupts: "); diff --git a/hw/usb/ccid-card-passthru.c b/hw/usb/ccid-card-passthru.c index ac1725e..e9f58c9 100644 --- a/hw/usb/ccid-card-passthru.c +++ b/hw/usb/ccid-card-passthru.c @@ -348,7 +348,7 @@ static int passthru_initfn(CCIDCardState *base) qemu_chr_fe_set_handlers(&card->cs, ccid_card_vscard_can_read, ccid_card_vscard_read, - ccid_card_vscard_event, card, NULL, true); + ccid_card_vscard_event, NULL, card, NULL, true); ccid_card_vscard_send_init(card); } else { error_report("missing chardev"); diff --git a/hw/usb/dev-serial.c b/hw/usb/dev-serial.c index bfbf7cd..dc145a6 100644 --- a/hw/usb/dev-serial.c +++ b/hw/usb/dev-serial.c @@ -502,7 +502,7 @@ static void usb_serial_realize(USBDevice *dev, Error **errp) } qemu_chr_fe_set_handlers(&s->cs, usb_serial_can_read, usb_serial_read, - usb_serial_event, s, NULL, true); + usb_serial_event, NULL, s, NULL, true); usb_serial_handle_reset(dev); if (chr->be_open && !dev->attached) { diff --git a/hw/usb/redirect.c b/hw/usb/redirect.c index aa22d69..115efb9 100644 --- a/hw/usb/redirect.c +++ b/hw/usb/redirect.c @@ -1399,7 +1399,7 @@ static void usbredir_realize(USBDevice *udev, Error **errp) /* Let the backend know we are ready */ qemu_chr_fe_set_handlers(&dev->cs, usbredir_chardev_can_read, usbredir_chardev_read, usbredir_chardev_event, - dev, NULL, true); + NULL, dev, NULL, true); dev->vmstate = qemu_add_vm_change_state_handler(usbredir_vm_state_change, dev); diff --git a/monitor.c b/monitor.c index 4031876..0cdbb21 100644 --- a/monitor.c +++ b/monitor.c @@ -4108,12 +4108,12 @@ void monitor_init(Chardev *chr, int flags) if (monitor_is_qmp(mon)) { qemu_chr_fe_set_handlers(&mon->chr, monitor_can_read, monitor_qmp_read, - monitor_qmp_event, mon, NULL, true); + monitor_qmp_event, NULL, mon, NULL, true); qemu_chr_fe_set_echo(&mon->chr, true); json_message_parser_init(&mon->qmp.parser, handle_qmp_command); } else { qemu_chr_fe_set_handlers(&mon->chr, monitor_can_read, monitor_read, - monitor_event, mon, NULL, true); + monitor_event, NULL, mon, NULL, true); } qemu_mutex_lock(&monitor_lock); diff --git a/net/colo-compare.c b/net/colo-compare.c index 6d500e1..abfc23c 100644 --- a/net/colo-compare.c +++ b/net/colo-compare.c @@ -543,7 +543,7 @@ static void compare_pri_chr_in(void *opaque, const uint8_t *buf, int size) ret = net_fill_rstate(&s->pri_rs, buf, size); if (ret == -1) { - qemu_chr_fe_set_handlers(&s->chr_pri_in, NULL, NULL, NULL, + qemu_chr_fe_set_handlers(&s->chr_pri_in, NULL, NULL, NULL, NULL, NULL, NULL, true); error_report("colo-compare primary_in error"); } @@ -560,7 +560,7 @@ static void compare_sec_chr_in(void *opaque, const uint8_t *buf, int size) ret = net_fill_rstate(&s->sec_rs, buf, size); if (ret == -1) { - qemu_chr_fe_set_handlers(&s->chr_sec_in, NULL, NULL, NULL, + qemu_chr_fe_set_handlers(&s->chr_sec_in, NULL, NULL, NULL, NULL, NULL, NULL, true); error_report("colo-compare secondary_in error"); } @@ -588,9 +588,11 @@ static void *colo_compare_thread(void *opaque) s->worker_context = g_main_context_new(); qemu_chr_fe_set_handlers(&s->chr_pri_in, compare_chr_can_read, - compare_pri_chr_in, NULL, s, s->worker_context, true); + compare_pri_chr_in, NULL, NULL, + s, s->worker_context, true); qemu_chr_fe_set_handlers(&s->chr_sec_in, compare_chr_can_read, - compare_sec_chr_in, NULL, s, s->worker_context, true); + compare_sec_chr_in, NULL, NULL, + s, s->worker_context, true); s->compare_loop = g_main_loop_new(s->worker_context, FALSE); diff --git a/net/filter-mirror.c b/net/filter-mirror.c index 52d978f..62a8265 100644 --- a/net/filter-mirror.c +++ b/net/filter-mirror.c @@ -112,7 +112,7 @@ static void redirector_chr_read(void *opaque, const uint8_t *buf, int size) if (ret == -1) { qemu_chr_fe_set_handlers(&s->chr_in, NULL, NULL, NULL, - NULL, NULL, true); + NULL, NULL, NULL, true); } } @@ -124,7 +124,7 @@ static void redirector_chr_event(void *opaque, int event) switch (event) { case CHR_EVENT_CLOSED: qemu_chr_fe_set_handlers(&s->chr_in, NULL, NULL, NULL, - NULL, NULL, true); + NULL, NULL, NULL, true); break; default: break; @@ -245,7 +245,7 @@ static void filter_redirector_setup(NetFilterState *nf, Error **errp) qemu_chr_fe_set_handlers(&s->chr_in, redirector_chr_can_read, redirector_chr_read, redirector_chr_event, - nf, NULL, true); + NULL, nf, NULL, true); } if (s->outdev) { diff --git a/net/slirp.c b/net/slirp.c index 6a6d727..9fbc949 100644 --- a/net/slirp.c +++ b/net/slirp.c @@ -778,7 +778,7 @@ static int slirp_guestfwd(SlirpState *s, const char *config_str, fwd->slirp = s->slirp; qemu_chr_fe_set_handlers(&fwd->hd, guestfwd_can_read, guestfwd_read, - NULL, fwd, NULL, true); + NULL, NULL, fwd, NULL, true); } return 0; diff --git a/net/vhost-user.c b/net/vhost-user.c index a042ec6..36f32a2 100644 --- a/net/vhost-user.c +++ b/net/vhost-user.c @@ -211,7 +211,7 @@ static void chr_closed_bh(void *opaque) vhost_user_stop(queues, ncs); qemu_chr_fe_set_handlers(&s->chr, NULL, NULL, net_vhost_user_event, - opaque, NULL, true); + NULL, opaque, NULL, true); if (err) { error_report_err(err); @@ -257,7 +257,7 @@ static void net_vhost_user_event(void *opaque, int event) g_source_remove(s->watch); s->watch = 0; - qemu_chr_fe_set_handlers(&s->chr, NULL, NULL, NULL, + qemu_chr_fe_set_handlers(&s->chr, NULL, NULL, NULL, NULL, NULL, NULL, false); aio_bh_schedule_oneshot(ctx, chr_closed_bh, opaque); @@ -305,7 +305,8 @@ static int net_vhost_user_init(NetClientState *peer, const char *device, return -1; } qemu_chr_fe_set_handlers(&s->chr, NULL, NULL, - net_vhost_user_event, nc0->name, NULL, true); + net_vhost_user_event, NULL, nc0->name, NULL, + true); } while (!s->started); assert(s->vhost_net); diff --git a/qtest.c b/qtest.c index 9a5d1dc..88a09e9 100644 --- a/qtest.c +++ b/qtest.c @@ -691,7 +691,7 @@ void qtest_init(const char *qtest_chrdev, const char *qtest_log, Error **errp) qemu_chr_fe_init(&qtest_chr, chr, errp); qemu_chr_fe_set_handlers(&qtest_chr, qtest_can_read, qtest_read, - qtest_event, &qtest_chr, NULL, true); + qtest_event, NULL, &qtest_chr, NULL, true); qemu_chr_fe_set_echo(&qtest_chr, true); inbuf = g_string_new(""); diff --git a/tests/test-char.c b/tests/test-char.c index 87c724c..527b785 100644 --- a/tests/test-char.c +++ b/tests/test-char.c @@ -182,6 +182,7 @@ static void char_mux_test(void) fe_can_read, fe_read, fe_event, + NULL, &h1, NULL, true); @@ -190,6 +191,7 @@ static void char_mux_test(void) fe_can_read, fe_read, fe_event, + NULL, &h2, NULL, true); qemu_chr_fe_take_focus(&chr_be2); @@ -213,7 +215,8 @@ static void char_mux_test(void) h1.read_count = 0; /* remove first handler */ - qemu_chr_fe_set_handlers(&chr_be1, NULL, NULL, NULL, NULL, NULL, true); + qemu_chr_fe_set_handlers(&chr_be1, NULL, NULL, NULL, NULL, + NULL, NULL, true); qemu_chr_be_write(base, (void *)"hello", 6); g_assert_cmpint(h1.read_count, ==, 0); g_assert_cmpint(h2.read_count, ==, 0); @@ -311,13 +314,13 @@ static void char_socket_test(void) qemu_chr_fe_init(&be, chr, &error_abort); qemu_chr_fe_set_handlers(&be, socket_can_read, socket_read, - NULL, &d, NULL, true); + NULL, NULL, &d, NULL, true); chr_client = qemu_chr_new("client", tmp); qemu_chr_fe_init(&client_be, chr_client, &error_abort); qemu_chr_fe_set_handlers(&client_be, socket_can_read_hello, socket_read_hello, - NULL, &d, NULL, true); + NULL, NULL, &d, NULL, true); g_free(tmp); d.conn_expected = true; @@ -387,6 +390,7 @@ static void char_pipe_test(void) fe_can_read, fe_read, fe_event, + NULL, &fe, NULL, true); @@ -435,7 +439,7 @@ static void char_udp_test(void) d.chr = chr; qemu_chr_fe_init(&be, chr, &error_abort); qemu_chr_fe_set_handlers(&be, socket_can_read_hello, socket_read_hello, - NULL, &d, NULL, true); + NULL, NULL, &d, NULL, true); ret = qemu_chr_write_all(chr, (uint8_t *)"hello", 5); g_assert_cmpint(ret, ==, 5); @@ -527,6 +531,7 @@ static void char_file_test(void) fe_can_read, fe_read, fe_event, + NULL, &fe, NULL, true); g_assert_cmpint(fe.last_event, !=, CHR_EVENT_BREAK); @@ -587,6 +592,7 @@ static void char_null_test(void) fe_can_read, fe_read, fe_event, + NULL, NULL, NULL, true); ret = qemu_chr_fe_write(&be, (void *)"buf", 4); diff --git a/tests/vhost-user-test.c b/tests/vhost-user-test.c index b3cc045..d4da09f 100644 --- a/tests/vhost-user-test.c +++ b/tests/vhost-user-test.c @@ -464,7 +464,7 @@ static void test_server_create_chr(TestServer *server, const gchar *opt) qemu_chr_fe_init(&server->chr, chr, &error_abort); qemu_chr_fe_set_handlers(&server->chr, chr_can_read, chr_read, - chr_event, server, NULL, true); + chr_event, NULL, server, NULL, true); } static void test_server_listen(TestServer *server)