- Timestamp:
- Dec 4, 2023, 10:22:47 AM (14 months ago)
- Branches:
- master
- Children:
- 8a4e472
- Parents:
- 4dc3b8c (diff), c4b9fa9 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/GenPoly/Box.cpp
r4dc3b8c r2f8d351 40 40 namespace { 41 41 42 /// The layout type is used to represent sizes, alignments and offsets. 43 ast::BasicType * makeLayoutType() { 44 return new ast::BasicType( ast::BasicType::LongUnsignedInt ); 45 } 46 47 /// Fixed version of layout type (just adding a 'C' in C++ style). 48 ast::BasicType * makeLayoutCType() { 49 return new ast::BasicType( ast::BasicType::LongUnsignedInt, 50 ast::CV::Qualifiers( ast::CV::Const ) ); 51 } 52 42 53 // -------------------------------------------------------------------------- 43 54 /// Adds layout-generation functions to polymorphic types. … … 60 71 } 61 72 return sizedParams; 62 }63 64 ast::BasicType * makeSizeAlignType() {65 return new ast::BasicType( ast::BasicType::LongUnsignedInt );66 73 } 67 74 … … 76 83 sizedParam->location, 77 84 sizeofName( paramName ), 78 make SizeAlignType()85 makeLayoutCType() 79 86 ) ); 80 87 params.emplace_back( new ast::ObjectDecl( 81 88 sizedParam->location, 82 89 alignofName( paramName ), 83 make SizeAlignType()90 makeLayoutCType() 84 91 ) ); 85 92 } 86 93 } 87 94 88 ast::Type * make SizeAlignOutType() {89 return new ast::PointerType( make SizeAlignType() );95 ast::Type * makeLayoutOutType() { 96 return new ast::PointerType( makeLayoutType() ); 90 97 } 91 98 … … 104 111 location, 105 112 sizeofName( aggr->name ), 106 make SizeAlignOutType()113 makeLayoutOutType() 107 114 ); 108 115 ast::ObjectDecl * alignParam = new ast::ObjectDecl( 109 116 location, 110 117 alignofName( aggr->name ), 111 make SizeAlignOutType()118 makeLayoutOutType() 112 119 ); 113 120 ast::ObjectDecl * offsetParam = nullptr; … … 117 124 location, 118 125 offsetofName( aggr->name ), 119 make SizeAlignOutType()126 makeLayoutOutType() 120 127 ); 121 128 params.push_back( offsetParam ); … … 1372 1379 }; 1373 1380 1374 // size/align/offset parameters may not be used, so add the unused attribute.1375 1381 ast::ObjectDecl * makeObj( 1376 1382 CodeLocation const & location, std::string const & name ) { 1383 // The size/align parameters may be unused, so add the unused attribute. 1377 1384 return new ast::ObjectDecl( location, name, 1378 make SizeAlignType(),1385 makeLayoutCType(), 1379 1386 nullptr, ast::Storage::Classes(), ast::Linkage::C, nullptr, 1380 1387 { new ast::Attribute( "unused" ) } ); 1388 } 1389 1390 /// A modified and specialized version of ast::add_qualifiers. 1391 ast::Type const * addConst( ast::Type const * type ) { 1392 ast::CV::Qualifiers cvq = { ast::CV::Const }; 1393 if ( ( type->qualifiers & cvq ) != 0 ) return type; 1394 auto mutType = ast::mutate( type ); 1395 mutType->qualifiers |= cvq; 1396 return mutType; 1381 1397 } 1382 1398 … … 1418 1434 } 1419 1435 for ( ast::ptr<ast::DeclWithType> & assert : mutDecl->assertions ) { 1436 ast::DeclWithType * mutAssert = ast::mutate( assert.get() ); 1420 1437 // Assertion parameters may not be used in body, 1421 1438 // pass along with unused attribute. 1422 assert.get_and_mutate()->attributes.push_back(1423 new ast::Attribute( "unused") );1424 inferredParams. push_back( assert );1439 mutAssert->attributes.push_back( new ast::Attribute( "unused" ) ); 1440 mutAssert->set_type( addConst( mutAssert->get_type() ) ); 1441 inferredParams.emplace_back( mutAssert ); 1425 1442 } 1426 1443 mutDecl->assertions.clear(); … … 1609 1626 1610 1627 /// Converts polymorphic type into a suitable monomorphic representation. 1611 /// Currently: __attribute__(( aligned(8) )) char[size_T];1628 /// Currently: __attribute__(( aligned(8) )) char[size_T]; 1612 1629 ast::Type * polyToMonoType( CodeLocation const & location, 1613 1630 ast::Type const * declType ) { … … 1615 1632 auto size = new ast::NameExpr( location, 1616 1633 sizeofName( Mangle::mangleType( declType ) ) ); 1617 auto aligned = new ast::Attribute( "aligned",1618 { ast::ConstantExpr::from_int( location, 8 ) } );1619 1634 auto ret = new ast::ArrayType( charType, size, 1620 1635 ast::VariableLen, ast::DynamicDim, ast::CV::Qualifiers() ); 1621 ret->attributes.push_back( aligned ); 1636 ret->attributes.emplace_back( new ast::Attribute( "aligned", 1637 { ast::ConstantExpr::from_int( location, 8 ) } ) ); 1622 1638 return ret; 1623 1639 } … … 1645 1661 ast::TypeInstType inst( decl->name, decl ); 1646 1662 std::string typeName = Mangle::mangleType( &inst ); 1647 ast::Type * layoutType = new ast::BasicType(1648 ast::BasicType::LongUnsignedInt );1649 1663 1650 1664 ast::ObjectDecl * sizeDecl = new ast::ObjectDecl( decl->location, 1651 sizeofName( typeName ), layoutType,1665 sizeofName( typeName ), makeLayoutCType(), 1652 1666 new ast::SingleInit( decl->location, 1653 1667 new ast::SizeofExpr( decl->location, deepCopy( base ) ) … … 1655 1669 ); 1656 1670 ast::ObjectDecl * alignDecl = new ast::ObjectDecl( decl->location, 1657 alignofName( typeName ), layoutType,1671 alignofName( typeName ), makeLayoutCType(), 1658 1672 new ast::SingleInit( decl->location, 1659 1673 new ast::AlignofExpr( decl->location, deepCopy( base ) ) … … 1752 1766 long findMember( ast::DeclWithType const * memberDecl, 1753 1767 const ast::vector<ast::Decl> & baseDecls ) { 1754 for ( auto pair: enumerate( baseDecls ) ) {1755 if ( isMember( memberDecl, pair.val.get() ) ) {1756 return pair.idx;1768 for ( auto const & [index, value] : enumerate( baseDecls ) ) { 1769 if ( isMember( memberDecl, value.get() ) ) { 1770 return index; 1757 1771 } 1758 1772 } … … 1912 1926 knownOffsets.insert( offsetName ); 1913 1927 1914 auto baseMembers = type->base->members;1915 ast::Type const * offsetType = new ast::BasicType(1916 ast::BasicType::LongUnsignedInt );1917 1918 1928 // Build initializer list for offset array. 1919 1929 ast::vector<ast::Init> inits; 1920 for ( ast::ptr<ast::Decl> & member : baseMembers ) {1930 for ( ast::ptr<ast::Decl> const & member : type->base->members ) { 1921 1931 auto memberDecl = member.as<ast::DeclWithType>(); 1922 1932 assertf( memberDecl, "Requesting offset of non-DWT member: %s", … … 1932 1942 auto offsetArray = makeVar( expr->location, offsetName, 1933 1943 new ast::ArrayType( 1934 offsetType,1935 ast::ConstantExpr::from_ulong( expr->location, baseMembers.size() ),1944 makeLayoutType(), 1945 ast::ConstantExpr::from_ulong( expr->location, inits.size() ), 1936 1946 ast::FixedLen, 1937 1947 ast::DynamicDim … … 2012 2022 // parameters to the layout call. 2013 2023 knownLayouts.insert( typeName ); 2014 ast::Type const * layoutType = makeSizeAlignType();2015 2024 2016 2025 int memberCount = inst->base->members.size(); … … 2018 2027 // All empty structures have the same layout (size 1, align 1). 2019 2028 makeVar( location, 2020 sizeofName( typeName ), layoutType,2029 sizeofName( typeName ), makeLayoutType(), 2021 2030 new ast::SingleInit( location, 2022 2031 ast::ConstantExpr::from_ulong( location, 1 ) ) ); 2023 2032 makeVar( location, 2024 alignofName( typeName ), ast::deepCopy( layoutType),2033 alignofName( typeName ), makeLayoutType(), 2025 2034 new ast::SingleInit( location, 2026 2035 ast::ConstantExpr::from_ulong( location, 1 ) ) ); … … 2028 2037 } else { 2029 2038 ast::ObjectDecl const * sizeofVar = makeVar( location, 2030 sizeofName( typeName ), deepCopy( layoutType), nullptr );2039 sizeofName( typeName ), makeLayoutType(), nullptr ); 2031 2040 ast::ObjectDecl const * alignofVar = makeVar( location, 2032 alignofName( typeName ), deepCopy( layoutType), nullptr );2041 alignofName( typeName ), makeLayoutType(), nullptr ); 2033 2042 ast::ObjectDecl const * offsetofVar = makeVar( location, 2034 2043 offsetofName( typeName ), 2035 2044 new ast::ArrayType( 2036 layoutType,2045 makeLayoutType(), 2037 2046 ast::ConstantExpr::from_int( location, memberCount ), 2038 2047 ast::FixedLen, … … 2078 2087 // parameters to the layout call. 2079 2088 knownLayouts.insert( typeName ); 2080 ast::Type const * layoutType = makeSizeAlignType();2081 2089 2082 2090 ast::ObjectDecl * sizeofVar = makeVar( location, 2083 sizeofName( typeName ), layoutType);2091 sizeofName( typeName ), makeLayoutType() ); 2084 2092 ast::ObjectDecl * alignofVar = makeVar( location, 2085 alignofName( typeName ), ast::deepCopy( layoutType) );2093 alignofName( typeName ), makeLayoutType() ); 2086 2094 2087 2095 ast::UntypedExpr * layoutCall = new ast::UntypedExpr( location,
Note: See TracChangeset
for help on using the changeset viewer.