Segfault when using Tonemapping on completely black data, fixes #4934
This commit is contained in:
@@ -941,7 +941,7 @@ void EdgePreservingDecomposition::CompressDynamicRange(float *Source, float Scal
|
|||||||
cev = xexpf(LVFU(Source[i]) + LVFU(u[i]) * (tempv)) - epsv;
|
cev = xexpf(LVFU(Source[i]) + LVFU(u[i]) * (tempv)) - epsv;
|
||||||
uev = xexpf(LVFU(u[i])) - epsv;
|
uev = xexpf(LVFU(u[i])) - epsv;
|
||||||
sourcev = xexpf(LVFU(Source[i])) - epsv;
|
sourcev = xexpf(LVFU(Source[i])) - epsv;
|
||||||
_mm_storeu_ps( &Source[i], cev + DetailBoostv * (sourcev - uev) );
|
_mm_storeu_ps( &Source[i], vmaxf(cev + DetailBoostv * (sourcev - uev), ZEROV));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -949,7 +949,7 @@ void EdgePreservingDecomposition::CompressDynamicRange(float *Source, float Scal
|
|||||||
float ce = xexpf(Source[i] + u[i] * (temp)) - eps;
|
float ce = xexpf(Source[i] + u[i] * (temp)) - eps;
|
||||||
float ue = xexpf(u[i]) - eps;
|
float ue = xexpf(u[i]) - eps;
|
||||||
Source[i] = xexpf(Source[i]) - eps;
|
Source[i] = xexpf(Source[i]) - eps;
|
||||||
Source[i] = ce + DetailBoost * (Source[i] - ue);
|
Source[i] = rtengine::max(ce + DetailBoost * (Source[i] - ue), 0.f);
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
@@ -961,7 +961,7 @@ void EdgePreservingDecomposition::CompressDynamicRange(float *Source, float Scal
|
|||||||
float ce = xexpf(Source[i] + u[i] * (temp)) - eps;
|
float ce = xexpf(Source[i] + u[i] * (temp)) - eps;
|
||||||
float ue = xexpf(u[i]) - eps;
|
float ue = xexpf(u[i]) - eps;
|
||||||
Source[i] = xexpf(Source[i]) - eps;
|
Source[i] = xexpf(Source[i]) - eps;
|
||||||
Source[i] = ce + DetailBoost * (Source[i] - ue);
|
Source[i] = rtengine::max(ce + DetailBoost * (Source[i] - ue), 0.f);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Reference in New Issue
Block a user