2.2 Error Handling

All driver functions provide a basic error trapping mechanism that stores the last reported error in the driver. If your application is not behaving properly, you can check for the last error by calling the function DSCGetLastError. This function takes an ERRPARAMS structure pointer as its argument. Nearly all of the available functions in the SAMD51 API return a BYTE value upon completion. This value represents an error code that will inform you as to whether or not the function call was successful. You should always check if the result returns a DE_NONE value (signifying that no errors were reported), as the code below illustrates:

BYTE result;
ERRPARAMS errparams;
BYTE Board_type;

if ((result = DSCSAM_InitBoard(&Board_type)) != DE_NONE)
{
    DSCGetLastError(&errparams);
    printf ( "DSCSAM_InitBoard error: %s %s\n", DSCGetErrorString ( errparams.ErrCode ), errparams.errstring );
    return 0;
}

In this code snippet, the BYTE result of executing a particular driver function (DSCSAM_InitBoard in this case) is stored and checked against the expected return value (DE_NONE). Anytime a function does not complete successfully, an error code other than DE_NONE will be generated, and the current API function will terminate. The function DSCGetErrorString provides a description of the error that occurred.

Last updated