hiraditya added a comment.

In D152279#4406896 <https://reviews.llvm.org/D152279#4406896>, @MaskRay wrote:

> In D152279#4405901 <https://reviews.llvm.org/D152279#4405901>, @asb wrote:
>
>> One of the key things we've been discussing on this at the LLVM call is that 
>> we probably want to keep the small data limit for embedded targets.
>
> It'd be useful to hear from some concrete embedded target users, whether they 
> customize `-msmall-data-limit=`, whether they are happy with 
> `-msmall-data-limit=8`, or whether they are just unaware of this threshold.
>
> If an embedded system typically customizes compiler driver options a lot, I 
> think they can consider adding `-msmall-data-limit=` (with a value suitable 
> for their use cases) in a configuration file 
> <https://clang.llvm.org/docs/UsersManual.html#configuration-files>, not 
> letting their use cases dictate Linux systems.
>
> I putting up the patch partly came from my stance finding UX of this option 
> is really confusing and misleading. I wish that the embedded target users can 
> give me compelling arguments to keep `-msmall-data-limit=8` (and not another 
> value).

The default of 8 is probably to make it consistent with gcc. Here is text from 
man gcc <https://man7.org/linux/man-pages/man1/gcc.1.html>

  -msmall-data
  -mlarge-data
      When -mexplicit-relocs is in effect, static data is accessed
      via gp-relative relocations.  When -msmall-data is used,
      objects 8 bytes long or smaller are placed in a small data
      area (the ".sdata" and ".sbss" sections) and are accessed via
      16-bit relocations off of the $gp register.  This limits the
      size of the small data area to 64KB, but allows the variables
      to be directly accessed via a single instruction.
  
      The default is -mlarge-data.  With this option the data area
      is limited to just below 2GB.  Programs that require more
      than 2GB of data must use "malloc" or "mmap" to allocate the
      data in the heap instead of in the program's data segment.
  
      When generating code for shared libraries, -fpic implies
      -msmall-data and -fPIC implies -mlarge-data.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D152279

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

Reply via email to