Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp5364701iog; Wed, 22 Jun 2022 18:32:24 -0700 (PDT) X-Google-Smtp-Source: AGRyM1uyEckxO16+iicWs0hhE5kivBRKF/4uljzZ7G5WVBk/mEuy7meTPP+6oSl3ST3X3NFzC0wv X-Received: by 2002:a50:ce4a:0:b0:435:c543:87e8 with SMTP id k10-20020a50ce4a000000b00435c54387e8mr2118016edj.295.1655947943789; Wed, 22 Jun 2022 18:32:23 -0700 (PDT) Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id er26-20020a056402449a00b00435643b13f6si16779075edb.374.2022.06.22.18.31.57; Wed, 22 Jun 2022 18:32:23 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=TNIF8GaW; arc=fail (signature failed); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234742AbiFWB30 (ORCPT + 99 others); Wed, 22 Jun 2022 21:29:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51468 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233608AbiFWB3Z (ORCPT ); Wed, 22 Jun 2022 21:29:25 -0400 Received: from mga04.intel.com (mga04.intel.com [192.55.52.120]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 441ED4339C for ; Wed, 22 Jun 2022 18:29:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1655947762; x=1687483762; h=message-id:date:subject:to:cc:references:from: in-reply-to:content-transfer-encoding:mime-version; bh=MC8mznSYXkYikQtqO+FTtiRUFXa8QZ+OxTtyErkjlds=; b=TNIF8GaWXabNDF/p6EQPq2mc3HUDKfvxQZAjS268cK3ZEdHdPRaGrj7Z 0Mvji5K/XWZDt6WO4KG03FjNJ2zjRN3L56uhztyHHjswbKqd2f7HJfPOo KeD+15jW0bwZzUq90EcVRCZh37NylR2H6i+gc+2XrVzVHDziB2XDzWI8r KxL8fE1LbDExgw/hwPfEunxn9E0wxZew1We1VphEl42raA7rEHHM8yBbu IhSVXfmzNRCMLhmPnU23o2YbM2UT+L+cZkCjckckqkZDqXr1g1TP3v3wI md0CEt4p/hdwcMoX7jOTXs4s8WSZyz/xfV6Z7akKsNhet0q26khc9bqMC A==; X-IronPort-AV: E=McAfee;i="6400,9594,10386"; a="279360608" X-IronPort-AV: E=Sophos;i="5.92,215,1650956400"; d="scan'208";a="279360608" Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Jun 2022 18:29:21 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.92,215,1650956400"; d="scan'208";a="538702183" Received: from orsmsx601.amr.corp.intel.com ([10.22.229.14]) by orsmga003.jf.intel.com with ESMTP; 22 Jun 2022 18:29:21 -0700 Received: from orsmsx612.amr.corp.intel.com (10.22.229.25) by ORSMSX601.amr.corp.intel.com (10.22.229.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.27; Wed, 22 Jun 2022 18:29:20 -0700 Received: from orsmsx611.amr.corp.intel.com (10.22.229.24) by ORSMSX612.amr.corp.intel.com (10.22.229.25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.27; Wed, 22 Jun 2022 18:29:17 -0700 Received: from ORSEDG601.ED.cps.intel.com (10.7.248.6) by orsmsx611.amr.corp.intel.com (10.22.229.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.27 via Frontend Transport; Wed, 22 Jun 2022 18:29:17 -0700 Received: from NAM11-DM6-obe.outbound.protection.outlook.com (104.47.57.175) by edgegateway.intel.com (134.134.137.102) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2308.27; Wed, 22 Jun 2022 18:29:17 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=UUQT3gem4QcHXQHjpkFc4jTWiMERb4qNDjfYYcMYr2wzlPAAhYRdDACSvI+0vr5Wnzuqpy7VODJH6Kc9dnKCoX6Oo1Ji6Y1sxjV/mLw49sdGYfMwyxnFqfQGl+qqwiTacfQLhGMlL5ZSR3/KlWer0SmKIoQ8DfuuLp7MiP8CC+eooH4y67GTFej0vQ8m6JidNnzLy+PuYVSvCsQJxFixKjChF00fAmoT6JwpTwr6t8Z9dQx+29KMho4tSuCZHvLlcjw81uOjkeX73+0QdFPh6rZI2UWFdofwfNZS4tMnqe9NXLvUvjOWk8p7AywNXSqNmjrp/bYDGW2V87Z6Is0Wtg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=beKQh/AhsuRJA6LHm610aq68kDaOjDAxumHNwpP52/0=; b=K6LWbwMmRWo3wb04JtkAtck7i3dWzWNaJxfaLJ38PMNoPX4VOcYqHWjol08/fXriwa8wMvTEnLLfHyQUf750S6Q+pPjMmR8VhypIln6VwhQ9uiVeLAgk8Ye4GiarGVOVfHKZkWsgEWrqTn+hNZZcyT0sXgxEeGhJXs6iNbNcrvaSntCKuU9/Gv2VuPTt+BubD4238Y7abYUKeD4syeqigrd1lhsB12OULlyPtW81UTzR9kT+xZqtp4tbmwwmVmMOTcIXZq5tVK2LKIVqz+mmSqt67fvzmE2YnDzpQ+pwN2RDBh1oz9ZLvt4iLW/1KT+4OU1a/mtS2q+DGsbT7Q+CIw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=intel.com; dmarc=pass action=none header.from=intel.com; dkim=pass header.d=intel.com; arc=none Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=intel.com; Received: from MN2PR11MB3870.namprd11.prod.outlook.com (2603:10b6:208:152::11) by SN6PR11MB2990.namprd11.prod.outlook.com (2603:10b6:805:cf::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5353.15; Thu, 23 Jun 2022 01:29:14 +0000 Received: from MN2PR11MB3870.namprd11.prod.outlook.com ([fe80::dd55:c9f5:fbc7:8a74]) by MN2PR11MB3870.namprd11.prod.outlook.com ([fe80::dd55:c9f5:fbc7:8a74%3]) with mapi id 15.20.5353.022; Thu, 23 Jun 2022 01:29:14 +0000 Message-ID: Date: Thu, 23 Jun 2022 09:29:05 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Firefox/91.0 Thunderbird/91.10.0 Subject: Re: [PATCH v3 2/4] memblock tests: add verbose output to memblock tests Content-Language: en-US To: Rebecca Mckeever CC: Mike Rapoport , , , David Hildenbrand References: <004e021cc3cb7be8749361b3b1cb324459b9cb9f.1655889641.git.remckee0@gmail.com> From: "Huang, Shaoqin" In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-ClientProxiedBy: SG2PR06CA0244.apcprd06.prod.outlook.com (2603:1096:4:ac::28) To MN2PR11MB3870.namprd11.prod.outlook.com (2603:10b6:208:152::11) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 31f82546-d9cd-4749-f465-08da54b7c7ec X-MS-TrafficTypeDiagnostic: SN6PR11MB2990:EE_ X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: W/pd5I44ZmEwfiAYP0erd31k92+HnUYdxcdomOOhDkigqm/yHewnr8kBxyQD3AHev0PUvd5n3ukhH/eG2gHmIq+xpqkMmJzxjUPT71XKwgxDy71MI22gBOBI7PHn9oJGzL4QZjhMlnd2um+1baHWZznsui0M7qvA75I48fMTob3PA0yZaaLDkK+730DciqMhWE33fsVkcmgghWmABbs67WrTYPipbrYkkT78XRJvSjpGskP/5u+vxrZTHXJcd49m1SXZh1FZImqQt1PDLrGI5fE4GbSVzuAYSMlNXJ+BrDBmKNT9VcUj0K6p/km96MvN76Twsv7rlVqq3gRj5rB5F315tPsogRGW5Ucjlp1/uSucINmf2awEJUGcSqYP+h9RjkDQpHcWyeSq0GO42nnZqez5DgyejQoHKjugbfGc37bUQ8v45VAhCT/MeABFec7oPb4SfYMm1GqbnGI0jBRBtbv94VcuYyiPcOqPchwsad+WAGv/vIK6waN09Bm9wbnzScNSQcj03rhnvQTr2NjHh3sZE5GQVBgPGLDKdlG0Vc5pvnmqPAr4wYvf11ZFJlIZKpe2yFFSF2eAtkAYEcbOXgukIadk9GGO9il8WEgh6tv2Gm3BamlHd/W0lHvgDJi4vi6hOP/a0M2Qr2AMrfAtKIR4x2LPTfbi1ytunw22SBsxU4KcfEacGor/U3gOPLxB6DSIZxgkKTTkMFxYIxuU6JkRYJBsEzhxNxeObV5ilzFbreqRnrF2JF+bsUtFVIvhJs6LpSAD+uFN6oQqb/Tf0Q== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:MN2PR11MB3870.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230016)(346002)(376002)(39860400002)(136003)(396003)(366004)(316002)(54906003)(6916009)(86362001)(478600001)(53546011)(30864003)(31686004)(6486002)(2906002)(6512007)(66476007)(5660300002)(26005)(4326008)(31696002)(41300700001)(66556008)(2616005)(8676002)(6666004)(8936002)(83380400001)(66946007)(38100700002)(186003)(6506007)(36756003)(82960400001)(45980500001)(43740500002)(579004)(559001);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?dzVtdCtHK2JDM0pHZjZnT2RhblYvVW9rTjUyQTFwdmZqR0JmOXRLYlJ5aFFC?= =?utf-8?B?WG9aSWdXMjZFTU00UmxmN0NEWENFazlUbllTOHNrUlI3SUlxU1RYRFJqVlF2?= =?utf-8?B?MXFxZG5qV2VGclk5RlpwODF0Y05MN2ZsZDJsR3Qya0krdUh3S25sTWNPZGQr?= =?utf-8?B?WVpObXlhT1JBNUpwQml4QUZHQ3RscmxrZkE2bWhPUHpXQXJMMTlEdzYzTWsy?= =?utf-8?B?TXlHSGJ5TUhxR3VuRWgycit2NGpRMGZXRXlZSzdHZlJEQ2VXb1Vnemx1Wmhi?= =?utf-8?B?QTRjRjBTMTJ4V3o4bFBZKzlLMzM4dWNUSWRCZHhpaWFJVW54Nk5qUHBwMngx?= =?utf-8?B?OU5MZ0lIdDBxbnpIWm9tZXlLS1ZTUnZqZzBHbmQxQzVIVkJkUE01ajdjYnUx?= =?utf-8?B?MkZzRUI4U2FGYjBJdUxyMFZ1c0h3alRlR0U2MFFCM3gxdHdQc2dyTGpoUmVp?= =?utf-8?B?ek5pV3JjQjBQb0dFSHhRYzcwc2ozaklLRTVqQW5mU3cydVZPaHVnbzJwakh5?= =?utf-8?B?dWtKZUhoOGIrcXQ1REJMaWVEOGU2Sjg0dHFXSlFjcTgyK0V6TXlMUE5vbjdC?= =?utf-8?B?eUZEcTZkYk41ZjVWMUNTbFJ2aDJISU1sQzBvb0M4ME9aWE84d2VyUXVJVUpQ?= =?utf-8?B?NFc0bFY2bnBvQ1EzN0h0RVpnaUZPayszNDRlQWlzSnhlakZCUk1DZkpaUDc1?= =?utf-8?B?M09Lcjc0Q2ZMRW45Z0dTNDVFTFJSODhCZjE4bWxyOEJUanB4eC9OV0FGRmU1?= =?utf-8?B?aTl3bm8rUGlwc2Zla0dUSFRSRk14bFdaeHZ4bVFsS2VScDJEYkJBeFFTMXVq?= =?utf-8?B?bTdmOFJ2bUFWWXAzNmVyWVcyc0w1aTZLYldDT3BtS1N4TG1Odm5LT21EOGtB?= =?utf-8?B?Q2h6bVFON0E1N0krdFVRcVJ2V3IrMnhubVRPMnVvL1VEWmtjNVArMTJwYzFE?= =?utf-8?B?Q1NOeWlxK2dBZ1NPYVFHV1ZjTzVUMzBjUGNEbGRLcUxiTU9jcWdtdkN5Y3VW?= =?utf-8?B?Sy90VWxlVXovQWtMWlI0Y3UyYmo5bUpzc3ZNTkFRMnBkbFkwUXNHTldkRHo5?= =?utf-8?B?U2VJOCtVZUlVdWFlbE42RDJ3bmZ3VldUVWExcFhwQ2lGL1cxYTJhN0NCS1M2?= =?utf-8?B?SWpFNkE4dXlyQUJ5MVRobjdNT2lZTktpZXkvT1hxNzUwRmtRZk5pVFJrenZn?= =?utf-8?B?M04wZmpaTm5xMjdiUWgwdmlaL0dOWC9tYVlHbm83eDJJVmZOSmczTkZSMEdt?= =?utf-8?B?SC8vMkpsYWdtR1FSL0tQOS9vTWswaDNtU2h5c2pSQkpYVW5lRzRvdUkwaEZs?= =?utf-8?B?b3ZjUEM1M2ZXVnc2d2ZLa2VFR25Fa21jVkl4RDVTbGVQTXhCYTZOazU2UzND?= =?utf-8?B?dnZBa244aEVVcW11SUtqZHNLQ1p3b01keEcwaDJ5SG9BNlBHRnVSL0pyN3ZX?= =?utf-8?B?aGxCaDgxSGVrczBMS0JDRU5XTkFZTFFTVE14MWg5eGVBc3BoZWxFak1ncEhS?= =?utf-8?B?ZXEwUWV2ZkZiYTB0NW90TjZrakNDdE42VHdPa3FxNTBoVTlGekJzL2xkRTJK?= =?utf-8?B?Zjh3dGtjY2xvVTNRZTlMaDB3NDRXdGJ4SWI4cTVrRzBTNzBrS0NaTzdEWHpR?= =?utf-8?B?am9rRkc1aDRZV2cxWFUzMXFrZU9PcVZlcVp3OERPNUZmVkh4dEsxNXhubnlF?= =?utf-8?B?YmE0T0xqdGd3SzAvRENkS01nRTdmRnQyOVNzWkR1RnZNRXN0QnZURUpEemNx?= =?utf-8?B?azdSTzFCUTl0Y2VnUmZrUnl6T2ZEeVZ3T0xjU3E0NE9kZXE0WFlnaTRQRG85?= =?utf-8?B?bkpQa1BPYXo2Z1FUY28zRHBWaitBRkhEYURGcGZVV2ozNGpPSjEycXBVSHpq?= =?utf-8?B?a0V4S2Q4dWRQSHpaRGd6a244cmxmaFpOZ2RMaHZsT25rS2ZJdGNXd2tCYlVK?= =?utf-8?B?R3NMYmNFQitHcU1MMXMvZjcyNGlqK3lrNFY0MmxDNnhCTTNqQ2pyU1ZXdU5s?= =?utf-8?B?enQ0UGdhWmhZdmtjTmRuc25JdVp6ekJWWnpSVXdWMFRiZEJWUXNHUzlJTFdT?= =?utf-8?B?LzJyTDRBVVBXR3Y5QVhCMlNWL3YxRzhwYWl2bGRCbzNxSFNGaXk1eEpESkky?= =?utf-8?B?c3krbXBlWHgrR2o3R2tNUkdhbDQvQ01ZQXVweFR4U0ZhNmpLZUVadGlRSlpz?= =?utf-8?B?Mm40dkhyVHdCOU5oWlhkMjQwM1hPVHB6aFo1L09TS2RIdEJUWC9LNy9QMkZy?= =?utf-8?B?clZjUFkzOVdvMG1KRWRKUklXa2xjbE5oc1BsWWppZGlabHV1TmNCRVlKcjVC?= =?utf-8?B?V08zZDBEUG5YdnRhQitHakdQMGtnZEpGMkJFVTJ5Q0Vla3FMaXRrRURKWWNp?= =?utf-8?Q?CzE+QdeFbMnUkT98=3D?= X-MS-Exchange-CrossTenant-Network-Message-Id: 31f82546-d9cd-4749-f465-08da54b7c7ec X-MS-Exchange-CrossTenant-AuthSource: MN2PR11MB3870.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 23 Jun 2022 01:29:14.2383 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 46c98d88-e344-4ed4-8496-4ed7712e255d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: mWY5NnPnvdw4Y66e9yPjVKr479NTGZLuSvwQFg2I5o6zWBzgZnLNUa5OHFF97m/0m0amOzDwBGaUwSj0Axs2nA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN6PR11MB2990 X-OriginatorOrg: intel.com X-Spam-Status: No, score=-5.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 6/23/2022 8:45 AM, Rebecca Mckeever wrote: > On Wed, Jun 22, 2022 at 06:32:04PM +0800, Huang, Shaoqin wrote: >> Just test it and everything works fine. And I think there are some thing can >> improve: >> >> The prefix_push() and prefix_pop() are used in so many functions and >> almost of them just put the prefix_push(__func__) begin in the head and the >> prefix_pop() in the end. >> May be you can define some macro that when you output something and >> automatically push the __func__ as prefix. And when leave the function, >> automatically pop it. And only in some special place, you call it manually. >> > Thank you for your review. I'm not sure how you would automatically push > __func__ since you have to be inside the function to access that > variable. Let me know if you have any suggestions. I am thinking about > adding another function in common.c that just calls test_pass() followed > by prefix_pop() since those are called together so often. Just like: #define test_pass_macro() \ do { \ prefix_push(__func__); \ test_pass(); \ prefix_pop(); \ } while (0) This macro will automatically push the __fun__ as prefix when you call test_pass_macro(). And then pop it after test_pass() output. And use this macro() to hidden most of the paired prefix_* functions. And I think that's the simplist way. May be someone has a better solution. >> >> On 6/22/2022 5:29 PM, Rebecca Mckeever wrote: >>> Add and use functions for printing verbose testing output. >>> >>> If the Memblock simulator was compiled with VERBOSE=1: >>> prefix_push() appends the given string to a prefix string that will be >>> printed in the test functions. >>> prefix_pop() removes the last prefix from the prefix string. >>> prefix_reset() clears the prefix string. >>> test_fail() prints a message after a test fails containing the test >>> number of the failing test and the prefix. >>> test_pass() prints a message after a test passes containing its test >>> number and the prefix. >>> test_print() prints the given formatted output string. >>> >> >> Comments like this is more clear, not just indent: >> - prefix_push(): appends ... >> - prefix_pop(): removes ... >> > That does look better, I'll update the commit text. > >>> If the Memblock simulator was not compiled with VERBOSE=1, these >>> functions do nothing. >>> >>> Add the assert wrapper macros ASSERT_EQ(), ASSERT_NE(), and ASSERT_LT(). >>> If the assert condition fails, these macros call test_fail() before >>> executing assert(). >>> >>> Signed-off-by: Rebecca Mckeever >>> --- >>> tools/testing/memblock/tests/alloc_api.c | 241 ++++++++---- >>> .../memblock/tests/alloc_helpers_api.c | 135 +++++-- >>> tools/testing/memblock/tests/alloc_nid_api.c | 371 ++++++++++++------ >>> tools/testing/memblock/tests/basic_api.c | 365 ++++++++++++----- >>> tools/testing/memblock/tests/common.c | 58 +++ >>> tools/testing/memblock/tests/common.h | 54 +++ >>> 6 files changed, 880 insertions(+), 344 deletions(-) >>> >>> diff --git a/tools/testing/memblock/tests/alloc_api.c b/tools/testing/memblock/tests/alloc_api.c >>> index d1aa7e15c18d..96df033d4300 100644 >>> --- a/tools/testing/memblock/tests/alloc_api.c >>> +++ b/tools/testing/memblock/tests/alloc_api.c >>> @@ -10,6 +10,8 @@ static int alloc_top_down_simple_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_2; >>> phys_addr_t expected_start; >>> @@ -19,12 +21,15 @@ static int alloc_top_down_simple_check(void) >>> allocated_ptr = memblock_alloc(size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == expected_start); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, expected_start); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -55,6 +60,8 @@ static int alloc_top_down_disjoint_check(void) >>> struct region r1; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r2_size = SZ_16; >>> /* Use custom alignment */ >>> phys_addr_t alignment = SMP_CACHE_BYTES * 2; >>> @@ -73,15 +80,18 @@ static int alloc_top_down_disjoint_check(void) >>> allocated_ptr = memblock_alloc(r2_size, alignment); >>> - assert(allocated_ptr); >>> - assert(rgn1->size == r1.size); >>> - assert(rgn1->base == r1.base); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn1->size, r1.size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> - assert(rgn2->size == r2_size); >>> - assert(rgn2->base == expected_start); >>> + ASSERT_EQ(rgn2->size, r2_size); >>> + ASSERT_EQ(rgn2->base, expected_start); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -101,6 +111,8 @@ static int alloc_top_down_before_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> /* >>> * The first region ends at the aligned address to test region merging >>> */ >>> @@ -114,12 +126,15 @@ static int alloc_top_down_before_check(void) >>> allocated_ptr = memblock_alloc(r2_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == memblock_end_of_DRAM() - total_size); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, memblock_end_of_DRAM() - total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -141,6 +156,8 @@ static int alloc_top_down_after_check(void) >>> struct region r1; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r2_size = SZ_512; >>> phys_addr_t total_size; >>> @@ -158,12 +175,15 @@ static int alloc_top_down_after_check(void) >>> allocated_ptr = memblock_alloc(r2_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == r1.base - r2_size); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, r1.base - r2_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -186,6 +206,8 @@ static int alloc_top_down_second_fit_check(void) >>> struct region r1, r2; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_1K; >>> phys_addr_t total_size; >>> @@ -204,12 +226,15 @@ static int alloc_top_down_second_fit_check(void) >>> allocated_ptr = memblock_alloc(r3_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == r2.size + r3_size); >>> - assert(rgn->base == r2.base - r3_size); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, r2.size + r3_size); >>> + ASSERT_EQ(rgn->base, r2.base - r3_size); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -231,6 +256,8 @@ static int alloc_in_between_generic_check(void) >>> struct region r1, r2; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t gap_size = SMP_CACHE_BYTES; >>> phys_addr_t r3_size = SZ_64; >>> /* >>> @@ -254,12 +281,15 @@ static int alloc_in_between_generic_check(void) >>> allocated_ptr = memblock_alloc(r3_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == r1.base - r2.size - r3_size); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, r1.base - r2.size - r3_size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -281,6 +311,8 @@ static int alloc_small_gaps_generic_check(void) >>> { >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t region_size = SZ_1K; >>> phys_addr_t gap_size = SZ_256; >>> phys_addr_t region_end; >>> @@ -296,7 +328,10 @@ static int alloc_small_gaps_generic_check(void) >>> allocated_ptr = memblock_alloc(region_size, SMP_CACHE_BYTES); >>> - assert(!allocated_ptr); >>> + ASSERT_EQ(allocated_ptr, NULL); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -309,6 +344,8 @@ static int alloc_all_reserved_generic_check(void) >>> { >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> setup_memblock(); >>> /* Simulate full memory */ >>> @@ -316,7 +353,10 @@ static int alloc_all_reserved_generic_check(void) >>> allocated_ptr = memblock_alloc(SZ_256, SMP_CACHE_BYTES); >>> - assert(!allocated_ptr); >>> + ASSERT_EQ(allocated_ptr, NULL); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -338,6 +378,8 @@ static int alloc_no_space_generic_check(void) >>> { >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> setup_memblock(); >>> phys_addr_t available_size = SZ_256; >>> @@ -348,7 +390,10 @@ static int alloc_no_space_generic_check(void) >>> allocated_ptr = memblock_alloc(SZ_1K, SMP_CACHE_BYTES); >>> - assert(!allocated_ptr); >>> + ASSERT_EQ(allocated_ptr, NULL); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -369,6 +414,8 @@ static int alloc_limited_space_generic_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t available_size = SZ_256; >>> phys_addr_t reserved_size = MEM_SIZE - available_size; >>> @@ -379,12 +426,15 @@ static int alloc_limited_space_generic_check(void) >>> allocated_ptr = memblock_alloc(available_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == MEM_SIZE); >>> - assert(rgn->base == memblock_start_of_DRAM()); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, MEM_SIZE); >>> + ASSERT_EQ(rgn->base, memblock_start_of_DRAM()); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, MEM_SIZE); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == MEM_SIZE); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -399,14 +449,19 @@ static int alloc_no_memory_generic_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> allocated_ptr = memblock_alloc(SZ_1K, SMP_CACHE_BYTES); >>> - assert(!allocated_ptr); >>> - assert(rgn->size == 0); >>> - assert(rgn->base == 0); >>> - assert(memblock.reserved.total_size == 0); >>> + ASSERT_EQ(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, 0); >>> + ASSERT_EQ(rgn->base, 0); >>> + ASSERT_EQ(memblock.reserved.total_size, 0); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -421,16 +476,21 @@ static int alloc_bottom_up_simple_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> setup_memblock(); >>> allocated_ptr = memblock_alloc(SZ_2, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == SZ_2); >>> - assert(rgn->base == memblock_start_of_DRAM()); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, SZ_2); >>> + ASSERT_EQ(rgn->base, memblock_start_of_DRAM()); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == SZ_2); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, SZ_2); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -459,6 +519,8 @@ static int alloc_bottom_up_disjoint_check(void) >>> struct region r1; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r2_size = SZ_16; >>> /* Use custom alignment */ >>> phys_addr_t alignment = SMP_CACHE_BYTES * 2; >>> @@ -477,16 +539,19 @@ static int alloc_bottom_up_disjoint_check(void) >>> allocated_ptr = memblock_alloc(r2_size, alignment); >>> - assert(allocated_ptr); >>> + ASSERT_NE(allocated_ptr, NULL); >>> - assert(rgn1->size == r1.size); >>> - assert(rgn1->base == r1.base); >>> + ASSERT_EQ(rgn1->size, r1.size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> - assert(rgn2->size == r2_size); >>> - assert(rgn2->base == expected_start); >>> + ASSERT_EQ(rgn2->size, r2_size); >>> + ASSERT_EQ(rgn2->base, expected_start); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -506,6 +571,8 @@ static int alloc_bottom_up_before_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r1_size = SZ_512; >>> phys_addr_t r2_size = SZ_128; >>> phys_addr_t total_size = r1_size + r2_size; >>> @@ -516,12 +583,15 @@ static int alloc_bottom_up_before_check(void) >>> allocated_ptr = memblock_alloc(r1_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == memblock_start_of_DRAM()); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, memblock_start_of_DRAM()); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -542,6 +612,8 @@ static int alloc_bottom_up_after_check(void) >>> struct region r1; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r2_size = SZ_512; >>> phys_addr_t total_size; >>> @@ -559,12 +631,15 @@ static int alloc_bottom_up_after_check(void) >>> allocated_ptr = memblock_alloc(r2_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == r1.base); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -588,6 +663,8 @@ static int alloc_bottom_up_second_fit_check(void) >>> struct region r1, r2; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_1K; >>> phys_addr_t total_size; >>> @@ -606,12 +683,15 @@ static int alloc_bottom_up_second_fit_check(void) >>> allocated_ptr = memblock_alloc(r3_size, SMP_CACHE_BYTES); >>> - assert(allocated_ptr); >>> - assert(rgn->size == r2.size + r3_size); >>> - assert(rgn->base == r2.base); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, r2.size + r3_size); >>> + ASSERT_EQ(rgn->base, r2.base); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -619,6 +699,7 @@ static int alloc_bottom_up_second_fit_check(void) >>> /* Test case wrappers */ >>> static int alloc_simple_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_top_down_simple_check(); >>> memblock_set_bottom_up(true); >>> @@ -629,6 +710,7 @@ static int alloc_simple_check(void) >>> static int alloc_disjoint_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_top_down_disjoint_check(); >>> memblock_set_bottom_up(true); >>> @@ -639,6 +721,7 @@ static int alloc_disjoint_check(void) >>> static int alloc_before_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_top_down_before_check(); >>> memblock_set_bottom_up(true); >>> @@ -649,6 +732,7 @@ static int alloc_before_check(void) >>> static int alloc_after_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_top_down_after_check(); >>> memblock_set_bottom_up(true); >>> @@ -659,6 +743,7 @@ static int alloc_after_check(void) >>> static int alloc_in_between_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_in_between_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -669,6 +754,7 @@ static int alloc_in_between_check(void) >>> static int alloc_second_fit_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_top_down_second_fit_check(); >>> memblock_set_bottom_up(true); >>> @@ -679,6 +765,7 @@ static int alloc_second_fit_check(void) >>> static int alloc_small_gaps_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_small_gaps_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -689,6 +776,7 @@ static int alloc_small_gaps_check(void) >>> static int alloc_all_reserved_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_all_reserved_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -699,6 +787,7 @@ static int alloc_all_reserved_check(void) >>> static int alloc_no_space_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_no_space_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -709,6 +798,7 @@ static int alloc_no_space_check(void) >>> static int alloc_limited_space_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_limited_space_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -719,6 +809,7 @@ static int alloc_limited_space_check(void) >>> static int alloc_no_memory_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_no_memory_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -729,6 +820,12 @@ static int alloc_no_memory_check(void) >>> int memblock_alloc_checks(void) >>> { >>> + static const char func_testing[] = "memblock_alloc"; >>> + >>> + prefix_reset(); >>> + prefix_push(func_testing); >>> + test_print("Running %s tests...\n", func_testing); >>> + >>> reset_memblock_attributes(); >>> dummy_physical_memory_init(); >>> @@ -746,5 +843,7 @@ int memblock_alloc_checks(void) >>> dummy_physical_memory_cleanup(); >>> + prefix_pop(); >>> + >>> return 0; >>> } >>> diff --git a/tools/testing/memblock/tests/alloc_helpers_api.c b/tools/testing/memblock/tests/alloc_helpers_api.c >>> index 963a966db461..f6eaed540427 100644 >>> --- a/tools/testing/memblock/tests/alloc_helpers_api.c >>> +++ b/tools/testing/memblock/tests/alloc_helpers_api.c >>> @@ -21,6 +21,8 @@ static int alloc_from_simple_generic_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_16; >>> phys_addr_t min_addr; >>> @@ -31,14 +33,17 @@ static int alloc_from_simple_generic_check(void) >>> allocated_ptr = memblock_alloc_from(size, SMP_CACHE_BYTES, min_addr); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, min_addr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == min_addr); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -64,6 +69,8 @@ static int alloc_from_misaligned_generic_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_32; >>> phys_addr_t min_addr; >>> @@ -75,14 +82,17 @@ static int alloc_from_misaligned_generic_check(void) >>> allocated_ptr = memblock_alloc_from(size, SMP_CACHE_BYTES, min_addr); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> - assert(rgn->size == size); >>> - assert(rgn->base == memblock_end_of_DRAM() - SMP_CACHE_BYTES); >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, memblock_end_of_DRAM() - SMP_CACHE_BYTES); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -110,6 +120,8 @@ static int alloc_from_top_down_high_addr_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_32; >>> phys_addr_t min_addr; >>> @@ -120,12 +132,15 @@ static int alloc_from_top_down_high_addr_check(void) >>> allocated_ptr = memblock_alloc_from(size, SMP_CACHE_BYTES, min_addr); >>> - assert(allocated_ptr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == memblock_end_of_DRAM() - SMP_CACHE_BYTES); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, memblock_end_of_DRAM() - SMP_CACHE_BYTES); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -151,6 +166,8 @@ static int alloc_from_top_down_no_space_above_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r1_size = SZ_64; >>> phys_addr_t r2_size = SZ_2; >>> phys_addr_t total_size = r1_size + r2_size; >>> @@ -165,12 +182,15 @@ static int alloc_from_top_down_no_space_above_check(void) >>> allocated_ptr = memblock_alloc_from(r1_size, SMP_CACHE_BYTES, min_addr); >>> - assert(allocated_ptr); >>> - assert(rgn->base == min_addr - r1_size); >>> - assert(rgn->size == total_size); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->base, min_addr - r1_size); >>> + ASSERT_EQ(rgn->size, total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -186,6 +206,8 @@ static int alloc_from_top_down_min_addr_cap_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r1_size = SZ_64; >>> phys_addr_t min_addr; >>> phys_addr_t start_addr; >>> @@ -199,12 +221,15 @@ static int alloc_from_top_down_min_addr_cap_check(void) >>> allocated_ptr = memblock_alloc_from(r1_size, SMP_CACHE_BYTES, min_addr); >>> - assert(allocated_ptr); >>> - assert(rgn->base == start_addr); >>> - assert(rgn->size == MEM_SIZE); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->base, start_addr); >>> + ASSERT_EQ(rgn->size, MEM_SIZE); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == MEM_SIZE); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, MEM_SIZE); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -230,6 +255,8 @@ static int alloc_from_bottom_up_high_addr_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_32; >>> phys_addr_t min_addr; >>> @@ -240,12 +267,15 @@ static int alloc_from_bottom_up_high_addr_check(void) >>> allocated_ptr = memblock_alloc_from(size, SMP_CACHE_BYTES, min_addr); >>> - assert(allocated_ptr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == memblock_start_of_DRAM()); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, memblock_start_of_DRAM()); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -270,6 +300,8 @@ static int alloc_from_bottom_up_no_space_above_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r1_size = SZ_64; >>> phys_addr_t min_addr; >>> phys_addr_t r2_size; >>> @@ -284,12 +316,15 @@ static int alloc_from_bottom_up_no_space_above_check(void) >>> allocated_ptr = memblock_alloc_from(r1_size, SMP_CACHE_BYTES, min_addr); >>> - assert(allocated_ptr); >>> - assert(rgn->base == memblock_start_of_DRAM()); >>> - assert(rgn->size == r1_size); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->base, memblock_start_of_DRAM()); >>> + ASSERT_EQ(rgn->size, r1_size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, r1_size + r2_size); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == r1_size + r2_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -304,6 +339,8 @@ static int alloc_from_bottom_up_min_addr_cap_check(void) >>> struct memblock_region *rgn = &memblock.reserved.regions[0]; >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r1_size = SZ_64; >>> phys_addr_t min_addr; >>> phys_addr_t start_addr; >>> @@ -315,12 +352,15 @@ static int alloc_from_bottom_up_min_addr_cap_check(void) >>> allocated_ptr = memblock_alloc_from(r1_size, SMP_CACHE_BYTES, min_addr); >>> - assert(allocated_ptr); >>> - assert(rgn->base == start_addr); >>> - assert(rgn->size == r1_size); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(rgn->base, start_addr); >>> + ASSERT_EQ(rgn->size, r1_size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, r1_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == r1_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -328,6 +368,7 @@ static int alloc_from_bottom_up_min_addr_cap_check(void) >>> /* Test case wrappers */ >>> static int alloc_from_simple_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_from_simple_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -338,6 +379,7 @@ static int alloc_from_simple_check(void) >>> static int alloc_from_misaligned_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_from_misaligned_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -348,6 +390,7 @@ static int alloc_from_misaligned_check(void) >>> static int alloc_from_high_addr_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_from_top_down_high_addr_check(); >>> memblock_set_bottom_up(true); >>> @@ -358,6 +401,7 @@ static int alloc_from_high_addr_check(void) >>> static int alloc_from_no_space_above_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_from_top_down_no_space_above_check(); >>> memblock_set_bottom_up(true); >>> @@ -368,6 +412,7 @@ static int alloc_from_no_space_above_check(void) >>> static int alloc_from_min_addr_cap_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_from_top_down_min_addr_cap_check(); >>> memblock_set_bottom_up(true); >>> @@ -378,6 +423,12 @@ static int alloc_from_min_addr_cap_check(void) >>> int memblock_alloc_helpers_checks(void) >>> { >>> + static const char func_testing[] = "memblock_alloc_from"; >>> + >>> + prefix_reset(); >>> + prefix_push(func_testing); >>> + test_print("Running %s tests...\n", func_testing); >>> + >>> reset_memblock_attributes(); >>> dummy_physical_memory_init(); >>> diff --git a/tools/testing/memblock/tests/alloc_nid_api.c b/tools/testing/memblock/tests/alloc_nid_api.c >>> index 6390206e50e1..601f4a7ee30d 100644 >>> --- a/tools/testing/memblock/tests/alloc_nid_api.c >>> +++ b/tools/testing/memblock/tests/alloc_nid_api.c >>> @@ -21,6 +21,8 @@ static int alloc_try_nid_top_down_simple_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_128; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -36,15 +38,18 @@ static int alloc_try_nid_top_down_simple_check(void) >>> b = (char *)allocated_ptr; >>> rgn_end = rgn->base + rgn->size; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, max_addr - size); >>> + ASSERT_EQ(rgn_end, max_addr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == max_addr - size); >>> - assert(rgn_end == max_addr); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -72,6 +77,8 @@ static int alloc_try_nid_top_down_end_misaligned_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_128; >>> phys_addr_t misalign = SZ_2; >>> phys_addr_t min_addr; >>> @@ -88,15 +95,18 @@ static int alloc_try_nid_top_down_end_misaligned_check(void) >>> b = (char *)allocated_ptr; >>> rgn_end = rgn->base + rgn->size; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> - assert(rgn->size == size); >>> - assert(rgn->base == max_addr - size - misalign); >>> - assert(rgn_end < max_addr); >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, max_addr - size - misalign); >>> + ASSERT_LT(rgn_end, max_addr); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -122,6 +132,8 @@ static int alloc_try_nid_exact_address_generic_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_1K; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -137,15 +149,18 @@ static int alloc_try_nid_exact_address_generic_check(void) >>> b = (char *)allocated_ptr; >>> rgn_end = rgn->base + rgn->size; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, min_addr); >>> + ASSERT_EQ(rgn_end, max_addr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == min_addr); >>> - assert(rgn_end == max_addr); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -173,6 +188,8 @@ static int alloc_try_nid_top_down_narrow_range_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_256; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -186,14 +203,17 @@ static int alloc_try_nid_top_down_narrow_range_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, max_addr - size); >>> - assert(rgn->size == size); >>> - assert(rgn->base == max_addr - size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -222,6 +242,8 @@ static int alloc_try_nid_low_max_generic_check(void) >>> { >>> void *allocated_ptr = NULL; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_1K; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -234,7 +256,10 @@ static int alloc_try_nid_low_max_generic_check(void) >>> allocated_ptr = memblock_alloc_try_nid(size, SMP_CACHE_BYTES, >>> min_addr, max_addr, NUMA_NO_NODE); >>> - assert(!allocated_ptr); >>> + ASSERT_EQ(allocated_ptr, NULL); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -259,6 +284,8 @@ static int alloc_try_nid_min_reserved_generic_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r1_size = SZ_128; >>> phys_addr_t r2_size = SZ_64; >>> phys_addr_t total_size = r1_size + r2_size; >>> @@ -278,14 +305,17 @@ static int alloc_try_nid_min_reserved_generic_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == reserved_base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, reserved_base); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -310,6 +340,8 @@ static int alloc_try_nid_max_reserved_generic_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r1_size = SZ_64; >>> phys_addr_t r2_size = SZ_128; >>> phys_addr_t total_size = r1_size + r2_size; >>> @@ -327,14 +359,17 @@ static int alloc_try_nid_max_reserved_generic_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, min_addr); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == min_addr); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -364,6 +399,8 @@ static int alloc_try_nid_top_down_reserved_with_space_check(void) >>> char *b; >>> struct region r1, r2; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_64; >>> phys_addr_t gap_size = SMP_CACHE_BYTES; >>> phys_addr_t total_size; >>> @@ -389,17 +426,20 @@ static int alloc_try_nid_top_down_reserved_with_space_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn1->size, r1.size + r3_size); >>> + ASSERT_EQ(rgn1->base, max_addr - r3_size); >>> - assert(rgn1->size == r1.size + r3_size); >>> - assert(rgn1->base == max_addr - r3_size); >>> + ASSERT_EQ(rgn2->size, r2.size); >>> + ASSERT_EQ(rgn2->base, r2.base); >>> - assert(rgn2->size == r2.size); >>> - assert(rgn2->base == r2.base); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -427,6 +467,8 @@ static int alloc_try_nid_reserved_full_merge_generic_check(void) >>> char *b; >>> struct region r1, r2; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_64; >>> phys_addr_t total_size; >>> phys_addr_t max_addr; >>> @@ -451,14 +493,17 @@ static int alloc_try_nid_reserved_full_merge_generic_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> - assert(rgn->size == total_size); >>> - assert(rgn->base == r2.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + ASSERT_EQ(rgn->base, r2.base); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -489,6 +534,8 @@ static int alloc_try_nid_top_down_reserved_no_space_check(void) >>> char *b; >>> struct region r1, r2; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_256; >>> phys_addr_t gap_size = SMP_CACHE_BYTES; >>> phys_addr_t total_size; >>> @@ -514,17 +561,20 @@ static int alloc_try_nid_top_down_reserved_no_space_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn1->size, r1.size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> - assert(rgn1->size == r1.size); >>> - assert(rgn1->base == r1.base); >>> + ASSERT_EQ(rgn2->size, r2.size + r3_size); >>> + ASSERT_EQ(rgn2->base, r2.base - r3_size); >>> - assert(rgn2->size == r2.size + r3_size); >>> - assert(rgn2->base == r2.base - r3_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -554,6 +604,8 @@ static int alloc_try_nid_reserved_all_generic_check(void) >>> void *allocated_ptr = NULL; >>> struct region r1, r2; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_256; >>> phys_addr_t gap_size = SMP_CACHE_BYTES; >>> phys_addr_t max_addr; >>> @@ -576,7 +628,10 @@ static int alloc_try_nid_reserved_all_generic_check(void) >>> allocated_ptr = memblock_alloc_try_nid(r3_size, SMP_CACHE_BYTES, >>> min_addr, max_addr, NUMA_NO_NODE); >>> - assert(!allocated_ptr); >>> + ASSERT_EQ(allocated_ptr, NULL); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -592,6 +647,8 @@ static int alloc_try_nid_top_down_cap_max_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_256; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -605,14 +662,17 @@ static int alloc_try_nid_top_down_cap_max_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, memblock_end_of_DRAM() - size); >>> - assert(rgn->size == size); >>> - assert(rgn->base == memblock_end_of_DRAM() - size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -628,6 +688,8 @@ static int alloc_try_nid_top_down_cap_min_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_1K; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -641,14 +703,17 @@ static int alloc_try_nid_top_down_cap_min_check(void) >>> min_addr, max_addr, NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> - assert(rgn->size == size); >>> - assert(rgn->base == memblock_end_of_DRAM() - size); >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, memblock_end_of_DRAM() - size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -673,6 +738,8 @@ static int alloc_try_nid_bottom_up_simple_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_128; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -689,15 +756,18 @@ static int alloc_try_nid_bottom_up_simple_check(void) >>> b = (char *)allocated_ptr; >>> rgn_end = rgn->base + rgn->size; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, min_addr); >>> + ASSERT_LT(rgn_end, max_addr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == min_addr); >>> - assert(rgn_end < max_addr); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -725,6 +795,8 @@ static int alloc_try_nid_bottom_up_start_misaligned_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_128; >>> phys_addr_t misalign = SZ_2; >>> phys_addr_t min_addr; >>> @@ -742,15 +814,18 @@ static int alloc_try_nid_bottom_up_start_misaligned_check(void) >>> b = (char *)allocated_ptr; >>> rgn_end = rgn->base + rgn->size; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, min_addr + (SMP_CACHE_BYTES - misalign)); >>> + ASSERT_LT(rgn_end, max_addr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == min_addr + (SMP_CACHE_BYTES - misalign)); >>> - assert(rgn_end < max_addr); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -778,6 +853,8 @@ static int alloc_try_nid_bottom_up_narrow_range_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_256; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -792,14 +869,17 @@ static int alloc_try_nid_bottom_up_narrow_range_check(void) >>> NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> - assert(rgn->size == size); >>> - assert(rgn->base == memblock_start_of_DRAM()); >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, memblock_start_of_DRAM()); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -829,6 +909,8 @@ static int alloc_try_nid_bottom_up_reserved_with_space_check(void) >>> char *b; >>> struct region r1, r2; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_64; >>> phys_addr_t gap_size = SMP_CACHE_BYTES; >>> phys_addr_t total_size; >>> @@ -855,17 +937,20 @@ static int alloc_try_nid_bottom_up_reserved_with_space_check(void) >>> NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> - assert(rgn1->size == r1.size); >>> - assert(rgn1->base == max_addr); >>> + ASSERT_EQ(rgn1->size, r1.size); >>> + ASSERT_EQ(rgn1->base, max_addr); >>> - assert(rgn2->size == r2.size + r3_size); >>> - assert(rgn2->base == r2.base); >>> + ASSERT_EQ(rgn2->size, r2.size + r3_size); >>> + ASSERT_EQ(rgn2->base, r2.base); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -899,6 +984,8 @@ static int alloc_try_nid_bottom_up_reserved_no_space_check(void) >>> char *b; >>> struct region r1, r2; >>> + prefix_push(__func__); >>> + >>> phys_addr_t r3_size = SZ_256; >>> phys_addr_t gap_size = SMP_CACHE_BYTES; >>> phys_addr_t total_size; >>> @@ -925,20 +1012,23 @@ static int alloc_try_nid_bottom_up_reserved_no_space_check(void) >>> NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn3->size, r3_size); >>> + ASSERT_EQ(rgn3->base, memblock_start_of_DRAM()); >>> - assert(rgn3->size == r3_size); >>> - assert(rgn3->base == memblock_start_of_DRAM()); >>> + ASSERT_EQ(rgn2->size, r2.size); >>> + ASSERT_EQ(rgn2->base, r2.base); >>> - assert(rgn2->size == r2.size); >>> - assert(rgn2->base == r2.base); >>> + ASSERT_EQ(rgn1->size, r1.size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> - assert(rgn1->size == r1.size); >>> - assert(rgn1->base == r1.base); >>> + ASSERT_EQ(memblock.reserved.cnt, 3); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> - assert(memblock.reserved.cnt == 3); >>> - assert(memblock.reserved.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -954,6 +1044,8 @@ static int alloc_try_nid_bottom_up_cap_max_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_256; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -968,14 +1060,17 @@ static int alloc_try_nid_bottom_up_cap_max_check(void) >>> NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, min_addr); >>> - assert(rgn->size == size); >>> - assert(rgn->base == min_addr); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -991,6 +1086,8 @@ static int alloc_try_nid_bottom_up_cap_min_check(void) >>> void *allocated_ptr = NULL; >>> char *b; >>> + prefix_push(__func__); >>> + >>> phys_addr_t size = SZ_1K; >>> phys_addr_t min_addr; >>> phys_addr_t max_addr; >>> @@ -1005,14 +1102,17 @@ static int alloc_try_nid_bottom_up_cap_min_check(void) >>> NUMA_NO_NODE); >>> b = (char *)allocated_ptr; >>> - assert(allocated_ptr); >>> - assert(*b == 0); >>> + ASSERT_NE(allocated_ptr, NULL); >>> + ASSERT_EQ(*b, 0); >>> + >>> + ASSERT_EQ(rgn->size, size); >>> + ASSERT_EQ(rgn->base, memblock_start_of_DRAM()); >>> - assert(rgn->size == size); >>> - assert(rgn->base == memblock_start_of_DRAM()); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -1020,6 +1120,7 @@ static int alloc_try_nid_bottom_up_cap_min_check(void) >>> /* Test case wrappers */ >>> static int alloc_try_nid_simple_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_top_down_simple_check(); >>> memblock_set_bottom_up(true); >>> @@ -1030,6 +1131,7 @@ static int alloc_try_nid_simple_check(void) >>> static int alloc_try_nid_misaligned_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_top_down_end_misaligned_check(); >>> memblock_set_bottom_up(true); >>> @@ -1040,6 +1142,7 @@ static int alloc_try_nid_misaligned_check(void) >>> static int alloc_try_nid_narrow_range_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_top_down_narrow_range_check(); >>> memblock_set_bottom_up(true); >>> @@ -1050,6 +1153,7 @@ static int alloc_try_nid_narrow_range_check(void) >>> static int alloc_try_nid_reserved_with_space_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_top_down_reserved_with_space_check(); >>> memblock_set_bottom_up(true); >>> @@ -1060,6 +1164,7 @@ static int alloc_try_nid_reserved_with_space_check(void) >>> static int alloc_try_nid_reserved_no_space_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_top_down_reserved_no_space_check(); >>> memblock_set_bottom_up(true); >>> @@ -1070,6 +1175,7 @@ static int alloc_try_nid_reserved_no_space_check(void) >>> static int alloc_try_nid_cap_max_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_top_down_cap_max_check(); >>> memblock_set_bottom_up(true); >>> @@ -1080,6 +1186,7 @@ static int alloc_try_nid_cap_max_check(void) >>> static int alloc_try_nid_cap_min_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_top_down_cap_min_check(); >>> memblock_set_bottom_up(true); >>> @@ -1090,6 +1197,7 @@ static int alloc_try_nid_cap_min_check(void) >>> static int alloc_try_nid_min_reserved_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_min_reserved_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -1100,6 +1208,7 @@ static int alloc_try_nid_min_reserved_check(void) >>> static int alloc_try_nid_max_reserved_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_max_reserved_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -1110,6 +1219,7 @@ static int alloc_try_nid_max_reserved_check(void) >>> static int alloc_try_nid_exact_address_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_exact_address_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -1120,6 +1230,7 @@ static int alloc_try_nid_exact_address_check(void) >>> static int alloc_try_nid_reserved_full_merge_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_reserved_full_merge_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -1130,6 +1241,7 @@ static int alloc_try_nid_reserved_full_merge_check(void) >>> static int alloc_try_nid_reserved_all_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_reserved_all_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -1140,6 +1252,7 @@ static int alloc_try_nid_reserved_all_check(void) >>> static int alloc_try_nid_low_max_check(void) >>> { >>> + test_print("\tRunning %s...\n", __func__); >>> memblock_set_bottom_up(false); >>> alloc_try_nid_low_max_generic_check(); >>> memblock_set_bottom_up(true); >>> @@ -1150,6 +1263,12 @@ static int alloc_try_nid_low_max_check(void) >>> int memblock_alloc_nid_checks(void) >>> { >>> + static const char func_testing[] = "memblock_alloc_try_nid"; >>> + >>> + prefix_reset(); >>> + prefix_push(func_testing); >>> + test_print("Running %s tests...\n", func_testing); >>> + >>> reset_memblock_attributes(); >>> dummy_physical_memory_init(); >>> @@ -1170,5 +1289,7 @@ int memblock_alloc_nid_checks(void) >>> dummy_physical_memory_cleanup(); >>> + prefix_pop(); >>> + >>> return 0; >>> } >>> diff --git a/tools/testing/memblock/tests/basic_api.c b/tools/testing/memblock/tests/basic_api.c >>> index a7bc180316d6..f223a9a57be7 100644 >>> --- a/tools/testing/memblock/tests/basic_api.c >>> +++ b/tools/testing/memblock/tests/basic_api.c >>> @@ -4,21 +4,30 @@ >>> #include "basic_api.h" >>> #define EXPECTED_MEMBLOCK_REGIONS 128 >>> +#define FUNC_ADD "memblock_add" >>> +#define FUNC_RESERVE "memblock_reserve" >>> +#define FUNC_REMOVE "memblock_remove" >>> +#define FUNC_FREE "memblock_free" >>> static int memblock_initialization_check(void) >>> { >>> - assert(memblock.memory.regions); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.max == EXPECTED_MEMBLOCK_REGIONS); >>> - assert(strcmp(memblock.memory.name, "memory") == 0); >>> + prefix_push(__func__); >>> - assert(memblock.reserved.regions); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.memory.max == EXPECTED_MEMBLOCK_REGIONS); >>> - assert(strcmp(memblock.reserved.name, "reserved") == 0); >>> + ASSERT_NE(memblock.memory.regions, NULL); >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.max, EXPECTED_MEMBLOCK_REGIONS); >>> + ASSERT_EQ(strcmp(memblock.memory.name, "memory"), 0); >>> - assert(!memblock.bottom_up); >>> - assert(memblock.current_limit == MEMBLOCK_ALLOC_ANYWHERE); >>> + ASSERT_NE(memblock.reserved.regions, NULL); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.memory.max, EXPECTED_MEMBLOCK_REGIONS); >>> + ASSERT_EQ(strcmp(memblock.reserved.name, "reserved"), 0); >>> + >>> + ASSERT_EQ(memblock.bottom_up, false); >>> + ASSERT_EQ(memblock.current_limit, MEMBLOCK_ALLOC_ANYWHERE); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -40,14 +49,19 @@ static int memblock_add_simple_check(void) >>> .size = SZ_4M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_add(r.base, r.size); >>> - assert(rgn->base == r.base); >>> - assert(rgn->size == r.size); >>> + ASSERT_EQ(rgn->base, r.base); >>> + ASSERT_EQ(rgn->size, r.size); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, r.size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == r.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -69,18 +83,27 @@ static int memblock_add_node_simple_check(void) >>> .size = SZ_16M >>> }; >>> + prefix_pop(); >>> + prefix_push("memblock_add_node"); >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_add_node(r.base, r.size, 1, MEMBLOCK_HOTPLUG); >>> - assert(rgn->base == r.base); >>> - assert(rgn->size == r.size); >>> + ASSERT_EQ(rgn->base, r.base); >>> + ASSERT_EQ(rgn->size, r.size); >>> #ifdef CONFIG_NUMA >>> - assert(rgn->nid == 1); >>> + ASSERT_EQ(rgn->nid, 1); >>> #endif >>> - assert(rgn->flags == MEMBLOCK_HOTPLUG); >>> + ASSERT_EQ(rgn->flags, MEMBLOCK_HOTPLUG); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, r.size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == r.size); >>> + test_pass(); >>> + prefix_pop(); >>> + prefix_pop(); >>> + prefix_push(FUNC_ADD); >>> return 0; >>> } >>> @@ -113,18 +136,23 @@ static int memblock_add_disjoint_check(void) >>> .size = SZ_8K >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_add(r1.base, r1.size); >>> memblock_add(r2.base, r2.size); >>> - assert(rgn1->base == r1.base); >>> - assert(rgn1->size == r1.size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> + ASSERT_EQ(rgn1->size, r1.size); >>> + >>> + ASSERT_EQ(rgn2->base, r2.base); >>> + ASSERT_EQ(rgn2->size, r2.size); >>> - assert(rgn2->base == r2.base); >>> - assert(rgn2->size == r2.size); >>> + ASSERT_EQ(memblock.memory.cnt, 2); >>> + ASSERT_EQ(memblock.memory.total_size, r1.size + r2.size); >>> - assert(memblock.memory.cnt == 2); >>> - assert(memblock.memory.total_size == r1.size + r2.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -162,17 +190,22 @@ static int memblock_add_overlap_top_check(void) >>> .size = SZ_512M >>> }; >>> + prefix_push(__func__); >>> + >>> total_size = (r1.base - r2.base) + r1.size; >>> reset_memblock_regions(); >>> memblock_add(r1.base, r1.size); >>> memblock_add(r2.base, r2.size); >>> - assert(rgn->base == r2.base); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r2.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, total_size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -210,17 +243,22 @@ static int memblock_add_overlap_bottom_check(void) >>> .size = SZ_1G >>> }; >>> + prefix_push(__func__); >>> + >>> total_size = (r2.base - r1.base) + r2.size; >>> reset_memblock_regions(); >>> memblock_add(r1.base, r1.size); >>> memblock_add(r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, total_size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -255,15 +293,20 @@ static int memblock_add_within_check(void) >>> .size = SZ_1M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_add(r1.base, r1.size); >>> memblock_add(r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == r1.size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, r1.size); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, r1.size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == r1.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -279,19 +322,28 @@ static int memblock_add_twice_check(void) >>> .size = SZ_2M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_add(r.base, r.size); >>> memblock_add(r.base, r.size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == r.size); >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, r.size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> static int memblock_add_checks(void) >>> { >>> + prefix_reset(); >>> + prefix_push(FUNC_ADD); >>> + test_print("Running %s tests...\n", FUNC_ADD); >>> + >>> memblock_add_simple_check(); >>> memblock_add_node_simple_check(); >>> memblock_add_disjoint_check(); >>> @@ -300,6 +352,8 @@ static int memblock_add_checks(void) >>> memblock_add_within_check(); >>> memblock_add_twice_check(); >>> + prefix_pop(); >>> + >>> return 0; >>> } >>> @@ -320,11 +374,16 @@ static int memblock_reserve_simple_check(void) >>> .size = SZ_128M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_reserve(r.base, r.size); >>> - assert(rgn->base == r.base); >>> - assert(rgn->size == r.size); >>> + ASSERT_EQ(rgn->base, r.base); >>> + ASSERT_EQ(rgn->size, r.size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -356,18 +415,23 @@ static int memblock_reserve_disjoint_check(void) >>> .size = SZ_512M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_reserve(r2.base, r2.size); >>> - assert(rgn1->base == r1.base); >>> - assert(rgn1->size == r1.size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> + ASSERT_EQ(rgn1->size, r1.size); >>> + >>> + ASSERT_EQ(rgn2->base, r2.base); >>> + ASSERT_EQ(rgn2->size, r2.size); >>> - assert(rgn2->base == r2.base); >>> - assert(rgn2->size == r2.size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, r1.size + r2.size); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == r1.size + r2.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -406,17 +470,22 @@ static int memblock_reserve_overlap_top_check(void) >>> .size = SZ_1G >>> }; >>> + prefix_push(__func__); >>> + >>> total_size = (r1.base - r2.base) + r1.size; >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_reserve(r2.base, r2.size); >>> - assert(rgn->base == r2.base); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r2.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -455,17 +524,22 @@ static int memblock_reserve_overlap_bottom_check(void) >>> .size = SZ_128K >>> }; >>> + prefix_push(__func__); >>> + >>> total_size = (r2.base - r1.base) + r2.size; >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_reserve(r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -502,15 +576,20 @@ static int memblock_reserve_within_check(void) >>> .size = SZ_64K >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_reserve(r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == r1.size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, r1.size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, r1.size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == r1.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -527,19 +606,28 @@ static int memblock_reserve_twice_check(void) >>> .size = SZ_2M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_reserve(r.base, r.size); >>> memblock_reserve(r.base, r.size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == r.size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, r.size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> static int memblock_reserve_checks(void) >>> { >>> + prefix_reset(); >>> + prefix_push(FUNC_RESERVE); >>> + test_print("Running %s tests...\n", FUNC_RESERVE); >>> + >>> memblock_reserve_simple_check(); >>> memblock_reserve_disjoint_check(); >>> memblock_reserve_overlap_top_check(); >>> @@ -547,6 +635,8 @@ static int memblock_reserve_checks(void) >>> memblock_reserve_within_check(); >>> memblock_reserve_twice_check(); >>> + prefix_pop(); >>> + >>> return 0; >>> } >>> @@ -581,16 +671,21 @@ static int memblock_remove_simple_check(void) >>> .size = SZ_4M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_add(r1.base, r1.size); >>> memblock_add(r2.base, r2.size); >>> memblock_remove(r1.base, r1.size); >>> - assert(rgn->base == r2.base); >>> - assert(rgn->size == r2.size); >>> + ASSERT_EQ(rgn->base, r2.base); >>> + ASSERT_EQ(rgn->size, r2.size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == r2.size); >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, r2.size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -626,15 +721,20 @@ static int memblock_remove_absent_check(void) >>> .size = SZ_1G >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_add(r1.base, r1.size); >>> memblock_remove(r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == r1.size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, r1.size); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, r1.size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == r1.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -674,6 +774,8 @@ static int memblock_remove_overlap_top_check(void) >>> .size = SZ_32M >>> }; >>> + prefix_push(__func__); >>> + >>> r1_end = r1.base + r1.size; >>> r2_end = r2.base + r2.size; >>> total_size = r1_end - r2_end; >>> @@ -682,11 +784,14 @@ static int memblock_remove_overlap_top_check(void) >>> memblock_add(r1.base, r1.size); >>> memblock_remove(r2.base, r2.size); >>> - assert(rgn->base == r1.base + r2.base); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r1.base + r2.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, total_size); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -724,17 +829,23 @@ static int memblock_remove_overlap_bottom_check(void) >>> .size = SZ_256M >>> }; >>> + prefix_push(__func__); >>> + >>> total_size = r2.base - r1.base; >>> reset_memblock_regions(); >>> memblock_add(r1.base, r1.size); >>> memblock_remove(r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> + >>> + ASSERT_EQ(memblock.memory.cnt, 1); >>> + ASSERT_EQ(memblock.memory.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> - assert(memblock.memory.cnt == 1); >>> - assert(memblock.memory.total_size == total_size); >>> return 0; >>> } >>> @@ -774,6 +885,8 @@ static int memblock_remove_within_check(void) >>> .size = SZ_1M >>> }; >>> + prefix_push(__func__); >>> + >>> r1_size = r2.base - r1.base; >>> r2_size = (r1.base + r1.size) - (r2.base + r2.size); >>> total_size = r1_size + r2_size; >>> @@ -782,26 +895,35 @@ static int memblock_remove_within_check(void) >>> memblock_add(r1.base, r1.size); >>> memblock_remove(r2.base, r2.size); >>> - assert(rgn1->base == r1.base); >>> - assert(rgn1->size == r1_size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> + ASSERT_EQ(rgn1->size, r1_size); >>> + >>> + ASSERT_EQ(rgn2->base, r2.base + r2.size); >>> + ASSERT_EQ(rgn2->size, r2_size); >>> - assert(rgn2->base == r2.base + r2.size); >>> - assert(rgn2->size == r2_size); >>> + ASSERT_EQ(memblock.memory.cnt, 2); >>> + ASSERT_EQ(memblock.memory.total_size, total_size); >>> - assert(memblock.memory.cnt == 2); >>> - assert(memblock.memory.total_size == total_size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> static int memblock_remove_checks(void) >>> { >>> + prefix_reset(); >>> + prefix_push(FUNC_REMOVE); >>> + test_print("Running %s tests...\n", FUNC_REMOVE); >>> + >>> memblock_remove_simple_check(); >>> memblock_remove_absent_check(); >>> memblock_remove_overlap_top_check(); >>> memblock_remove_overlap_bottom_check(); >>> memblock_remove_within_check(); >>> + prefix_pop(); >>> + >>> return 0; >>> } >>> @@ -835,16 +957,21 @@ static int memblock_free_simple_check(void) >>> .size = SZ_1M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_reserve(r2.base, r2.size); >>> memblock_free((void *)r1.base, r1.size); >>> - assert(rgn->base == r2.base); >>> - assert(rgn->size == r2.size); >>> + ASSERT_EQ(rgn->base, r2.base); >>> + ASSERT_EQ(rgn->size, r2.size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, r2.size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == r2.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -880,15 +1007,20 @@ static int memblock_free_absent_check(void) >>> .size = SZ_128M >>> }; >>> + prefix_push(__func__); >>> + >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_free((void *)r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == r1.size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, r1.size); >>> + >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, r1.size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == r1.size); >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -928,17 +1060,22 @@ static int memblock_free_overlap_top_check(void) >>> .size = SZ_8M >>> }; >>> + prefix_push(__func__); >>> + >>> total_size = (r1.size + r1.base) - (r2.base + r2.size); >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_free((void *)r2.base, r2.size); >>> - assert(rgn->base == r2.base + r2.size); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r2.base + r2.size); >>> + ASSERT_EQ(rgn->size, total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -973,17 +1110,22 @@ static int memblock_free_overlap_bottom_check(void) >>> .size = SZ_32M >>> }; >>> + prefix_push(__func__); >>> + >>> total_size = r2.base - r1.base; >>> reset_memblock_regions(); >>> memblock_reserve(r1.base, r1.size); >>> memblock_free((void *)r2.base, r2.size); >>> - assert(rgn->base == r1.base); >>> - assert(rgn->size == total_size); >>> + ASSERT_EQ(rgn->base, r1.base); >>> + ASSERT_EQ(rgn->size, total_size); >>> - assert(memblock.reserved.cnt == 1); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 1); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> @@ -1024,6 +1166,8 @@ static int memblock_free_within_check(void) >>> .size = SZ_1M >>> }; >>> + prefix_push(__func__); >>> + >>> r1_size = r2.base - r1.base; >>> r2_size = (r1.base + r1.size) - (r2.base + r2.size); >>> total_size = r1_size + r2_size; >>> @@ -1032,26 +1176,35 @@ static int memblock_free_within_check(void) >>> memblock_reserve(r1.base, r1.size); >>> memblock_free((void *)r2.base, r2.size); >>> - assert(rgn1->base == r1.base); >>> - assert(rgn1->size == r1_size); >>> + ASSERT_EQ(rgn1->base, r1.base); >>> + ASSERT_EQ(rgn1->size, r1_size); >>> - assert(rgn2->base == r2.base + r2.size); >>> - assert(rgn2->size == r2_size); >>> + ASSERT_EQ(rgn2->base, r2.base + r2.size); >>> + ASSERT_EQ(rgn2->size, r2_size); >>> - assert(memblock.reserved.cnt == 2); >>> - assert(memblock.reserved.total_size == total_size); >>> + ASSERT_EQ(memblock.reserved.cnt, 2); >>> + ASSERT_EQ(memblock.reserved.total_size, total_size); >>> + >>> + test_pass(); >>> + prefix_pop(); >>> return 0; >>> } >>> static int memblock_free_checks(void) >>> { >>> + prefix_reset(); >>> + prefix_push(FUNC_FREE); >>> + test_print("Running %s tests...\n", FUNC_FREE); >>> + >>> memblock_free_simple_check(); >>> memblock_free_absent_check(); >>> memblock_free_overlap_top_check(); >>> memblock_free_overlap_bottom_check(); >>> memblock_free_within_check(); >>> + prefix_pop(); >>> + >>> return 0; >>> } >>> diff --git a/tools/testing/memblock/tests/common.c b/tools/testing/memblock/tests/common.c >>> index 62d3191f7c9a..e55b2a8bf0ff 100644 >>> --- a/tools/testing/memblock/tests/common.c >>> +++ b/tools/testing/memblock/tests/common.c >>> @@ -4,8 +4,12 @@ >>> #define INIT_MEMBLOCK_REGIONS 128 >>> #define INIT_MEMBLOCK_RESERVED_REGIONS INIT_MEMBLOCK_REGIONS >>> +#define PREFIXES_LEN_MAX 256 >>> +#define DELIM ": " >>> +#define DELIM_LEN strlen(DELIM) >>> static struct test_memory memory_block; >>> +static char __maybe_unused prefixes[PREFIXES_LEN_MAX]; >>> void reset_memblock_regions(void) >>> { >>> @@ -46,3 +50,57 @@ void dummy_physical_memory_cleanup(void) >>> { >>> free(memory_block.base); >>> } >>> + >>> +#ifdef VERBOSE >>> +void test_fail(void) >>> +{ >>> + ksft_test_result_fail(": %sfailed\n", prefixes); >>> +} >>> + >>> +void test_pass(void) >>> +{ >>> + ksft_test_result_pass(": %spassed\n", prefixes); >>> +} >>> + >>> +void test_print(const char *fmt, ...) >>> +{ >>> + int saved_errno = errno; >>> + va_list args; >>> + >>> + va_start(args, fmt); >>> + errno = saved_errno; >>> + vprintf(fmt, args); >>> + va_end(args); >>> +} >>> + >>> +void prefix_reset(void) >>> +{ >>> + memset(prefixes, 0, PREFIXES_LEN_MAX); >>> +} >>> + >>> +void prefix_push(const char *prefix) >>> +{ >>> + int prefix_max = PREFIXES_LEN_MAX - strlen(prefixes) - DELIM_LEN - 1; >>> + >>> + assert(strlen(prefix) <= prefix_max); >>> + strncat(prefixes, prefix, prefix_max); >>> + strncat(prefixes, DELIM, PREFIXES_LEN_MAX - strlen(prefixes) - 1); >>> +} >>> + >>> +void prefix_pop(void) >>> +{ >>> + char *ptr; >>> + >>> + ptr = strrchr(prefixes, DELIM[0]); >>> + if (!ptr) >>> + prefixes[0] = 0; >>> + else >>> + *(ptr) = 0; >>> + >>> + ptr = strrchr(prefixes, DELIM[0]); >>> + if (!ptr) >>> + prefixes[0] = 0; >>> + else >>> + *(ptr + DELIM_LEN) = 0; >>> +} >>> +#endif /* VERBOSE */ >>> diff --git a/tools/testing/memblock/tests/common.h b/tools/testing/memblock/tests/common.h >>> index 619054d03219..bdddb5f72871 100644 >>> --- a/tools/testing/memblock/tests/common.h >>> +++ b/tools/testing/memblock/tests/common.h >>> @@ -7,9 +7,47 @@ >>> #include >>> #include >>> #include >>> +#include >>> +#include <../selftests/kselftest.h> >>> #define MEM_SIZE SZ_16K >>> +/** >>> + * ASSERT_EQ(): >>> + * Check the condition >>> + * @_expected == @_seen >>> + * If false, print failed test message (if in VERBOSE mode) and then assert >>> + */ >>> +#define ASSERT_EQ(_expected, _seen) do { \ >>> + if ((_expected) != (_seen)) \ >>> + test_fail(); \ >>> + assert((_expected) == (_seen)); \ >>> +} while (0) >>> + >>> +/** >>> + * ASSERT_NE(): >>> + * Check the condition >>> + * @_expected != @_seen >>> + * If false, print failed test message (if in VERBOSE mode) and then assert >>> + */ >>> +#define ASSERT_NE(_expected, _seen) do { \ >>> + if ((_expected) == (_seen)) \ >>> + test_fail(); \ >>> + assert((_expected) != (_seen)); \ >>> +} while (0) >>> + >>> +/** >>> + * ASSERT_LT(): >>> + * Check the condition >>> + * @_expected < @_seen >>> + * If false, print failed test message (if in VERBOSE mode) and then assert >>> + */ >>> +#define ASSERT_LT(_expected, _seen) do { \ >>> + if ((_expected) >= (_seen)) \ >>> + test_fail(); \ >>> + assert((_expected) < (_seen)); \ >>> +} while (0) >>> + >>> /* >>> * Available memory registered with memblock needs to be valid for allocs >>> * test to run. This is a convenience wrapper for memory allocated in >>> @@ -31,4 +69,20 @@ void setup_memblock(void); >>> void dummy_physical_memory_init(void); >>> void dummy_physical_memory_cleanup(void); >>> +#ifdef VERBOSE >>> +void test_fail(void); >>> +void test_pass(void); >>> +void test_print(const char *fmt, ...); >>> +void prefix_reset(void); >>> +void prefix_push(const char *prefix); >>> +void prefix_pop(void); >>> +#else >>> +static inline void test_fail(void) {} >>> +static inline void test_pass(void) {} >>> +static inline void test_print(const char *fmt, ...) {} >>> +static inline void prefix_reset(void) {} >>> +static inline void prefix_push(const char *prefix) {} >>> +static inline void prefix_pop(void) {} >>> +#endif /* VERBOSE */ >>> + >>> #endif >