On Tue, 10 Jan 2017, Alexander Monakov wrote: > On Tue, 10 Jan 2017, Richard Biener wrote: > > In general I think they should match. But without seeing concrete > > examples of where they do not I can't comment on whether such exceptions > > make sense. For example if you adjust a DECLs alignment and then > > re-layout it I'd expect you might get a non-BLKmode mode for an > > aggregate in some circumstances -- but then decl and type are not 1:1 > > compatible (due to different alignment), but this case is clearly desired > > as requiring type copies for the sake of alignment would be wasteful. > > Thanks; Vlad will follow up with (I believe) a different kind of mismatches > originating in the C++ front-end. > > > > For our original goal, I think we'll switch to the other solution I've > > > outlined in the opening mail, i.e. propagating mode tables at WPA stage > > > and keeping enough information to know if the section comes from the > > > host or native compiler. > > > > So add a hack ontop of the hack? Ugh. So why exactly doesn't it > > already work? It looks like decls and types have their modes > > "fixed" with the per-file mode table at WPA time. So what is missing > > is to "fix" modes in the per-function sections that are not touched > > by WPA? > > WPA re-streams packed function bodies as-is, so anything referred to > from within just the body won't be subject to mode remapping; I think > only modes of toplevel declarations and functions' arguments will be > remapped. And I believe it wouldn't be acceptable to unpack/remap/repack > function bodies at WPA stage (it's contrary to LTO scalability goal).
Yes indeed. But this means the mode-maps have to be per function section (with possibly a way to "share" them?). Or we need a way to annotate function sections with "no need to re-map" as the native nvptx sections don't need remapping and the others all use the same map? Richard.