%implements "genrtnonfinite" "C"
%function rtIsInf(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function rtIsInfF(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function rtIsNaN(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function rtIsNaNF(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function CodeForBinary64NaNCheck(endianAwareStruct)
%return "/
union {/
%<endianAwareStruct> bitVal;/
real_T fltVal;/
} tmpVal;/
tmpVal.fltVal = value;/
result = (boolean_T)((tmpVal.bitVal.words.wordH & 0x7FF00000) == 0x7FF00000 &&/
( (tmpVal.bitVal.words.wordH & 0x000FFFFF) != 0 ||/
(tmpVal.bitVal.words.wordL != 0) ));/
"
%endfunction
%function CodeForSwitchOnEndianness(codeForLittleEndian, codeForBigEndian) Output
%if ConfigSet.TargetEndianess == "Unspecified" || ConfigSet.PortableWordSizes == 1
uint16_T one = 1U;
enum {
LittleEndian,
BigEndian
} machByteOrder = (*((uint8_T *) &one) == 1U) ? LittleEndian : BigEndian;
switch (machByteOrder) {
case LittleEndian: {
%<codeForLittleEndian>
break;
}
case BigEndian: {
%<codeForBigEndian>
break;
}
}
%elseif ConfigSet.TargetEndianess == "LittleEndian"
%<codeForLittleEndian>
%elseif ConfigSet.TargetEndianess == "BigEndian"
%<codeForBigEndian>
%else
%openfile errTxt
Unsupported Target Endianess: %<ConfigSet.TargetEndianess>
%closefile errTxt
%<LibReportFatalError(errTxt)>
%endif
%endfunction
%function gen_rtInf(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function gen_rtInfF(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function gen_rtMinusInf(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function gen_rtMinusInfF(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function gen_rtNaN(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function gen_rtNaNF(fctInfo,fileH,fileC) void
%<rt_InitInfAndNaN(fctInfo,fileH,fileC)>
%endfunction
%function rt_InitInfAndNaN(fctInfo,fileH,fileC) void
%if EXISTS(CustomNonFinites)
%if FILE_EXISTS(CustomNonFinites)
%include CustomNonFinites
%return
%else
%assign customFilePath = FEVAL("which", CustomNonFinites)
%if (TYPE(customFilePath) == "String") && FILE_EXISTS(customFilePath)
%include customFilePath
%return
%else
%assign warnTxt = "The CustomNonFinites file, '%'," ...
" was specified, however, the file does not exist. Generating " ...
"the default nonfinite support."
%<LibReportWarning(warnTxt)>
%endif
%endif
%endif
%openfile buf
/*
* %<fctInfo.FileName>.h
*
%<SLibCommonUtilHeaderInfo()>/
*/
%closefile buf
%<SLibCacheUtilCodeToFile("util_hdr_banner", fileH, buf)>
%<SLibCacheUtilCodeToFile("util_hdr_reqed_incl", fileH, "")>
%openfile buf
#include "%<SLibCoderTypesFilename()>"
%closefile buf
%<SLibCacheUtilCodeToFile("util_hdr_incl", fileH, buf)>
%assign msFcn = SLibGetMemSecCategoryForUtilityFcn()
%openfile buf
%<FcnGenOpenExternCForCPP()>
%<SLibApplyMemSecToDataDecl("real_T rtInf;", "MemSecDataParameters", "rtInf")>
%<SLibApplyMemSecToDataDecl("real_T rtMinusInf;", "MemSecDataParameters", "rtMinusInf")>
%<SLibApplyMemSecToDataDecl("real_T rtNaN;", "MemSecDataParameters", "rtNaN")>
%<SLibApplyMemSecToDataDecl("real32_T rtInfF;", "MemSecDataParameters", "rtInfF")>
%<SLibApplyMemSecToDataDecl("real32_T rtMinusInfF;", "MemSecDataParameters", "rtMinusInfF")>
%<SLibApplyMemSecToDataDecl("real32_T rtNaNF;", "MemSecDataParameters", "rtNaNF")>
%<SLibGetFcnMemSecPragmaOnDecl("rt_InitInfAndNaN", msFcn, "Pre")>/
%<LibStaticOrExternInFcnDecls()>void rt_InitInfAndNaN(size_t realSize);
%<SLibGetFcnMemSecPragmaOnDecl("rt_InitInfAndNaN", msFcn, "Post")>/
%<SLibGetFcnMemSecPragmaOnDecl("rtIsInf", msFcn, "Pre")>/
%<LibStaticOrExternInFcnDecls()>boolean_T rtIsInf(real_T value);
%<SLibGetFcnMemSecPragmaOnDecl("rtIsInf", msFcn, "Post")>/
%<SLibGetFcnMemSecPragmaOnDecl("rtIsInfF", msFcn, "Pre")>/
%<LibStaticOrExternInFcnDecls()>boolean_T rtIsInfF(real32_T value);
%<SLibGetFcnMemSecPragmaOnDecl("rtIsInfF", msFcn, "Post")>/
%<SLibGetFcnMemSecPragmaOnDecl("rtIsNaN", msFcn, "Pre")>/
%<LibStaticOrExternInFcnDecls()>boolean_T rtIsNaN(real_T value);
%<SLibGetFcnMemSecPragmaOnDecl("rtIsNaN", msFcn, "Post")>/
%<SLibGetFcnMemSecPragmaOnDecl("rtIsNaNF", msFcn, "Pre")>/
%<LibStaticOrExternInFcnDecls()>boolean_T rtIsNaNF(real32_T value);
%<SLibGetFcnMemSecPragmaOnDecl("rtIsNaNF", msFcn, "Post")>/
typedef struct {
struct {
uint32_T wordH;
uint32_T wordL;
} words;
} BigEndianIEEEDouble;
typedef struct {
struct {
uint32_T wordL;
uint32_T wordH;
} words;
} LittleEndianIEEEDouble;
typedef struct {
union {
real32_T wordLreal;
uint32_T wordLuint;
} wordL;
} IEEESingle;
%<FcnGenCloseExternCForCPP()>
%closefile buf
%<SLibCacheUtilCodeToFile("util_hdr_infnan_decl", fileH, buf)>
%<LibPushEmptyStackSharedUtils()>
%assign rtGetNaNDblInfo = SLibGenOneInputOneOutputFcnCallInfo("getNaN",tSS_VOID,tSS_DOUBLE,"")
%assign rtGetNaNSglInfo = SLibGenOneInputOneOutputFcnCallInfo("getNaN",tSS_VOID,tSS_SINGLE,"")
%assign rtGetInfDblInfo = SLibGenOneInputOneOutputFcnCallInfo("getInf",tSS_VOID,tSS_DOUBLE,"")
%assign rtGetInfSglInfo = SLibGenOneInputOneOutputFcnCallInfo("getInf",tSS_VOID,tSS_SINGLE,"")
%assign rtGetMinusInfDblInfo = SLibGenOneInputOneOutputFcnCallInfo("getMinusInf",tSS_VOID,tSS_DOUBLE,"")
%assign rtGetMinusInfSglInfo = SLibGenOneInputOneOutputFcnCallInfo("getMinusInf",tSS_VOID,tSS_SINGLE,"")
%assign nonfiniteIncludes = FcnDumpSharedUtilsIncludes()
%assign derivStackBuf = LibPopStackSharedUtilsIncludes()
%openfile buf
/*
* %<fctInfo.FileName>.%<LangFileExt>
*
%<SLibCommonUtilHeaderInfo()>/
*/
%closefile buf
%<SLibCacheUtilCodeToFile("util_src_banner", fileC, buf)>
%openfile buf
/*
* Abstract:
* Function to initialize non-finites,
* (Inf, NaN and -Inf).
*/
%if ((GenUtilsSrcInSharedLocation == 1) || !SLibIsCompactFileFormat())
#include "rt_nonfinite.h"
%endif
%<nonfiniteIncludes>
%closefile buf
%<SLibCacheUtilCodeToFile("util_src_incl", fileC, buf)>
%openfile buf
#define NumBitsPerChar %<::CompiledModel.ConfigSet.ProdBitPerChar>U
%closefile buf
%<SLibCacheMacroToUtilityFile("NumBitsPerChar", buf, "util_src_defines", fileC)>
%openfile buf
%if GenCPP
extern "C" {
%endif
%<SLibApplyMemSecToDataDefn("real_T rtInf;", "MemSecDataParameters", "rtInf")>
%<SLibApplyMemSecToDataDefn("real_T rtMinusInf;", "MemSecDataParameters", "rtMinusInf")>
%<SLibApplyMemSecToDataDefn("real_T rtNaN;", "MemSecDataParameters", "rtNaN")>
%<SLibApplyMemSecToDataDefn("real32_T rtInfF;", "MemSecDataParameters", "rtInfF")>
%<SLibApplyMemSecToDataDefn("real32_T rtMinusInfF;", "MemSecDataParameters", "rtMinusInfF")>
%<SLibApplyMemSecToDataDefn("real32_T rtNaNF;", "MemSecDataParameters", "rtNaNF")>
%if GenCPP
}
%endif
%closefile buf
%<SLibCacheUtilCodeToFile("util_src_decl", fileC, buf)>
%openfile buf
%if GenCPP
extern "C" {
%endif
%assign fcnName = "rt_InitInfAndNaN"
%assign fcnReturns = "void"
%assign fcnParams = "size_t realSize"
%assign functionSpecifier = LibStaticInFcnDecls()
%openfile fcnAbstract
Initialize the rtInf, rtMinusInf, and rtNaN needed by the
generated code. NaN is initialized as non-signaling. Assumes IEEE.
%closefile fcnAbstract
%createrecord fcnRec {Name fcnName; Returns fcnReturns; Params fcnParams; ...
Abstract fcnAbstract; Category "utility"; GeneratedBy "genrtnonfinite.tlc"}
%<SLibDumpFunctionBanner(fcnRec)>
%undef fcnRec
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Pre")>/
%<functionSpecifier> %<fcnReturns> %<fcnName>(%<fcnParams>) {
(void) (realSize);
rtNaN = %<rtGetNaNDblInfo.Expr>;
rtNaNF = %<rtGetNaNSglInfo.Expr>;
rtInf = %<rtGetInfDblInfo.Expr>;
rtInfF = %<rtGetInfSglInfo.Expr>;
rtMinusInf = %<rtGetMinusInfDblInfo.Expr>;
rtMinusInfF = %<rtGetMinusInfSglInfo.Expr>;
}
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Post")>/
%assign fcnName = "rtIsInf"
%assign fcnReturns = "boolean_T"
%assign fcnParams = "real_T value"
%assign fcnAbstract = "Test if value is infinite"
%assign functionSpecifier = LibStaticInFcnDecls()
%createrecord fcnRec {Name fcnName; Returns fcnReturns; Params fcnParams; ...
Abstract fcnAbstract; Category "utility"; GeneratedBy "genrtnonfinite.tlc"}
%<SLibDumpFunctionBanner(fcnRec)>
%undef fcnRec
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Pre")>/
%<functionSpecifier> %<fcnReturns> %<fcnName>(%<fcnParams>) {
return (boolean_T)((value==rtInf || value==rtMinusInf) ? 1U : 0U);
}
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Post")>/
%assign fcnName = "rtIsInfF"
%assign fcnReturns = "boolean_T"
%assign fcnParams = "real32_T value"
%assign fcnAbstract = "Test if single-precision value is infinite"
%assign functionSpecifier = LibStaticInFcnDecls()
%createrecord fcnRec {Name fcnName; Returns fcnReturns; Params fcnParams; ...
Abstract fcnAbstract; Category "utility"; GeneratedBy "genrtnonfinite.tlc"}
%<SLibDumpFunctionBanner(fcnRec)>
%undef fcnRec
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Pre")>/
%<functionSpecifier> %<fcnReturns> %<fcnName>(%<fcnParams>) {
return (boolean_T)(((value)==rtInfF || (value)==rtMinusInfF) ? 1U : 0U);
}
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Post")>/
%assign fcnName = "rtIsNaN"
%assign fcnReturns = "boolean_T"
%assign fcnParams = "real_T value"
%assign fcnAbstract = "Test if value is not a number"
%assign functionSpecifier = LibStaticInFcnDecls()
%createrecord fcnRec {Name fcnName; Returns fcnReturns; Params fcnParams; ...
Abstract fcnAbstract; Category "utility"; GeneratedBy "genrtnonfinite.tlc"}
%<SLibDumpFunctionBanner(fcnRec)>
%undef fcnRec
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Pre")>/
%<functionSpecifier> %<fcnReturns> %<fcnName>(%<fcnParams>) {
boolean_T result = (boolean_T) 0;
size_t bitsPerReal = sizeof(real_T) * (NumBitsPerChar);
if (bitsPerReal == 32U) {
result = rtIsNaNF((real32_T)value);
} else {
%assign codeForLittleEndian = CodeForBinary64NaNCheck("LittleEndianIEEEDouble")
%assign codeForBigEndian = CodeForBinary64NaNCheck("BigEndianIEEEDouble")
%<CodeForSwitchOnEndianness(codeForLittleEndian, codeForBigEndian)>
}
return result;
}
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Post")>/
%assign fcnName = "rtIsNaNF"
%assign fcnReturns = "boolean_T"
%assign fcnParams = "real32_T value"
%assign fcnAbstract = "Test if single-precision value is not a number"
%assign functionSpecifier = LibStaticInFcnDecls()
%createrecord fcnRec {Name fcnName; Returns fcnReturns; Params fcnParams; ...
Abstract fcnAbstract; Category "utility"; GeneratedBy "genrtnonfinite.tlc"}
%<SLibDumpFunctionBanner(fcnRec)>
%undef fcnRec
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Pre")>/
%<functionSpecifier> %<fcnReturns> %<fcnName>(%<fcnParams>) {
IEEESingle tmp;
tmp.wordL.wordLreal = value;
return (boolean_T)( (tmp.wordL.wordLuint & 0x7F800000) == 0x7F800000 &&
(tmp.wordL.wordLuint & 0x007FFFFF) != 0 );
}
%<SLibGetFcnMemSecPragma(fcnName, msFcn, "Post")>/
%if GenCPP
}
%endif
%closefile buf
%<SLibCacheUtilCodeToFile("util_src_fcn_defn", fileC, buf)>
%endfunction