Commits

Jed Brown committed 75d1f5b Merge

Merge branch 'jed/fix-mat-sbaij-sor-prefetch' into maint

* jed/fix-mat-sbaij-sor-prefetch:
Mat SBAIJ: avoid invalid memory read in MatSOR_SBAIJ

  • Participants
  • Parent commits 3b77805, 6c11f90

Comments (0)

Files changed (1)

File src/mat/impls/sbaij/seq/relax.h

         nz = 0;
         for (i=m-1; i>=0; i--) {
           sum = b[i];
-          nz2 = ai[i] - ai[i-1] - 1;
+          nz2 = ai[i] - ai[PetscMax(i-1,0)] - 1; /* avoid referencing ai[-1], nonsense nz2 is okay on last iteration */
           PETSC_Prefetch(v-nz2-1,0,PETSC_PREFETCH_HINT_NTA);
           PETSC_Prefetch(vj-nz2-1,0,PETSC_PREFETCH_HINT_NTA);
           PetscSparseDenseMinusDot(sum,x,v,vj,nz);
         nz = 0;
         for (i=m-1; i>=0; i--) {
           sum = t[i];
-          nz2 = ai[i] - ai[i-1] - 1;
+          nz2 = ai[i] - ai[PetscMax(i-1,0)] - 1; /* avoid referencing ai[-1], nonsense nz2 is okay on last iteration */
           PETSC_Prefetch(v-nz2-1,0,PETSC_PREFETCH_HINT_NTA);
           PETSC_Prefetch(vj-nz2-1,0,PETSC_PREFETCH_HINT_NTA);
           PetscSparseDenseMinusDot(sum,x,v,vj,nz);