mstorsjo wrote:

> > clang/lib/CodeGen/CGBuiltin.cpp is over 1MB long (>23k LoC), and can take 
> > minutes to recompile (depending on compiler and host system) when modified, 
> > and 5 seconds for clangd to update for every edit. Splitting this file was 
> > discussed in this thread:
> 
> It looks like while this makes the individual files somewhat faster to 
> compile, it makes the total time to compile all them _much_ higher, by a 
> factor of more than 3. It adds 1% to the clang build time.

I'm also seeing an increase, but not quite that much.

With GCC 13, I previously saw this (for `CGBuiltin.cpp.o`):
```
real    1m23.524s
user    1m22.800s
sys     0m0.705s
```
Now I see this (for `CGBuiltin.cpp.o` and all the `TargetBuiltins` object 
files):
```
real    1m12.927s
user    2m29.557s
sys     0m3.611s
```

I tried looking at the compile time for the indiviual object files. The vast 
majority of them take around 5 seconds to compile here, but we have one single 
outlier - `TargetBuiltins/RISCV.cpp.o`:
```
real    1m9.225s
user    1m8.728s
sys     0m0.477s
```

So even if `RISCV.cpp` only has 425 lines, compiling this single file still 
takes >80% of the time it took the compile the previous file.

https://github.com/llvm/llvm-project/pull/132252
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to