MaskRay added a comment.

In D155290#4576643 <https://reviews.llvm.org/D155290#4576643>, @qiongsiwu1 
wrote:

> In D155290#4574797 <https://reviews.llvm.org/D155290#4574797>, @MaskRay wrote:
>
>> In D155290#4572965 <https://reviews.llvm.org/D155290#4572965>, @qiongsiwu1 
>> wrote:
>>
>>> Ping for review.
>>>
>>> If there are no comments on whether we should add `-lpthread` for platforms 
>>> other than AIX, I will land this patch soon, and let the official buildbots 
>>> check for problems. If there are problems, I will let the bots run a bit 
>>> (probably a day or so) before reverting to catch as many platforms I need 
>>> to fix as possible, revert, and fix the patch.
>>>
>>> Thanks!
>>
>> I will take a look as well but please don't land this `-lpthread` change for 
>> non-AIX platforms. I will think about the implication.
>
> Thanks @MaskRay ! I am putting this patch on hold till I hear back. The patch 
> does not alter non-AIX platforms at the moment.

The `pthread_atfork` undefined reference will cause a problem using glibc<2.34 
where `pthread_atfork` lives in libpthread instead of libc.
I think non-AIX-non-Windows systems can live with an extra `-lpthread`. For ELF 
systems (not Apple's among non-AIX-non-Windows systems), `-lpthread` must be 
after `libclang_rt.profile.a`.



================
Comment at: compiler-rt/test/profile/Posix/instrprof-fork.c:22
+  pid = fork();
+  if (!pid) {
+    printf("%ld.profraw\n", (long)getpid());
----------------
MaskRay wrote:
> parent and child have the same logic. Use:
> ```
> if (pid == -1)
>   return 1;
> printf("%ld.profraw\n", (long)getpid());
> ```
Please ignore my previous comment. I think we want to have a deterministic 
parent / child output order. Consider adding a wait for the parent process so 
that we always see the child `printf("%ld.profraw\n", (long)getpid());` output 
before the parent one.

We should inspect more information of the two raw profile files. Create a 
function only called by the parent and another function only called by the 
child. Check their counters.

We also need a test if the child process spawns another process.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D155290/new/

https://reviews.llvm.org/D155290

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to