From patchwork Tue Nov 1 15:52:19 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Brijesh Singh X-Patchwork-Id: 689981 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org 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 3t7bPm1YWyz9t3N for ; Wed, 2 Nov 2016 02:54:04 +1100 (AEDT) Authentication-Results: ozlabs.org; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=amdcloud.onmicrosoft.com header.i=@amdcloud.onmicrosoft.com header.b=OYI8Zyf+; dkim-atps=neutral Received: from localhost ([::1]:48840 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1c1bNx-0005nu-7J for incoming@patchwork.ozlabs.org; Tue, 01 Nov 2016 11:54:01 -0400 Received: from eggs.gnu.org ([2001:4830:134:3::10]:57142) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1c1bMR-0004Xp-S8 for qemu-devel@nongnu.org; Tue, 01 Nov 2016 11:52:32 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1c1bMO-0003aD-Pz for qemu-devel@nongnu.org; Tue, 01 Nov 2016 11:52:27 -0400 Received: from mail-sn1nam02on0067.outbound.protection.outlook.com ([104.47.36.67]:58927 helo=NAM02-SN1-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 1c1bMO-0003a6-I4 for qemu-devel@nongnu.org; Tue, 01 Nov 2016 11:52:24 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector1-amd-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=Wx9yBLF+QfSbHDqyTTyk3jVo33v+Qh4Fwi8fyutJR4U=; b=OYI8Zyf+2CCMK4jy4wbYlmdK+a4qo3mVFEQ7nickQ/iL3EOVe6L2lvZZg0Ng8z1jIqKb/mlAd4Ek5zxwq4NwO3JQknHbjY1s2VEdwyFKDohqHQIwOxxJ734K7lYf7XQSYhMzqciaDDnWnQvepxM6Ih/L/Kfb6CIthLNg62L0rsA= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=brijesh.singh@amd.com; Received: from [127.0.1.1] (165.204.77.1) by CY1PR12MB0665.namprd12.prod.outlook.com (10.163.238.150) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id 15.1.693.12; Tue, 1 Nov 2016 15:52:21 +0000 From: Brijesh Singh To: , , , , , , , , , Date: Tue, 1 Nov 2016 11:52:19 -0400 Message-ID: <147801553959.18237.12050179142368380598.stgit@brijesh-build-machine> In-Reply-To: <147801550845.18237.12915616525154608660.stgit@brijesh-build-machine> References: <147801550845.18237.12915616525154608660.stgit@brijesh-build-machine> User-Agent: StGit/0.17.1-dirty MIME-Version: 1.0 X-Originating-IP: [165.204.77.1] X-ClientProxiedBy: DM5PR18CA0041.namprd18.prod.outlook.com (10.173.208.27) To CY1PR12MB0665.namprd12.prod.outlook.com (10.163.238.150) X-MS-Office365-Filtering-Correlation-Id: e5119377-2fae-4727-1107-08d4026f1156 X-Microsoft-Exchange-Diagnostics: 1; CY1PR12MB0665; 2:tTVmPalp0tfF8SqSEmz3ZAn198f1VrtMPVxOyP3xd6Jfzw2ddNntL2vBSC5bub80HkmD3HtfusyH77CKRz0t20DFEca/zgwhxuSQ/hyWSsiDtNsW3fvLc2Cwi3y3+n56retXa7fZOZe0C+R5ZtiN5FPgtSjIIoRqR2avcb8u9lKoJazqRHgBBZGPJ5H0L8bXMzne3tGl1YTKqah64r27AQ==; 3:/JchmgcB9pCRaYUsTA+cVAbS+nzaGrwAYTk7aRo73GoSCEoBHvKsrizxXygw8eaxopZ60Gj888IKbzpb/Ryu1tlXH6Lt8lvCaFBgV9zcUdLI0mkUmNMWDOV+C/n6b90xo9YHqTTb57QoPspUfLjRrw== X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:CY1PR12MB0665; X-Microsoft-Exchange-Diagnostics: 1; CY1PR12MB0665; 25:2BgY2gBPp0SWR5zxYICCK12LE7UVbu9IpIwCFQl572Wti/nWcsQzpLnl3LNAXlN/OXd+BuqPvDTEgPYbUFciDnMlHXjR2Ajmuq+DsX9PdPifwVn4aDWEnoU5PYBhbqvBsxxjG2DXhNYBYc7KnJmX1Z3dTgFFKC8L6QEuAyZB2dMT4LTpdKbR0ksyVebWus2+EIUuCQJEoJS7RBku8Msu5pof2q5ZiRTe70Eny/g9Lq+ja2J8XTqhXrdgmd1zdcKlR5QxEtTqY3+OyGNLAzfNpEiYUlnOQwDZfeGK2h0UkXLkf1UQq0Hl+Z4RylQKhmO0hKMy3vPXNjKEppZtqxLeUV9Nx3Yo4qyvEL0Ciu5nFeJMF03wsik7e/Afn9wbMhM/bdV8039qnHOVNtuGXV8v9CF5Un8zSEQl3YxuIZ7CK6grfaXTY2rGZNRqOtufg1lePgEpLEofZmBnid+z/N76bM7Fb+/cPJ0EdD345hkkJ0V27rPDkt9kuTFUrpettKuEkC2ntlBnS/mSu1uZNSc41Ozryz+ZEbPXDsnfcR0bupyv2OzjHu3+/MzY74l0wwQBlhlXEWdWl1oNWGVb5ZI5o97gy/kjZS72iBTkCdsDcgixGkGpnA/Wlc3h6JwlKfCgTvKDJ3UpggToegaoSHtYBB035kZAThK6d5q9uISEgqTMFPtak/yLtY405qwaX5slAwqq3etdQd+TEyacON8JbyPnalTxK0yWSagWbOes2Rw= X-Microsoft-Exchange-Diagnostics: 1; CY1PR12MB0665; 31:UIPMO4oU3I+hvxwvepxhm0R8P71grHL1U9RaxKxDhFIhNyb0fw+HjOnjac4W11VcYePpq7BpoK+GGyM8UeOvTcjejQ2TPEV2vq99Og1s+9GOOvYP0Emy3TT9jbtI3jEiabDxxXnZ09tui/ClpBvOFZaBrLU18PqMNI1MYfAKxtHH4wz/eGc1HQFPWv/US3C6Zrqtaq7nZWKebQ4ybIEu2qrz7RlkL6Z4ETknQSKyGP8jA1mz1fUiZMmsj99lzW8ntikZDnqYTgNmq4NtYr1B2g==; 20:vv9d+eQK/2Yz80t3AhkwXj7s7jRSiZWBbkV43/jCHCuu7xISAZc+vFm8rWqc6r3aMRjVtuXTz5HqqS8DoxLMKSsfm++2gl98iOurOiZsq9rLNZ2GwhxFPOmT720RQMdBh3bU23TgREh7WBxJSZ8NR1EG1YjECXM8yq/lMqxaKevWMaewh0wBRVtWKrjb2xwgbf4FB40Vu5fjolJfX9APCd+UmxwcLDR/2mlvrHW52sQ+h+urRrPbNuVyictLPSjLfYA3DU3ZxTivzKxPt3mn49SPlxeWoFfhp+HrcnFJedbGSR55AKvdZ5kPZdQSsfckGB6wncAObMwIn8L6UkZERkW8/3Cd2dstywdbYejRBEbzZT5KIfypjt5GCoZYFaGG2wUT6MEaH5RvLVRdJYpE+EA+XpvKaQV6+aR3Xp8WGNZlUoYnt2VNHULyvu4QNKJTnIZtuqoNI9a6rMSIYIZdfXmFxSjebzd4Hv1yR+5hvPAMB4r0g0ZuDcTtr4W9JBJr X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(767451399110); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6040176)(601004)(2401047)(8121501046)(5005006)(10201501046)(3002001)(6055026); SRVR:CY1PR12MB0665; BCL:0; PCL:0; RULEID:; SRVR:CY1PR12MB0665; X-Microsoft-Exchange-Diagnostics: 1; CY1PR12MB0665; 4:LEWdhohzeyA3sOZs2feOD7dYlEzd0Q78J8ZQcJxWCegXqVOUSVhQVYFXeru8MyCvk0jjk8PQEHmYAADN7Ta5Jm2l6bejzQa/7jv7CNBagSd0AviSZizn5Y+RrOxU/pYsiR4Zt9oDvHiACiyp39HNI5CxDdSluRES6ziq/Jq8bBjRyO+AtegzJJ2WA+uQb+UEbD4fJ6W8GsMsWd3cXE7Qjwpe85GG5USLecvrKz/X/MTPGVh/iwoAAW+DPFNdxVZHfACCgTMzYuL728M76xluH4SNSxZiOS7EjfZWEb/SdPfD6L0LbQrYIv1Wl/Df/yH3mkEubq9wKlA7NyULSPFelkcNdaLbGwm49prkeHqv7aq7KkqW9f6TalmH/bTqVptw7UHQsvguBL+D57DSOWF8aCN+I2a7r39IById92uOwNjK1fLdwIZG/p4tofw7ebG8LHIwRBsPd4EaouSeXbxPXg== X-Forefront-PRVS: 01136D2D90 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(4630300001)(6009001)(6049001)(7916002)(189002)(199003)(103116003)(81156014)(33646002)(50986999)(47776003)(76176999)(106356001)(6116002)(42186005)(189998001)(230700001)(81166006)(4326007)(3846002)(586003)(23676002)(9686002)(105586002)(54356999)(229853001)(66066001)(68736007)(101416001)(33716001)(305945005)(19580405001)(7736002)(77096005)(83506001)(2950100002)(50466002)(7846002)(5660300001)(7416002)(97736004)(92566002)(2906002)(86362001)(19580395003)(8676002)(5001770100001)(4001350100001)(2201001)(921003)(217873001)(1121003); DIR:OUT; SFP:1101; SCL:1; SRVR:CY1PR12MB0665; H:[127.0.1.1]; FPR:; SPF:None; PTR:InfoNoRecords; MX:1; A:1; LANG:en; Received-SPF: None (protection.outlook.com: amd.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?utf-8?B?MTtDWTFQUjEyTUIwNjY1OzIzOnJKQXJoWmt0SnRud2RpY3laaWg5Y0RQUjc2?= =?utf-8?B?Q25hZjJnRGp3cW4xZ2I2ejlUdk1xY1pwazUrZlptOUtMU2pJQktWZ0oxNWNY?= =?utf-8?B?Zzh5eDRoUm9BV0dUNW91RFNiQ25vb2dqYWcyQ1dMTURtMHpRZ1lMbnFiTXgx?= =?utf-8?B?STFGUzhjNkZQR3BzUytDOXNiejNqU1VzUWNveDBFalJvK2dMUmhNUWZEYkh0?= =?utf-8?B?VXBZMlY3UDdwT3dUOUl6VWJVZ2dtR1F3U2duSmd0L3JQUkVKcjh3UnJ3N08r?= =?utf-8?B?MTNDUWVFT1A3cjduc0VOcWc2NGF6ejQrVEwycy9aOHBYc3pIUlhWYzczZlpR?= =?utf-8?B?SFpOd1hISnlsclJIMjFjTngzVUIrbXF4WnJWZ0VFVnZOQm41L01FSjlIM1cx?= =?utf-8?B?TWQ3YzU0ajJjMSthMW9hcTU0KzN4bnduQU1yRThYOVBCalY5NG9Ec0FGTHA3?= =?utf-8?B?VW5nRllMZTNCbC96R1lxbEVFRVJLRzQxaWdxUy9KMFpPa3ZIaTJTVVVzMXo3?= =?utf-8?B?SXpyMDE4d3Y1VVkzY09mQ3U2Z2xIbmVWeTJlK2JRZit5WlltcytjSGVDUzU3?= =?utf-8?B?N2RLS0RDY2U5eHdYU0ZtV0pqWEZmL0JTUUNPUlBybkVkZXlkUUF4bVBEQ2Za?= =?utf-8?B?M2s4cnlZajVTR2tDWGluQ1NyaExLa1BFMXE5MGd3aEFxTG9PSWpBMG1mbjEx?= =?utf-8?B?RHpndkJkd2hEVFRLTUlXM2xEOFdvSk0wTEEvQVNQSENnckZ0b1Y0Y1NkYUM1?= =?utf-8?B?VjZocGUwOFU5S1kvU29Lc3JuOWp2Yk9FU3gvcTRueWRlS0JJdXI2UkVobWh0?= =?utf-8?B?ZnJiMFhkcXJlWHptWXBOSnNIYzZmalZuaTVPMHhzdEFaZ1FmejEwZW9GWmRF?= =?utf-8?B?K3hFYjBvZG5LMWIveWpZS1pBUldyY0tmTS9JRm1tbS8zc0VOU0plQ213c3F6?= =?utf-8?B?alRacmhCdlJ6RHN5eFBrTFVHcm1tSGJBVGYrTjI4Q3h6enFUNlJTV0xPVTEz?= =?utf-8?B?MW5GcUdvUUZycWpyeStNOWNvblZjdHZ4V0ZSbTZZQzR1U3B6YVE0UUd2THFY?= =?utf-8?B?a1RIQjJySVo3RWFaQ3FmOGorTXBFNVlmdTl5Uk5JbHdKVXNMbVVHc0VNUk0y?= =?utf-8?B?azJwMXVxOUhndWpnR0xycEd1UTF6c3VVdUhGM29CZXZMN3k5a2JyaHp1ZG9u?= =?utf-8?B?RVZDSmJ1c28za2h1NnBnQTBGa0hObXl0YzhTY1p2YTZSOHpCTERHTlpldG02?= =?utf-8?B?U0RDM3dBYVlnK3RBbzdsM0FnbmswRGVlbDBUNXFvb3NNNUpsYTl0TjZ4WWxt?= =?utf-8?B?Z2ZtWUdaL1dyT2J2TkVTVVBHN29Bek83aWRBc3Q1SU5nWW95ZmRFc2liR1Nw?= =?utf-8?B?NlQwVVFVaG5iNUtWdXh0bWhoSjhxOHE0TTJrSjRxVmV3T2tYM2hpNXU1RlJr?= =?utf-8?B?NnUvKzFTOTliUlV0VTFNTFdyS25wbEtJYjdBUHJpblVFT0VrY1J5MW9iL3VI?= =?utf-8?B?RldlZWswekM2OWJsTXNpL2dOVlROeUdTQ0o1enV3L3JwQ3ZxdWdDaWNQU0dw?= =?utf-8?B?Z2Y3RGN4YWgxR29JRjBKczYyTUNuUEZ3Vk9HL0czUjlDdys0cnVxdy93YktC?= =?utf-8?B?R0NacVp5ejZlRXJrT3plZGZ6S3dVSnVsYXU2ZmJCWFpoWlJ4N2xPK0Y0VXhU?= =?utf-8?B?TDkwenQyN2RnekRzbGw5OGFMaVMzZ2VacU0zaGRzMUVLbzZaOU5jUHVrNTUx?= =?utf-8?B?czZpNU9XY29Gd24xdDY2UT09?= X-Microsoft-Exchange-Diagnostics: 1; CY1PR12MB0665; 6:Xmu/8TPMiTsVa464htI6Z/O/zhiBnmxRPDrl6xze+RhOGY4u7SCRsjkfJhudfCfO/JhT656RuNVekyyHFcSrmOSEl1Aq5UOTebX1ltV8EQ33xl5evz+S5Xlava4LuGOQYIjr2iu12c5y6lbUNOgWl5vKM9B4QfrMB5MxjehLqDl1MzGd4CbNnEmWsOZYQmxrISbL/CGB3MRYvuaczP6Ul2o6prHw4Y2FcuEaMrbbg+AEsHffYxuJ1BYR/G5u8hutL8ui+riZqzF1LdnRMiIf9j3sqPg0Qq3fD56zPCkyilmjV1oynlRVZjGdRqvJ+qqv9Pv2eyQWr2oFPm1Exml0iw==; 5:ua88t1jVen13llv7vYMFziFYK6jclCqHJKKAg1t7HRaR4MDSu3shbN/SnQZdTewGMtFAxp1qXnmJNqIed5FXcxz7Qy0vY1U/75O+INLEkEWgDWtulhoEvRQ2rH01AhVjFFko5iCvY3++4WKgvMk0+Q==; 24:mhp1UkDenRGLFI6NtLcMue2I19PJgyICRgSdWyy1azip+963pVUYDspkLhktuMHYb9Gtoti+7HW7oSHCz/XYpg6ABQfBCIb3FlGBmMzOiJo= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; CY1PR12MB0665; 7:+5bvZNhOTsyWwONEWGSSOiuwYwlcmkT9EybwLBCb4wK+7Rrrw8M3fONPAj9M6HzHb7/ZBIPoGvYBEASw0Fw0RqOuAPwDCnhg9IWv6MyJTvgawcX6vmLjFNhPR9ogfjWERYDo4mlcBfi5Dn8nQeqmOTQ0HeanlbNUcXSx/2Eyg6CprO8GJhzGyQFmaJcfYUnuc921j959NJp/Z/lkuSnwyVH8B78pQh2shTyuh7aVXwzQMvf/lCTsMQE+4/CWqhb5JWwbLAwxbYslkaLadtDiU8rW+JgdcMrbGwX9JdbYi4zxZKmFyBIAcDlqrKn/gbPwlR6jLfUbRndkNcus1muyhpAeRo1By0cgAeL1wYddHus=; 20:e1gWAEMGbKnDj+so4BSVSPo22jZIZPKAQy/bNx4eQZd1RTGvocGfRBFWrtE2hdP92SV5rpG0VXJnCdee37uyDBP4YyFbAD/0yZsHKaex85QCLeE8wx4KnTgF8H1FR8JuDLqwEtyS/xPB6j5jpyaxaIueW1mtP/OJ5ii27pljgHHcOpT9MNu8t2yERiMWPRfXT9BRtkDNwqMVH1ZPvusktm4407ub5JYyvDLJi+1KnMcAI6MHikD4HCRu3ANvsU5Y X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Nov 2016 15:52:21.6637 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY1PR12MB0665 X-detected-operating-system: by eggs.gnu.org: Windows 7 or 8 [fuzzy] X-Received-From: 104.47.36.67 Subject: [Qemu-devel] [RFC PATCH v3 03/18] exec: add debug version of physical memory read and write apis 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: brijesh.ksingh@gmail.com Errors-To: qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org Sender: "Qemu-devel" The patch adds the following new APIs: - cpu_physical_memory_read_debug - cpu_physical_memory_write_debug - cpu_physical_memory_rw_debug - ldl_phys_debug - ldq_phys_debug The idea behind this patch is that if all the qemu monitor memory dumps and gdbserver accesses are done through these common APIs then in future we can define some kind of global debug policy to control debug behavior. Signed-off-by: Brijesh Singh Reviewed-by: Paolo Bonzini --- exec.c | 32 ++++++++++++++++++++++++++++++++ include/exec/cpu-common.h | 15 +++++++++++++++ 2 files changed, 47 insertions(+) diff --git a/exec.c b/exec.c index d3356cd..4022e13 100644 --- a/exec.c +++ b/exec.c @@ -3149,6 +3149,30 @@ uint32_t ldl_phys(AddressSpace *as, hwaddr addr) return address_space_ldl(as, addr, MEMTXATTRS_UNSPECIFIED, NULL); } +uint32_t ldl_phys_debug(CPUState *cpu, hwaddr addr) +{ + MemTxAttrs attrs = MEMTXATTRS_DEBUG; + int asidx = cpu_asidx_from_attrs(cpu, attrs); + uint32_t val; + + cpu_physical_memory_rw_debug_internal(cpu->cpu_ases[asidx].as, + addr, (void *) &val, + 4, attrs, READ_DATA); + return tswap32(val); +} + +uint64_t ldq_phys_debug(CPUState *cpu, hwaddr addr) +{ + MemTxAttrs attrs = MEMTXATTRS_DEBUG; + int asidx = cpu_asidx_from_attrs(cpu, attrs); + uint64_t val; + + cpu_physical_memory_rw_debug_internal(cpu->cpu_ases[asidx].as, + addr, (void *) &val, + 8, attrs, READ_DATA); + return val; +} + uint32_t ldl_le_phys(AddressSpace *as, hwaddr addr) { return address_space_ldl_le(as, addr, MEMTXATTRS_UNSPECIFIED, NULL); @@ -3659,6 +3683,14 @@ void stq_be_phys(AddressSpace *as, hwaddr addr, uint64_t val) address_space_stq_be(as, addr, val, MEMTXATTRS_UNSPECIFIED, NULL); } +void cpu_physical_memory_rw_debug(hwaddr addr, uint8_t *buf, + int len, int is_write) +{ + cpu_physical_memory_rw_debug_internal(&address_space_memory, addr, + buf, len, MEMTXATTRS_DEBUG, + is_write ? WRITE_DATA : READ_DATA); +} + /* virtual memory access for debug (includes writing to ROM) */ int cpu_memory_rw_debug(CPUState *cpu, target_ulong addr, uint8_t *buf, int len, int is_write) diff --git a/include/exec/cpu-common.h b/include/exec/cpu-common.h index cffdc13..9abff47 100644 --- a/include/exec/cpu-common.h +++ b/include/exec/cpu-common.h @@ -67,6 +67,8 @@ size_t qemu_ram_pagesize(RAMBlock *block); void cpu_physical_memory_rw(hwaddr addr, uint8_t *buf, int len, int is_write); +void cpu_physical_memory_rw_debug(hwaddr addr, uint8_t *buf, + int len, int is_write); static inline void cpu_physical_memory_read(hwaddr addr, void *buf, int len) { @@ -77,6 +79,19 @@ static inline void cpu_physical_memory_write(hwaddr addr, { cpu_physical_memory_rw(addr, (void *)buf, len, 1); } +static inline void cpu_physical_memory_read_debug(hwaddr addr, + void *buf, int len) +{ + cpu_physical_memory_rw_debug(addr, buf, len, 0); +} +static inline void cpu_physical_memory_write_debug(hwaddr addr, + const void *buf, int len) +{ + cpu_physical_memory_rw_debug(addr, (void *)buf, len, 1); +} +uint32_t ldl_phys_debug(CPUState *cpu, hwaddr addr); +uint64_t ldq_phys_debug(CPUState *cpu, hwaddr addr); + void *cpu_physical_memory_map(hwaddr addr, hwaddr *plen, int is_write);