#define __disable_irq() __asm__ volatile("CPSID i");
#define __enable_irq() __asm__ volatile("CPSIE i");
+/* only mask default irqs, see NVIC_SET_PRIORITY users
+ * note: usb code uses 112 priority */
+#define __mask_irq() do { \
+ int basepri_ = 128 - 16; \
+ __asm__ volatile("msr BASEPRI, %0" :: "r"(basepri_)); \
+} while (0)
+#define __unmask_irq() do { \
+ int basepri_ = 0; \
+ __asm__ volatile("msr BASEPRI, %0" :: "r"(basepri_)); \
+} while (0)
+
// System Control Space (SCS), ARMv7 ref manual, B3.2, page 708
#define SCB_CPUID (*(const uint32_t *)0xE000ED00) // CPUID Base Register
#define SCB_ICSR (*(volatile uint32_t *)0xE000ED04) // Interrupt Control and State
usb_packet_t *ret;
endpoint--;
if (endpoint >= NUM_ENDPOINTS) return NULL;
- __disable_irq();
+ __mask_irq();
ret = rx_first[endpoint];
if (ret) {
rx_first[endpoint] = ret->next;
usb_rx_byte_count_data[endpoint] -= ret->len;
}
- __enable_irq();
+ __unmask_irq();
//serial_print("rx, epidx=");
//serial_phex(endpoint);
//serial_print(", packet=");
{
uint32_t count=0;
- __disable_irq();
+ __mask_irq();
for ( ; p; p = p->next) {
count += p->len;
}
- __enable_irq();
+ __unmask_irq();
return count;
}
endpoint--;
if (endpoint >= NUM_ENDPOINTS) return 0;
- __disable_irq();
+ __mask_irq();
for (p = tx_first[endpoint]; p; p = p->next) count++;
- __enable_irq();
+ __unmask_irq();
return count;
}
cfg = usb_endpoint_config_table;
//serial_print("rx_mem:");
- __disable_irq();
+ __mask_irq();
for (i=1; i <= NUM_ENDPOINTS; i++) {
if (*cfg++ & USB_ENDPT_EPRXEN) {
if (table[index(i, RX, EVEN)].desc == 0) {
table[index(i, RX, EVEN)].addr = packet->buf;
table[index(i, RX, EVEN)].desc = BDT_DESC(64, 0);
usb_rx_memory_needed--;
- __enable_irq();
+ __unmask_irq();
//serial_phex(i);
//serial_print(",even\n");
return;
table[index(i, RX, ODD)].addr = packet->buf;
table[index(i, RX, ODD)].desc = BDT_DESC(64, 1);
usb_rx_memory_needed--;
- __enable_irq();
+ __unmask_irq();
//serial_phex(i);
//serial_print(",odd\n");
return;
}
}
}
- __enable_irq();
+ __unmask_irq();
// we should never reach this point. If we get here, it means
// usb_rx_memory_needed was set greater than zero, but no memory
// was actually needed.
endpoint--;
if (endpoint >= NUM_ENDPOINTS) return;
- __disable_irq();
+ __mask_irq();
//serial_print("txstate=");
//serial_phex(tx_state[endpoint]);
//serial_print("\n");
tx_last[endpoint]->next = packet;
}
tx_last[endpoint] = packet;
- __enable_irq();
+ __unmask_irq();
return;
}
tx_state[endpoint] = next;
b->addr = packet->buf;
b->desc = BDT_DESC(packet->len, ((uint32_t)b & 8) ? DATA1 : DATA0);
- __enable_irq();
+ __unmask_irq();
}