From c14fe623a22bb059d5b6401fd357c275bdae1664 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=B1=9F=E5=92=8C=E6=9D=BE?= <32100330+Darkness303@users.noreply.github.com> Date: Thu, 27 Feb 2020 21:02:03 +0800 Subject: [PATCH] Solve the problem of core dumped when using large-scale data in benchmark test MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit E.g : when running test calse such as below in benchmark: ./dgesv.goto 100000 100000 100000 From : 100000 To : 100000 Step = 100000 Trans = 'N' Inc_x = 1 Inc_y = 1 Loops = 1 SIZE Flops 100000 : Segmentation fault (core dumped) Because i+j*m has exceeded the maximum range of int --- benchmark/gesv.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/benchmark/gesv.c b/benchmark/gesv.c index 26ff8bc1a..80f644e69 100644 --- a/benchmark/gesv.c +++ b/benchmark/gesv.c @@ -177,20 +177,20 @@ int main(int argc, char *argv[]){ for(j = 0; j < m; j++){ for(i = 0; i < m * COMPSIZE; i++){ - a[i + j * m * COMPSIZE] = ((FLOAT) rand() / (FLOAT) RAND_MAX) - 0.5; + a[(long)i + (long)j * (long)m * COMPSIZE] = ((FLOAT) rand() / (FLOAT) RAND_MAX) - 0.5; } } for(j = 0; j < m; j++){ for(i = 0; i < m * COMPSIZE; i++){ - b[i + j * m * COMPSIZE] = 0.0; + b[(long)i + (long)j * (long)m * COMPSIZE] = 0.0; } } for (j = 0; j < m; ++j) { for (i = 0; i < m * COMPSIZE; ++i) { - b[i] += a[i + j * m * COMPSIZE]; + b[i] += a[(long)i + (long)j * (long)m * COMPSIZE]; } }