craig.topper added inline comments.

================
Comment at: clang/include/clang/Basic/riscv_vector.td:66
+//      element type which is bool
+//   0: void type, ignores "t"
+//   z: size_t, ignores "t"
----------------
jrtc27 wrote:
> craig.topper wrote:
> > jrtc27 wrote:
> > > khchen wrote:
> > > > jrtc27 wrote:
> > > > > Then why aren't these just base types? We don't have to follow the 
> > > > > brain-dead nature of printf.
> > > > Basically builtin interface is instantiated by the "base type + LMUL" 
> > > > with type transformers. But in some intrinsic function we need a 
> > > > specific type regardless "base type + LMUL"
> > > > ex. `vuint32m2_t vssrl_vx_u32m2_vl (vuint32m2_t op1, uint8_t op2, 
> > > > size_t vl);`
> > > Then fix the way you define these? This is just bad design IMO.
> > For each signature there is effectively a single key type that is a vector. 
> > The type transformer is a list of rules for how to derive all of the other 
> > operands from that one key type. Conceptually similar to 
> > LLVMScalarOrSameVectorWidth or LLVMHalfElementsVectorType in Intrinsics.td. 
> > Some types are fixed and don't vary by the key type. Like the size_t vl 
> > operand or a store intrinsic returning void.  There is no separate place to 
> > put a base type.
> Oh I see, I hadn't appreciated that TypeRange got split up and each character 
> was a whole separate intrinsic, I had misinterpreted it as it being a list of 
> the types of arguments, i.e. an N-character string for an (N-1)-argument 
> (plus return type) intrinsic that you could then use as a base and apply 
> transformations too (e.g. "if" for a float-to-int intrinsic, with "vv" etc 
> giving you a vectorised versions) and so was confused as to why the 
> void/size_t/ptrdiff_t/uint8_t/bool-ness couldn't just be pushed into the 
> TypeRange and the corresponding transforms left as "e". But, how _would_ you 
> define vector float-to-int (and back) conversions with this scheme then?
> 
> On a related note, I feel one way to make this less obfuscated is change 
> v/w/q/o to be v1/v2/v4/v8 (maybe with the 1 being optional, don't really 
> care), and is also more extensible in future rather than ending up with yet 
> more alphabet soup, though it does change the parsing from being a list of 
> characters to a list of strings.
I think these transforms are used for the float-to-int and int-to-float. 

//   I: given a vector type, compute the vector type with integer type
//      elements of the same width
//   F: given a vector type, compute the vector type with floating-point type
//      elements of the same width

The float and integer types for conversion are always the same size or one lmul 
up or one lmul down. So combining I and F with v or w should cover it.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D95016/new/

https://reviews.llvm.org/D95016

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

Reply via email to