forked from lix-project/lix
Merge pull request #4444 from matthewbauer/unset-curproc-arch-affinity
Set kern.curproc_arch_affinity=0 to escape Rosetta
This commit is contained in:
commit
4e9cec79bf
|
@ -52,6 +52,7 @@
|
||||||
|
|
||||||
#if __APPLE__
|
#if __APPLE__
|
||||||
#include <spawn.h>
|
#include <spawn.h>
|
||||||
|
#include <sys/sysctl.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
|
@ -2865,6 +2866,10 @@ void DerivationGoal::runChild()
|
||||||
throw SysError("failed to initialize builder");
|
throw SysError("failed to initialize builder");
|
||||||
|
|
||||||
if (drv->platform == "aarch64-darwin") {
|
if (drv->platform == "aarch64-darwin") {
|
||||||
|
// Unset kern.curproc_arch_affinity so we can escape Rosetta
|
||||||
|
int affinity = 0;
|
||||||
|
sysctlbyname("kern.curproc_arch_affinity", NULL, NULL, &affinity, sizeof(affinity));
|
||||||
|
|
||||||
cpu_type_t cpu = CPU_TYPE_ARM64;
|
cpu_type_t cpu = CPU_TYPE_ARM64;
|
||||||
posix_spawnattr_setbinpref_np(&attrp, 1, &cpu, NULL);
|
posix_spawnattr_setbinpref_np(&attrp, 1, &cpu, NULL);
|
||||||
} else if (drv->platform == "x86_64-darwin") {
|
} else if (drv->platform == "x86_64-darwin") {
|
||||||
|
|
Loading…
Reference in a new issue