On Tue, May 14, 2013 at 4:07 PM, Charles Davis <span dir="ltr"><<a href="mailto:cdavis5x@gmail.com" target="_blank">cdavis5x@gmail.com</a>></span> wrote:<br><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im"><br>
On May 14, 2013, at 4:26 PM, Aaron Ballman wrote:<br>
><br>
>> Do __sptr and __uptr get different manglings?<br>
><br>
> They do:<br>
><br>
> void func( int * __ptr32 p ) {}<br>
> void func2( int * __ptr64 p ) {}<br>
><br>
> PUBLIC ?func@@YAXPAH@Z ; func<br>
> PUBLIC ?func2@@YAXPEAH@Z ; func2<br>
><br>
> Namely, the presence of E (rnk pointed this out previously).<br>
</div>He was asking about __sptr and __uptr :). They don't by the way:<br>
<br>
> cl /c test.cpp<br>
[extraneous banner output omitted]<br>
> dumpbin /symbols test.obj<br>
[...]<br>
00F 00000010 SECT4  notype ()    External     | ?func@@YAXPAH@Z (void __cdecl func(int *))<br>
010 00000020 SECT4  notype ()    External     | ?func2@@YAXPAH@Z (void __cdecl func2(int *)) </blockquote></div><br><div>Thanks. One more thing:</div><div><br></div><div>template<typename T> void f(void **p, T *q) { *p = *q; }</div>
<div><br></div><div>void *g(int *__ptr32 __sptr a) {</div><div>  void *result;</div><div>  f(&result, &a);</div><div>  return result;</div><div>}</div><div><div>void *h(char *__ptr32 __uptr a) {</div><div>  void *result;</div>
<div>  f(&result, &a);</div><div>  return result;</div><div>}</div></div><div><br></div><div>int main() {</div><div>  printf("%p\n", g((int *__ptr32 __sptr)0xdeadbeef));</div><div>  printf("%p\n", h((char *__ptr32 __uptr)0xdeadbeef));</div>
<div>}</div><div><br></div><div>Does one of these get sign-extended and the other one get zero-extended?</div>