| 'INFO_TABLE_CONSTR' '(' NAME ',' INT ',' INT ',' INT ',' INT ',' STRING ',' STRING ')'
-- ptrs, nptrs, tag, closure type, description, type
- { stdInfo $3 $5 $7 $9 $11 $13 $15 }
+ { conInfo $3 $5 $7 $9 $11 $13 $15 }
| 'INFO_TABLE_SELECTOR' '(' NAME ',' INT ',' INT ',' STRING ',' STRING ')'
-- selector, closure type, description, type
( "f2f32", flip MO_S_Conv F32 ), -- TODO; rounding mode
( "f2f64", flip MO_S_Conv F64 ), -- TODO; rounding mode
( "f2i8", flip MO_S_Conv I8 ),
- ( "f2i16", flip MO_S_Conv I8 ),
- ( "f2i32", flip MO_S_Conv I8 ),
- ( "f2i64", flip MO_S_Conv I8 ),
+ ( "f2i16", flip MO_S_Conv I16 ),
+ ( "f2i32", flip MO_S_Conv I32 ),
+ ( "f2i64", flip MO_S_Conv I64 ),
( "i2f32", flip MO_S_Conv F32 ),
( "i2f64", flip MO_S_Conv F64 )
]
basicInfo name (packHalfWordsCLit ptrs nptrs)
srt_bitmap cl_type desc_str ty_str
+conInfo name ptrs nptrs srt_bitmap cl_type desc_str ty_str = do
+ (lbl, info1, _) <- basicInfo name (packHalfWordsCLit ptrs nptrs)
+ srt_bitmap cl_type desc_str ty_str
+ desc_lit <- code $ mkStringCLit desc_str
+ let desc_field = makeRelativeRefTo lbl desc_lit
+ return (lbl, info1, [desc_field])
+
basicInfo name layout srt_bitmap cl_type desc_str ty_str = do
lit1 <- if opt_SccProfilingOn
then code $ mkStringCLit desc_str