donat.nagy marked 7 inline comments as done.
donat.nagy added a comment.

I found a solution for determining the precision value of a floating point 
type. Is this acceptable?



================
Comment at: lib/StaticAnalyzer/Checkers/ConversionChecker.cpp:163
+
+    switch (FloatingSize) {
+      case 64:
----------------
NoQ wrote:
> donat.nagy wrote:
> > NoQ wrote:
> > > Continuing the float semantics discussion on the new revision - Did you 
> > > consider `llvm::APFloat`? 
> > > (http://llvm.org/doxygen/classllvm_1_1APFloat.html) This looks like 
> > > something that you're trying to re-implement.
> > This switch statement essentially fulfills two functions: it maps QualTypes 
> > to standardized IEEE floating point types and it immediately maps the 
> > standardized IEEE types to  their precision values.
> > 
> > The difficulty is that I don't think that the first map is available as a 
> > public function in the clang libraries. This means that although a switch 
> > over the bit width of the floating point type is certainly inelegant, I 
> > cannot avoid it.
> > 
> > The second map is available in the APFloat library (via the 
> > llvm::fltSemantics constants, which describe the standard IEEE types). 
> > However, this map is extremely stable (e.g. I don't think that the binary 
> > structure of the IEEE double type will ever change), so I think that 
> > re-implementing it is justified by the fact that it yields shorter and 
> > cleaner code. However, as I had noted previously, I am open to using the 
> > llvm::fltSemantics constants to implement this mapping.
> > 
> > As an additional remark, my current code supports the _Float16 type, which 
> > is currently not supported by the APFloat/fltSemantics library. If we 
> > decide to use the llvm::fltSemantics constants, then we must either extend 
> > the APFloat library or apply some workarounds for this case.  
> > 
> > The difficulty is that I don't think that the first map is available as a 
> > public function in the clang libraries. This means that although a switch 
> > over the bit width of the floating point type is certainly inelegant, I 
> > cannot avoid it.
> 
> `fltSemantics` are not just enum constants, [[ 
> http://llvm.org/doxygen/structllvm_1_1fltSemantics.html | they contain a lot 
> of fancy data ]]:
> ```
>    static const fltSemantics semIEEEhalf = {15, -14, 11, 16};
>    static const fltSemantics semIEEEsingle = {127, -126, 24, 32};
>    static const fltSemantics semIEEEdouble = {1023, -1022, 53, 64};
>    static const fltSemantics semIEEEquad = {16383, -16382, 113, 128};
>    static const fltSemantics semX87DoubleExtended = {16383, -16382, 64, 80};
> ```
I knew about the data members of fltSemantics, but I did not see a way to use 
them elegantly (although fltSemantics has sizeInBits as a member, the possible 
fltSemantics values are not collected into one data structure, so I could not 
look up the precision field).

However, as I examined the APFloat.h source again, I found the function 
llvm::APFloat::getAllOnesValue which allows me to map bit width to semantics. 
While this is a somewhat indirect solution, it avoids using a switch.

The `missing _Float16' problem mentioned in my previous comments was my 
mistake, somehow I managed to overlook semIEEEhalf.


Repository:
  rC Clang

https://reviews.llvm.org/D52730



_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to