/* Copyright (C) 2021-2024 Free Software Foundation, Inc. Contributed by Oracle. This file is part of GNU Binutils. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. */ #include #include #include #include "stopwatch.h" /*=======================================================*/ /* pagethrash - allocate some memory, and thrash around in it */ int pagethrash (int thrashmb) { char buf[1024]; hrtime_t start = gethrtime (); hrtime_t vstart = gethrvtime (); /* Log the event */ wlog ("start of pagethrash", NULL); /* Start a stopwatch */ stopwatch_t *w = stpwtch_alloc ("pagethrash", 0); /* compute the size */ unsigned long size = thrashmb * 1024 * 1024; int pagesize = getpagesize (); void *space = malloc (size + pagesize); if (space == NULL) { fprintf (stderr, "\tpagethrash failed; can't get %ld bytes.\n", size); exit (1); } /* round address to page boundary */ unsigned long loc = (((unsigned long) space + pagesize - 1) & ~(pagesize - 1)); long npages = size / pagesize; /* touch all the pages to force them in */ for (long i = 0; i < npages; i++) { stpwtch_start (w); *(int *) (loc + i * pagesize) = i; stpwtch_stop (w); } /* now free up the space */ free (space); /* print the timing results */ stpwtch_print (w); free ((void *) w); sprintf (buf, "pagethrash: %ld pages", npages); whrvlog (gethrtime () - start, gethrvtime () - vstart, buf, NULL); return 0; }