/* Copyright (C) 2021-2023 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 "mydefs.h" /* * ----------------------------------------------------------------------------- * This function determines the number of rows each thread will be working on * and also how many threads will be active. * ----------------------------------------------------------------------------- */ void get_workload_stats (int64_t number_of_threads, int64_t number_of_rows, int64_t number_of_columns, int64_t *rows_per_thread, int64_t *remainder_rows, int64_t *active_threads) { if (number_of_threads <= number_of_rows) { *remainder_rows = number_of_rows%number_of_threads; *rows_per_thread = (number_of_rows - (*remainder_rows))/number_of_threads; } else { *remainder_rows = 0; *rows_per_thread = 1; } *active_threads = number_of_threads < number_of_rows ? number_of_threads : number_of_rows; if (verbose) { printf ("Rows per thread = %ld remainder = %ld\n", *rows_per_thread, *remainder_rows); printf ("Number of active threads = %ld\n", *active_threads); } } /* * ----------------------------------------------------------------------------- * This function determines which rows each thread will be working on. * ----------------------------------------------------------------------------- */ void determine_work_per_thread (int64_t TID, int64_t rows_per_thread, int64_t remainder_rows, int64_t *row_index_start, int64_t *row_index_end) { int64_t chunk_per_thread; if (TID < remainder_rows) { chunk_per_thread = rows_per_thread + 1; *row_index_start = TID * chunk_per_thread; *row_index_end = (TID + 1) * chunk_per_thread - 1; } else { chunk_per_thread = rows_per_thread; *row_index_start = remainder_rows * (rows_per_thread + 1) + (TID - remainder_rows) * chunk_per_thread; *row_index_end = remainder_rows * (rows_per_thread + 1) + (TID - remainder_rows) * chunk_per_thread + chunk_per_thread - 1; } if (verbose) { printf ("TID = %ld row_index_start = %ld row_index_end = %ld\n", TID, *row_index_start, *row_index_end); } }