You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I see two problems with this: first, the vector in this case only contains 5 entries, so accessing QR_ii[Type.Int] would lead to an error that does not tell the user much.
Second, QR_ii contains 5 elements, but only 4 of them are initialized. The last one defaults to a NULL pointer, and when the function is called this leads to a segfault or kernel crash. This makes debugging very hard.
Here is a suggestion to add fallback implementations of all internal functions in order to make things more solid:
In src/backend/linalg_internal_interface.cpp:
manuschneider
changed the title
linalg internal uses zero pointers for undefined functions
linalg internal uses NULL pointers for undefined functions
Oct 2, 2024
Many xx_cd, xx_cf, ... functions, do similar things. The other way to ease the pain is letting the callers take the responsibility of type checking. And then templatize xx_cd, xx_cf, ... functions or use function overload: xx(int value) {}, xx(double value). By doing so, some error will be caught at the compile time.
Indeed, it would be possible to not provide these function pointer vectors and let the calling function handle things. But then the calling function needs to have some switch - case statement everywhere to call the correct function. I think the current implementation is more convenient, one can just call QR_ii[dtype] for a generic dtype. But the current implementation is not very robust because of the NULL pointers and vectors that are shorter than N_Type.
Function overloading would be a clean way to implement things, but does not work here unfortunately. The function arguments are tensors, and the implementation depends on their dtype. So the function arguments always have the same types.
The only alternative I can think of is to provide only one function that checks the dtype of the input tensors and changes the behavior accordingly/calls the correct function (maybe a bit slower though).
Here is an example of the current behavior of many backend functions for different dtyes:
in
src/backend/linalg_internal_interface.hpp
, a vector containing function pointers is created:Then, in
src/backend/linalg_internal_interface.cpp
, this vector is filled with the implementations for the different dtypes:I see two problems with this: first, the vector in this case only contains 5 entries, so accessing
QR_ii[Type.Int]
would lead to an error that does not tell the user much.Second,
QR_ii
contains 5 elements, but only 4 of them are initialized. The last one defaults to aNULL
pointer, and when the function is called this leads to a segfault or kernel crash. This makes debugging very hard.Here is a suggestion to add fallback implementations of all internal functions in order to make things more solid:
In
src/backend/linalg_internal_interface.cpp
:In
src/backend/linalg_internal_cpu/QR_internal.hpp
:In
src/backend/linalg_internal_cpu/QR_internal.cpp
:However, this would have to be done for many internal functions in the backend.
The text was updated successfully, but these errors were encountered: