Add calls to tight_loop_contents in a few more places. (#1401)

Fixes #1290
diff --git a/src/rp2_common/hardware_sync/include/hardware/sync.h b/src/rp2_common/hardware_sync/include/hardware/sync.h
index b15f36b..35bd783 100644
--- a/src/rp2_common/hardware_sync/include/hardware/sync.h
+++ b/src/rp2_common/hardware_sync/include/hardware/sync.h
@@ -262,7 +262,9 @@
     // Note we don't do a wfe or anything, because by convention these spin_locks are VERY SHORT LIVED and NEVER BLOCK and run
     // with INTERRUPTS disabled (to ensure that)... therefore nothing on our core could be blocking us, so we just need to wait on another core
     // anyway which should be finished soon
-    while (__builtin_expect(!*lock, 0));
+    while (__builtin_expect(!*lock, 0)) {
+        tight_loop_contents();
+    }
     __mem_fence_acquire();
 }
 
diff --git a/src/rp2_common/hardware_xosc/xosc.c b/src/rp2_common/hardware_xosc/xosc.c
index 03e6785..e226022 100644
--- a/src/rp2_common/hardware_xosc/xosc.c
+++ b/src/rp2_common/hardware_xosc/xosc.c
@@ -37,7 +37,9 @@
     hw_set_bits(&xosc_hw->ctrl, XOSC_CTRL_ENABLE_VALUE_ENABLE << XOSC_CTRL_ENABLE_LSB);
 
     // Wait for XOSC to be stable
-    while(!(xosc_hw->status & XOSC_STATUS_STABLE_BITS));
+    while(!(xosc_hw->status & XOSC_STATUS_STABLE_BITS)) {
+        tight_loop_contents();
+    }
 }
 
 void xosc_disable(void) {
@@ -46,12 +48,16 @@
     tmp |= (XOSC_CTRL_ENABLE_VALUE_DISABLE << XOSC_CTRL_ENABLE_LSB);
     xosc_hw->ctrl = tmp;
     // Wait for stable to go away
-    while(xosc_hw->status & XOSC_STATUS_STABLE_BITS);
+    while(xosc_hw->status & XOSC_STATUS_STABLE_BITS) {
+        tight_loop_contents();
+    }
 }
 
 void xosc_dormant(void) {
     // WARNING: This stops the xosc until woken up by an irq
     xosc_hw->dormant = XOSC_DORMANT_VALUE_DORMANT;
     // Wait for it to become stable once woken up
-    while(!(xosc_hw->status & XOSC_STATUS_STABLE_BITS));
+    while(!(xosc_hw->status & XOSC_STATUS_STABLE_BITS)) {
+        tight_loop_contents();
+    }
 }