+
+void
+scale_setup()
+{
+ int scale = 0;
+#if defined(__LP64__)
+ typeof(task_max) task_max_base = task_max;
+
+ /* Raise limits for servers with >= 16G */
+ if ((serverperfmode != 0) && ((uint64_t)sane_size >= (uint64_t)(16 * 1024 * 1024 *1024ULL))) {
+ scale = (int)((uint64_t)sane_size / (uint64_t)(8 * 1024 * 1024 *1024ULL));
+ /* limit to 128 G */
+ if (scale > 16)
+ scale = 16;
+ task_max_base = 2500;
+ } else if ((uint64_t)sane_size >= (uint64_t)(3 * 1024 * 1024 *1024ULL))
+ scale = 2;
+
+ task_max = MAX(task_max, task_max_base * scale);
+
+ if (scale != 0) {
+ task_threadmax = task_max;
+ thread_max = task_max * 5;
+ }
+
+#endif
+
+ bsd_scale_setup(scale);
+
+ ipc_space_max = SPACE_MAX;
+ ipc_port_max = PORT_MAX;
+ ipc_pset_max = SET_MAX;
+ semaphore_max = SEMAPHORE_MAX;
+}
+