+#elif defined(__arm__)
+ arm_thread_state_t state = {0};
+ arm_thread_state_t *ts = &state;
+ thread_state_flavor_t flavor = ARM_THREAD_STATE;
+ count = ARM_THREAD_STATE_COUNT;
+
+ if (suspended) {
+ PTHREAD_MACH_CALL(thread_get_state(thread->kernel_thread,
+ flavor,
+ (thread_state_t) &state,
+ &count),
+ r);
+ }
+
+ ts->pc = (uintptr_t)routine;
+
+ if (ts->pc & 1) {
+ ts->pc &= ~1;
+ ts->cpsr |= 0x20; /* PSR_THUMB */
+ }
+
+ ts->sp = (uintptr_t)vsp - C_ARGSAVE_LEN - C_RED_ZONE;
+ ts->r[0] = (uintptr_t)thread;
+
+ /* Incase of needresume, suspend is always set */
+ if (suspended) {
+ PTHREAD_MACH_CALL(thread_set_state(thread->kernel_thread,
+ flavor,
+ (thread_state_t) &state,
+ count),
+ r);
+ if (needresume)
+ PTHREAD_MACH_CALL(thread_resume(thread->kernel_thread),
+ r);
+ } else {
+ PTHREAD_MACH_CALL(thread_create_running(mach_task_self(),
+ flavor,
+ (thread_state_t) ts,
+ count,
+ &thread->kernel_thread),
+ r);
+ }