<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/57809>57809</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
ld64.lld: Support synthesizing relative ObjC method lists
</td>
</tr>
<tr>
<th>Labels</th>
<td>
lld:MachO
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
BertalanD
</td>
</tr>
</table>
<pre>
Starting with macOS 11, a more compact encoding is available for ObjC method lists. Previously, each method had a descriptor consisting of 3 pointers:
```c
struct _objc_method {
SEL _cmd;
char *method_type;
char *_imp;
}
```
In the new format, `__TEXT,__objc_methlist` stores 32-bit offsets instead.
```c++
struct _objc_method_rel {
int32_t _cmd;
int32_t method_type;
int32_t _imp;
}
```
This transformation can be controlled with the `-objc_relative_method_lists`/`-no_objc_relative_method_lists` linker flags.
Currently, method lists are stored in `__DATA,__objc_const`. With this transformation, Chromium Framework's data segment will shrink by about 40 KB, meaning that 3 fewer pages will have to be relocated at startup.
<details>
<summary>Sidenote: AppleClang itself can be coaxed into generating the relative encoding with `-fobjc-relative-method-lists`</summary>
```objc
// test.m
#include <Foundation/Foundation.h>
int main() {
NSObject *foo = [[NSObject alloc] init];
}
```
```
❯ clang test.m -S -emit-llvm -o - | grep _objc_method
%struct.__method_list_t = type { i32, i32, [0 x %struct._objc_method] }
%struct._objc_method = type { i8*, i8*, i8* }
❯ clang test.m -S -emit-llvm -o - -fobjc-relative-method-lists | grep _objc_method
%struct.__method_list_t = type { i32, i32, [0 x %struct._objc_method_rel] }
%struct._objc_method_rel = type { i32, i32, i32 }
```
</details>
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy9VsuOqzgQ_RqyKYEI5MWCRR4daTSPHiktzeyQwZXge42NbNN9M18_Zci7u696NhOhEFN2UefUOXZKzY_5zjHjhDrAm3A1NKx63sF4HCRrYNBog1DppmWVA1SV5n6isMBemZCslAh7beC5_LaGBl2tOUhhnY3gT4OvQndWHn0mZFV9nlAzTpk52sqI1tHqSitLi3xmvYcUWi2UQ2ODdBnEmyBeBrN4uKphbJ3pqJ5Cl9-q4pQ1mK-GINBn9_QbFFXDg_TmYVUzA0GyHBYU7tjih_FCNO0lEMw3DzWchv33LwpcjaDwzdPQMOex0pyieHn6-4UGxbVGzwuFwBJktJAmYSkcAd5bdBaEsg4Zj26z38BOVv76DHxhUN4TQASmSeHek3AOfEbCZeHXSXipSQ_OMGUHDoRWUDEFpVeOckZLiXwQlyeLVod97VQ0TX7FM4heOD53svVzlC5-Oo2Epr6jgb1kB3vH27ozBpUblHerSmCk5p5_TkCHRm2WL8tro7wUfZci-Guo9x00n3NdG92IroGtYQ2-afM9SOYWOHMMLB4aejnhlRJsbahIKI_ASt05mMTw62qoiimvd1czR4rf4xshadmBhNEvrNkrgtOeQ8KvK-aoZJpqvVe79l4m6ZqjIzuSYZ4eArZrGmaOFNgJjko76vYSlm0rcS2Zt7KzKPfXfrEfPTf06gMqNMwNVfZl9G247gJ9R32n9p668DwhHBgPL-1M19TRayEfKtxnOD2i7idbcGhd1JwfpUJVsuMknnS91Z3ip1Zsr4OofshNIGgzEzRrESTZvT3-2NGOheQisvtea0q7gWC6ousSYZJoD6YbIkM4un_RDI8Pn5Ig2wTLLVQ93QMsgHAHITbChVK--qGGkCpcw8Fge2ftMwPTwfZRcWsD8qmv3JvY4wORJl5cpxuhieEH3Ky9zUvIrkg-nPKQm1hc9tnvftwk-c-Afyac_5cNv8l8gZFhn_38HXSDT-XR2-Bq1BHm49ksnWSLaZaOeJ7yLM3YyAknMZd8Nomk5N6su65ttSHrHxX50Ip_vPcubnx38o46I_PaubY_PnszHcioXRnRMU4Dz__pFrZGe63TUFjboaUf0_kizkZ1XpZZPInj8STOMBvPF4yN-XTOeJVguthP5iM6_FHa3LsmSYZSf6dD_plGxORI5EmcJHE2Xozj6SxNoz2fsvEMOVbjNE5xFkxiJHvKyFcSaXMYmbwvquwOloLD34hLkFkrDgqxfyHlZx1BNvkKjWMkNHqhR5D35f8LnXC7NA">