From patchwork Fri Feb 2 19:38:01 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Alistair Francis X-Patchwork-Id: 868771 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=pass (mailfrom) smtp.mailfrom=nongnu.org (client-ip=2001:4830:134:3::11; helo=lists.gnu.org; envelope-from=qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org; receiver=) Authentication-Results: ozlabs.org; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=xilinx.onmicrosoft.com header.i=@xilinx.onmicrosoft.com header.b="xqjA92sl"; dkim-atps=neutral Received: from lists.gnu.org (lists.gnu.org [IPv6:2001:4830:134:3::11]) (using TLSv1 with cipher AES256-SHA (256/256 bits)) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 3zY6sF3xywz9sR8 for ; Sat, 3 Feb 2018 06:45:21 +1100 (AEDT) Received: from localhost ([::1]:55487 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ehhGx-0003pT-E4 for incoming@patchwork.ozlabs.org; Fri, 02 Feb 2018 14:45:19 -0500 Received: from eggs.gnu.org ([2001:4830:134:3::10]:54062) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ehhET-00023E-Fd for qemu-devel@nongnu.org; Fri, 02 Feb 2018 14:42:46 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1ehhEP-0002wS-CY for qemu-devel@nongnu.org; Fri, 02 Feb 2018 14:42:45 -0500 Received: from mail-by2nam01on0041.outbound.protection.outlook.com ([104.47.34.41]:61408 helo=NAM01-BY2-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 1ehhEO-0002ug-W5 for qemu-devel@nongnu.org; Fri, 02 Feb 2018 14:42:41 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=xilinx.onmicrosoft.com; s=selector1-xilinx-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=Pm1nWnIdF0DLF1rHkSx15wEmQ0QKk9ilC04va+1metk=; b=xqjA92slziK2RBxihMv7kB4uQUtAaGZsbzNWr3hi2MmQ1U6ILB6RWSJKwEZD1lDqKchS+nDwNMlljShb7AQe/eXNdhCLsRVFUYXtScHL9jBJJVTteV/aeEbvUJMlGiirmGHd+dGtYY9TISAY40SBRAdl7KDFQ0V2wuf9+WUN5dM= Received: from BN6PR02CA0080.namprd02.prod.outlook.com (10.161.158.21) by SN1PR02MB1342.namprd02.prod.outlook.com (10.162.0.148) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.464.11; Fri, 2 Feb 2018 19:42:38 +0000 Received: from BL2NAM02FT054.eop-nam02.prod.protection.outlook.com (2a01:111:f400:7e46::207) by BN6PR02CA0080.outlook.office365.com (2603:10b6:405:60::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.444.14 via Frontend Transport; Fri, 2 Feb 2018 19:42:37 +0000 Authentication-Results: spf=pass (sender IP is 149.199.60.83) smtp.mailfrom=xilinx.com; gmail.com; dkim=none (message not signed) header.d=none;gmail.com; dmarc=bestguesspass action=none header.from=xilinx.com; Received-SPF: Pass (protection.outlook.com: domain of xilinx.com designates 149.199.60.83 as permitted sender) receiver=protection.outlook.com; client-ip=149.199.60.83; helo=xsj-pvapsmtpgw01; Received: from xsj-pvapsmtpgw01 (149.199.60.83) by BL2NAM02FT054.mail.protection.outlook.com (10.152.77.107) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.20.444.13 via Frontend Transport; Fri, 2 Feb 2018 19:42:35 +0000 Received: from unknown-38-66.xilinx.com ([149.199.38.66] helo=xsj-pvapsmtp01) by xsj-pvapsmtpgw01 with esmtp (Exim 4.63) (envelope-from ) id 1ehhEI-0001Mn-SP; Fri, 02 Feb 2018 11:42:34 -0800 Received: from [127.0.0.1] (helo=localhost) by xsj-pvapsmtp01 with smtp (Exim 4.63) (envelope-from ) id 1ehhEI-0005rd-PU; Fri, 02 Feb 2018 11:42:34 -0800 Received: from xsj-pvapsmtp01 (mailman.xilinx.com [149.199.38.66]) by xsj-smtp-dlp1.xlnx.xilinx.com (8.13.8/8.13.1) with ESMTP id w12JgX4o015297; Fri, 2 Feb 2018 11:42:33 -0800 Received: from [172.19.2.220] (helo=xsjalistai50.xilinx.com) by xsj-pvapsmtp01 with esmtp (Exim 4.63) (envelope-from ) id 1ehhEH-0005rO-BA; Fri, 02 Feb 2018 11:42:33 -0800 From: Alistair Francis To: , Date: Fri, 2 Feb 2018 11:38:01 -0800 Message-ID: <8be93dc009d8473294b1adc26657058b8e56a550.1517600250.git.alistair.francis@xilinx.com> X-Mailer: git-send-email 2.14.1 X-RCIS-Action: ALLOW X-TM-AS-Product-Ver: IMSS-7.1.0.1224-8.2.0.1013-23620.005 X-TM-AS-User-Approved-Sender: Yes;Yes X-EOPAttributedMessage: 0 X-MS-Office365-Filtering-HT: Tenant X-Forefront-Antispam-Report: CIP:149.199.60.83; IPV:NLI; CTRY:US; EFV:NLI; SFV:NSPM; SFS:(10009020)(979002)(396003)(39380400002)(39860400002)(346002)(376002)(2980300002)(438002)(199004)(189003)(50466002)(39060400002)(336011)(59450400001)(48376002)(36386004)(9786002)(63266004)(47776003)(2906002)(81166006)(81156014)(305945005)(16586007)(36756003)(186003)(50226002)(6666003)(4326008)(110136005)(7696005)(316002)(54906003)(8936002)(51416003)(356003)(106002)(77096007)(5660300001)(106466001)(478600001)(118296001)(26005)(8676002)(107986001)(969003)(989001)(999001)(1009001)(1019001); DIR:OUT; SFP:1101; SCL:1; SRVR:SN1PR02MB1342; H:xsj-pvapsmtpgw01; FPR:; SPF:Pass; PTR:unknown-60-83.xilinx.com; A:1; MX:1; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BL2NAM02FT054; 1:z2tFVfP85O9oZBG025ivv36i31b6vp40OLjnB5dwaRM2YioxS+fb7gguuXeD4AqI2GIkzT4hgY5t0v5d2flTD3hIFZ09+CHAR4hcBj7SZnAQ0lvtP2q4otOuAFuHAz8c MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: d3911955-f3db-46ef-519b-08d56a751cda X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(7020095)(4652020)(4534165)(4627221)(201703031133081)(201702281549075)(5600026)(4604075)(4608076)(2017052603307)(7153060); SRVR:SN1PR02MB1342; X-Microsoft-Exchange-Diagnostics: 1; SN1PR02MB1342; 3:IHXjoW3qVvITldTZJnJBUXdFLKiAy0CH8p1kWV/HypziaK9U8yu/bzjwvxYe42DUZzrytSjy9sNJ7A6VDayLaO81I6/dHFAizdqG7ZFpRaZeUU8tV4GGIfE12cxtZ+uZHlpHwMFcY74vgIqo8VYq/jQRR0CXieaqzcWK7IEziwcVCb6JS4mWoh4O8xCAG1wcVHYBXt5soZ5JCFYtPXK6pIW6rPwanAdr2lSOcD2wGLB/sAr+IBa6GZ/IeYdCVbxS6jf8Oqk8xRnb3aLp9QtymRe4A8EfDrzC4D02+w1khTlDhBbW0/oLuk9ulae0ow0R0OkxI8QBPHaWZoTM0WXY9WSKfqxPWdaXdFDldd1tJMc=; 25:nnlQ8xOOI9caZvafziaG8flygi0MGniiL6Vc2445osTnjlvyHRccPJ097dYoU5B7aCzkyYFtJ+fZk4B/HyNBbM/ZRBW6WvVu+yVQ2FcOcOdKQk9Z6/XfoEZUiis/UwwFNzkZzvbWyxDX9UlmmIzp+xv91e/urpRgwtzoFg5RhqulgeygBoLNz5CWthBDl5lJva4LnzDhh+curQVyc2E9dA5ePVn6+zMjt7b+SEJFkyReTkFXybgtgV1eBbA6X3aFjmKOpcKm3IsrfSxBpz+n4S1ZKiHYh1vc6PsbLlj1H7rrlhWX5Pb2+XYVz9eS5+FHGf/1c1Th8QAynyqOjusJxg== X-MS-TrafficTypeDiagnostic: SN1PR02MB1342: X-Microsoft-Exchange-Diagnostics: 1; SN1PR02MB1342; 31:nx3Be/ys0S82PZdh/lwiAppawGV6wrNE76mQp0gzsKnV2LYK08b70XcLxMhtuMo8y3/aJeIpCe9pWeQS1WEx/UB4Ud3bZLtaj4AAWCnohNnhpTociVsp2nmMjSSxze3t2EA+GSjYaOFIRARlGT5XqKBmwj20u1arf0yt+IbVW8ThjSlz59iv/j/hc4TxLoF2/unIzsveTEtqfWemIWbVUKIGH4cVWbsFVXk0wJ9fbyA=; 20:G/PNRx5FrdfxloYsNRIv6cB3JpijEfxqlavlvZHL+PZIixbtgT5rKGrgF1+HM7IuRzYSQ5140yxTUw1VlMz4L6383tz0cyx8KUyCXdwQCqQQPni5503AsxfFO1JoEd23WqalUv+aFtILcKaK1Gq+TvnYEnNXE6yotxp6SEKtOOuo5rK4ah7kqzBILxX2Rw1xcZN6puG6LlTUvL0nL7+hY2Zt+tySDjHy0XZehHjPuf1rDgPTwOJBZYa+FTfWHnx03UQWlyliDjbXXDmTQnTbVjsbMc/yY2jww2NMxpRdf3vLpCM6/2UmL5VN+kaOLxjEG4C8XiMSX0rgNgyedmt4vMr9JN9XlWF7fFpGigy0SXeG9x7X6QoPSoS7r1L0U9vn+bui/SUDHyEZsLCcm/NfVfV8KSVeoxZfd3vLuF3fgvNEQ1SAHWE7ISoQaBCDVxJBGvNL3H/BNEhMrAUhMQzohJVPPJOoPecIcmGsLIZzm7l0aQf0cOsFJCaFyFx4as4N X-Auto-Response-Suppress: DR, RN, NRN, OOF, AutoReply X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(192813158149592); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6040501)(2401047)(8121501046)(5005006)(3231101)(2400082)(944501161)(93006095)(93004095)(3002001)(10201501046)(6055026)(6041288)(20161123562045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123564045)(20161123560045)(20161123558120)(6072148)(201708071742011); SRVR:SN1PR02MB1342; BCL:0; PCL:0; RULEID:; SRVR:SN1PR02MB1342; X-Microsoft-Exchange-Diagnostics: 1; SN1PR02MB1342; 4:v/bjrYUXLTRGnXD7q7K/10BA3NaQE8RKGee+HLYvqpGHBctAClPUJ3Avz99dVl9HTnglkY9JzsNj5boQqvMhT8InfKTqlcEUq7VVxdW37QxdFyayrbBtUDhQ/ZU4qpLMvg28RbhCdqYyNDCXQ2T+tJytC/jS31vjPpf/CniLF0Bbd1UjGk+YAQWsebV2vvOrtVEoEFDcHvb6N8J3cC6gP7CgGNC0PbH8Z7VS0EQT5rxMbDLh24SgXnHXKpn2kyb8g9mWJib/q6Ynm3HmNYAQEDEBSjy9Om3sodPLFiYodF8JE9+UFIWmnVLTcqh6APoO X-Forefront-PRVS: 05715BE7FD X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; SN1PR02MB1342; 23:RB3XsX0lZEKfvSlRTYLnvCkrthFnTWbpa8tjs32rF?= 1SZuubaV+ThDpb5o66x4Y7t02l30x8ChHjq59hwv8r5WDkQCACtZa2Mz0Hbt6gdLInS+0dcS5xUkAE0XFfxq6APHiSqhbIPy89oX/qFYZ+ckNViKtxD548Q36FqkL3CxaX2d8HMMcqgeisEv+WWYhpZU3cImTQY3sv5tlGiRQdvsjFKlNBqR8Pk0FzXjNX5382OONAfmyjfep1dExUax/QFSvsTdgCmZqCFJRmtWR5aH7zsVEvECXzC5FfPYKnEA4Ip2Wjn0VL2o0HOx5RBwwgZumeMDG1MVvrki14/Q9GrAPR48jmf1PtuaswuLXWSUCqcuKbywnbDp3d2JqbWm6/vgVOsz/PXDTojSm5gyKkHe7+tlcfb0cDdkCKwFTiMutdVUd7u8glfvqYBbYf/SeXzylfSd2J3KVmPwO4kKsARWBT8PUVZN5VpBFy5ifjLuklO+pN503mLXwP1OUIFkPnwO/Kr+h+M/IYpO0TxzVhH9vjIWDNDZdz+IyPO/47pFIqzsM+Jc7O6IxzbMIygRAZi9k+EU+di+tVIH7HjtLahXvsKJlHGO3bfm9dJf1VsK25BGFxzrVx2Oukx5BdAY/ZSJu8g0a2F5AlHdBhMSejPVjLT3/GNC+Ewgd/MRjQZN1hURXuceBsIXluLeWIym0TN92SHejPhcpTAzw9LVJ0qHda9Zas0jRytr7VUlLliBDY9u5+GGqY5zgl2qKB2UUD6denY6Q6OLrMCIAsmm5sQNo85gZCuQykozB0I2x3KNU/IN/ba3Ti8jEgQgwu+xd2GMoynRW381gaFMr0ileXAMA3g2RiJvCmoS3BwZTAOTeMFdhn0mdx++f6MN7i4/BFTKeA7vO8g5FI6wXaHYe/7FUG2PqFQ+ivDcXXtZ7O7MWM0Ef8/7rqK1p3F3DJK1d36JsK0nHfgtVcPSiAavIOLi7u09yQiEQjJb+loHcj/pDWGc9dEVc/ocOeBvaOuius9aX1sPOGoP0ppY8Te6ae3aoAdChkBhbAa/h+vMBr1QjpUYFV5GabpEMkKJMHM2O02hnLiAYQYci5GVsWNLyqWOJ7ePyJwtU+2fK6dEAM3lC0= X-Microsoft-Exchange-Diagnostics: 1; SN1PR02MB1342; 6:s8th9Da6ZBfKEOw2NzSUMiyXAzJPByUWjf/glcdkTxIAhQKod5h9y6sgzv7+FbFRF2FEwJE7+ADBP50f3yRPXTAApwud5eCwPkzHTIqeERVX4mCyVonPZt2j1Shy2uyUh060LB2UYipdfJhuDr2TAmuDKRljfnMMo6kDL1NzMblcYG62Typ8EOPn5zf39yHqy1I6S9Oz8PK+ZG9eTLW1CFR1V4buM+VuGj7tKQ5zWc2k827oEqdID5badRV6o1i3afAaC/wa9Fm7ZToERxtpVN5ljaFxP/eEZZyS3lMQP9/LhCRETLDSONTcdbqjx8kjD0ZdcW0QoyIqVqudIaiYubrW4TTv1XbT+akO1m5IxEM=; 5:XnbVLlP1G1gABf1TOMkO1QIphlIcme5/NBwEMyjksOgV0zIUFHgelCvzmk1wVsd0zw49Y4oU0byMNXHs+6KNahhRZ3NEFBUSDGPTiuY9S61GUN/gvBMJ9m0mpZPMdMgJzGoPAbJZIKbVcQW0AxJvcYrrMMcnY22D7UMdBDsFyhY=; 24:Tx3ldNsvIR+kCZmkNTYDahJA5rKoIPThFAtjbUr9LLEC57gKZPFoFjnarfaWJIQCyHLlarB/L19acaisWMNRG2NXI06gwxEfbOJSDlh25XY=; 7:vROD5+3vTYHl3NA3mN+gFnb8QBHdHWmJHJ5VRxLc/d80BFyJRYxxd4LfGVrutUtAiK1IC1wXb/dhRdot+DizJkyJ/1TsYBOexTzE/i3cyKsPoQ6bjIjxDjtTRmXAb7H1iWl3IKw27izoA45KsdR7ZdwttZEB37gZNkJXW0U3MsaTee1YUeJeWBpP7Q8PUlZ6dY+jViUFPht98bRkYMr/CgdObUENWfCShiaj+eovBYZe9BM2l2icVbnyj9ZJpj8g SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: xilinx.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 02 Feb 2018 19:42:35.8393 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: d3911955-f3db-46ef-519b-08d56a751cda X-MS-Exchange-CrossTenant-Id: 657af505-d5df-48d0-8300-c31994686c5c X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=657af505-d5df-48d0-8300-c31994686c5c; Ip=[149.199.60.83]; Helo=[xsj-pvapsmtpgw01] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN1PR02MB1342 X-detected-operating-system: by eggs.gnu.org: Windows 7 or 8 [fuzzy] X-Received-From: 104.47.34.41 Subject: [Qemu-devel] [PATCH v1 1/1] hw: register: Run post_write hook on reset 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: alistair23@gmail.com, alistair.francis@xilinx.com Errors-To: qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org Sender: "Qemu-devel" Ensure that the post write hook is called during reset. This allows us to rely on the post write functions instead of having to call them from the reset() function. Signed-off-by: Alistair Francis Reviewed-by: Philippe Mathieu-Daudé --- hw/core/register.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/hw/core/register.c b/hw/core/register.c index 900294b9c4..0741a1af32 100644 --- a/hw/core/register.c +++ b/hw/core/register.c @@ -159,13 +159,21 @@ uint64_t register_read(RegisterInfo *reg, uint64_t re, const char* prefix, void register_reset(RegisterInfo *reg) { + const RegisterAccessInfo *ac; + g_assert(reg); if (!reg->data || !reg->access) { return; } + ac = reg->access; + register_write_val(reg, reg->access->reset); + + if (ac->post_write) { + ac->post_write(reg, reg->access->reset); + } } void register_init(RegisterInfo *reg)