tra added inline comments.
================ Comment at: clang/lib/AST/ASTContext.cpp:11760-11763 + auto Cutoff = [](unsigned V) { return V > 1 ? V : 1; }; + if (CUDANameMangleCtx.MangleDeviceNameInHostCompilation) + return Cutoff(Res >> 16); + return Cutoff(Res & 0xffff); ---------------- rnk wrote: > rnk wrote: > > tra wrote: > > > I think we should change the `MangleNumbers` instead to use uin64_t or, > > > perhaps `unsigned[2]` or even `struct{ unsigned host; unsigned device;}`. > > > Reducing the max number of anything to just 64K will be prone to failing > > > sooner or later. > > IMO it would be simpler to set up a ternary instead of a lambda and two > > returns: > > Res = Cond ? (Res >> 16) : (Res & 0xFFFF); > > return Res > 1 ? Res : 1; > I suspect we could live with a 64K mangling number limit, but that is low > enough that we need to put in a check for overflow somewhere. If we'd produce a reasonable diagnostic for that, it might work. CHANGES SINCE LAST ACTION https://reviews.llvm.org/D122734/new/ https://reviews.llvm.org/D122734 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits