acpki: fix race condition disabling batch mode
Some checks failed
Hydra zc706-nist_clock-firmware Hydra build #198795 of artiq:zynq-beta:zc706-nist_clock-firmware
Hydra zc706-nist_qc2_satellite_100mhz-firmware Hydra build #198840 of artiq:zynq-beta:zc706-nist_qc2_satellite_100mhz-firmware
Hydra zc706-cxp_4r_fmc-firmware Hydra build #198789 of artiq:zynq-beta:zc706-cxp_4r_fmc-firmware
Hydra zc706-acpki_nist_qc2_satellite-firmware Hydra build #198779 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite-firmware
Hydra kasli_soc-satellite-firmware Hydra build #198734 of artiq:zynq-beta:kasli_soc-satellite-firmware
Hydra zc706-acpki_nist_clock_master_100mhz-firmware Hydra build #198749 of artiq:zynq-beta:zc706-acpki_nist_clock_master_100mhz-firmware
Hydra zc706-acpki_nist_clock-firmware Hydra build #198739 of artiq:zynq-beta:zc706-acpki_nist_clock-firmware
Hydra zc706-acpki_nist_qc2-firmware Hydra build #198764 of artiq:zynq-beta:zc706-acpki_nist_qc2-firmware
Hydra zc706-acpki_nist_clock_master-firmware Hydra build #198744 of artiq:zynq-beta:zc706-acpki_nist_clock_master-firmware
Hydra zc706-acpki_nist_clock_satellite-firmware Hydra build #198754 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite-firmware
Hydra zc706-acpki_nist_clock_satellite_100mhz-firmware Hydra build #198759 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite_100mhz-firmware
Hydra zc706-acpki_nist_qc2_master-firmware Hydra build #198769 of artiq:zynq-beta:zc706-acpki_nist_qc2_master-firmware
Hydra zc706-cxp_4r_fmc-gateware Hydra build #198791 of artiq:zynq-beta:zc706-cxp_4r_fmc-gateware
Hydra zc706-nist_qc2_satellite-gateware Hydra build #198837 of artiq:zynq-beta:zc706-nist_qc2_satellite-gateware
Hydra zc706-acpki_nist_qc2-gateware Hydra build #198766 of artiq:zynq-beta:zc706-acpki_nist_qc2-gateware
Hydra zc706-acpki_nist_clock_satellite_100mhz-gateware Hydra build #198761 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite_100mhz-gateware
Hydra zc706-nist_qc2_satellite_100mhz-gateware Hydra build #198842 of artiq:zynq-beta:zc706-nist_qc2_satellite_100mhz-gateware
Hydra zc706-acpki_nist_clock-gateware Hydra build #198741 of artiq:zynq-beta:zc706-acpki_nist_clock-gateware
Hydra zc706-acpki_nist_clock_master_100mhz-gateware Hydra build #198751 of artiq:zynq-beta:zc706-acpki_nist_clock_master_100mhz-gateware
Hydra zc706-acpki_nist_clock_satellite-gateware Hydra build #198756 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite-gateware
Hydra zc706-acpki_nist_clock_master-gateware Hydra build #198746 of artiq:zynq-beta:zc706-acpki_nist_clock_master-gateware
Hydra zc706-acpki_nist_qc2_master_100mhz-firmware Hydra build #198774 of artiq:zynq-beta:zc706-acpki_nist_qc2_master_100mhz-firmware
Hydra zc706-acpki_nist_qc2_satellite_100mhz-firmware Hydra build #198784 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite_100mhz-firmware
Hydra zc706-nist_qc2-firmware Hydra build #198820 of artiq:zynq-beta:zc706-nist_qc2-firmware
Hydra zc706-acpki_nist_qc2_satellite_100mhz-gateware Hydra build #198786 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite_100mhz-gateware
Hydra zc706-acpki_nist_qc2_master_100mhz-gateware Hydra build #198776 of artiq:zynq-beta:zc706-acpki_nist_qc2_master_100mhz-gateware
Hydra kasli_soc-demo-firmware Hydra build #198726 of artiq:zynq-beta:kasli_soc-demo-firmware
Hydra zc706-nist_clock_master-firmware Hydra build #198800 of artiq:zynq-beta:zc706-nist_clock_master-firmware
Hydra zc706-nist_clock-gateware Hydra build #198797 of artiq:zynq-beta:zc706-nist_clock-gateware
Hydra zc706-acpki_nist_qc2_master-gateware Hydra build #198771 of artiq:zynq-beta:zc706-acpki_nist_qc2_master-gateware
Hydra zc706-nist_clock_master_100mhz-firmware Hydra build #198805 of artiq:zynq-beta:zc706-nist_clock_master_100mhz-firmware
Hydra zc706-nist_clock_satellite-firmware Hydra build #198810 of artiq:zynq-beta:zc706-nist_clock_satellite-firmware
Hydra zc706-nist_clock_satellite_100mhz-firmware Hydra build #198815 of artiq:zynq-beta:zc706-nist_clock_satellite_100mhz-firmware
Hydra zc706-nist_qc2_master-firmware Hydra build #198825 of artiq:zynq-beta:zc706-nist_qc2_master-firmware
Hydra zc706-nist_qc2-gateware Hydra build #198822 of artiq:zynq-beta:zc706-nist_qc2-gateware
Hydra zc706-nist_qc2_master_100mhz-firmware Hydra build #198830 of artiq:zynq-beta:zc706-nist_qc2_master_100mhz-firmware
Hydra zc706-acpki_nist_qc2_satellite-gateware Hydra build #198781 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite-gateware
Hydra zc706-nist_qc2_satellite-firmware Hydra build #198835 of artiq:zynq-beta:zc706-nist_qc2_satellite-firmware
Hydra ebaz4205-base-firmware Hydra build #198720 of artiq:zynq-beta:ebaz4205-base-firmware
Hydra zc706-nist_clock_satellite_100mhz-gateware Hydra build #198817 of artiq:zynq-beta:zc706-nist_clock_satellite_100mhz-gateware
Hydra zc706-acpki_nist_qc2-jtag Hydra build #198767 of artiq:zynq-beta:zc706-acpki_nist_qc2-jtag
Hydra zc706-nist_qc2-jtag Hydra build #198823 of artiq:zynq-beta:zc706-nist_qc2-jtag
Hydra fmt-check Hydra build #198724 of artiq:zynq-beta:fmt-check
Hydra gateware-sim Hydra build #198725 of artiq:zynq-beta:gateware-sim
Hydra ebaz4205-base-gateware Hydra build #198721 of artiq:zynq-beta:ebaz4205-base-gateware
Hydra zc706-acpki_nist_clock-fsbl-sd Hydra build #198740 of artiq:zynq-beta:zc706-acpki_nist_clock-fsbl-sd
Hydra ebaz4205-base-jtag Hydra build #198722 of artiq:zynq-beta:ebaz4205-base-jtag
Hydra ebaz4205-base-sd Hydra build #198723 of artiq:zynq-beta:ebaz4205-base-sd
Hydra zc706-acpki_nist_clock-jtag Hydra build #198742 of artiq:zynq-beta:zc706-acpki_nist_clock-jtag
Hydra kasli_soc-master-firmware Hydra build #198730 of artiq:zynq-beta:kasli_soc-master-firmware
Hydra zc706-nist_clock_master-gateware Hydra build #198802 of artiq:zynq-beta:zc706-nist_clock_master-gateware
Hydra zc706-nist_clock_master_100mhz-jtag Hydra build #198808 of artiq:zynq-beta:zc706-nist_clock_master_100mhz-jtag
Hydra zc706-acpki_nist_clock-sd Hydra build #198743 of artiq:zynq-beta:zc706-acpki_nist_clock-sd
Hydra zc706-acpki_nist_clock_master-fsbl-sd Hydra build #198745 of artiq:zynq-beta:zc706-acpki_nist_clock_master-fsbl-sd
Hydra zc706-acpki_nist_clock_master-jtag Hydra build #198747 of artiq:zynq-beta:zc706-acpki_nist_clock_master-jtag
Hydra zc706-acpki_nist_clock_master-sd Hydra build #198748 of artiq:zynq-beta:zc706-acpki_nist_clock_master-sd
Hydra zc706-acpki_nist_clock_master_100mhz-fsbl-sd Hydra build #198750 of artiq:zynq-beta:zc706-acpki_nist_clock_master_100mhz-fsbl-sd
Hydra zc706-acpki_nist_clock_master_100mhz-jtag Hydra build #198752 of artiq:zynq-beta:zc706-acpki_nist_clock_master_100mhz-jtag
Hydra zc706-acpki_nist_clock_master_100mhz-sd Hydra build #198753 of artiq:zynq-beta:zc706-acpki_nist_clock_master_100mhz-sd
Hydra zc706-acpki_nist_clock_satellite-fsbl-sd Hydra build #198755 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite-fsbl-sd
Hydra zc706-acpki_nist_clock_satellite-jtag Hydra build #198757 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite-jtag
Hydra zc706-acpki_nist_clock_satellite-sd Hydra build #198758 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite-sd
Hydra zc706-acpki_nist_clock_satellite_100mhz-fsbl-sd Hydra build #198760 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite_100mhz-fsbl-sd
Hydra zc706-acpki_nist_clock_satellite_100mhz-jtag Hydra build #198762 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite_100mhz-jtag
Hydra zc706-acpki_nist_clock_satellite_100mhz-sd Hydra build #198763 of artiq:zynq-beta:zc706-acpki_nist_clock_satellite_100mhz-sd
Hydra zc706-acpki_nist_qc2-fsbl-sd Hydra build #198765 of artiq:zynq-beta:zc706-acpki_nist_qc2-fsbl-sd
Hydra zc706-acpki_nist_qc2-sd Hydra build #198768 of artiq:zynq-beta:zc706-acpki_nist_qc2-sd
Hydra zc706-acpki_nist_qc2_master-fsbl-sd Hydra build #198770 of artiq:zynq-beta:zc706-acpki_nist_qc2_master-fsbl-sd
Hydra zc706-acpki_nist_qc2_master-jtag Hydra build #198772 of artiq:zynq-beta:zc706-acpki_nist_qc2_master-jtag
Hydra zc706-acpki_nist_qc2_master-sd Hydra build #198773 of artiq:zynq-beta:zc706-acpki_nist_qc2_master-sd
Hydra zc706-acpki_nist_qc2_master_100mhz-fsbl-sd Hydra build #198775 of artiq:zynq-beta:zc706-acpki_nist_qc2_master_100mhz-fsbl-sd
Hydra zc706-acpki_nist_qc2_master_100mhz-jtag Hydra build #198777 of artiq:zynq-beta:zc706-acpki_nist_qc2_master_100mhz-jtag
Hydra zc706-acpki_nist_qc2_master_100mhz-sd Hydra build #198778 of artiq:zynq-beta:zc706-acpki_nist_qc2_master_100mhz-sd
Hydra zc706-acpki_nist_qc2_satellite-fsbl-sd Hydra build #198780 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite-fsbl-sd
Hydra zc706-acpki_nist_qc2_satellite-jtag Hydra build #198782 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite-jtag
Hydra zc706-acpki_nist_qc2_satellite-sd Hydra build #198783 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite-sd
Hydra zc706-acpki_nist_qc2_satellite_100mhz-fsbl-sd Hydra build #198785 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite_100mhz-fsbl-sd
Hydra zc706-acpki_nist_qc2_satellite_100mhz-jtag Hydra build #198787 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite_100mhz-jtag
Hydra zc706-acpki_nist_qc2_satellite_100mhz-sd Hydra build #198788 of artiq:zynq-beta:zc706-acpki_nist_qc2_satellite_100mhz-sd
Hydra zc706-cxp_4r_fmc-fsbl-sd Hydra build #198790 of artiq:zynq-beta:zc706-cxp_4r_fmc-fsbl-sd
Hydra zc706-cxp_4r_fmc-jtag Hydra build #198792 of artiq:zynq-beta:zc706-cxp_4r_fmc-jtag
Hydra zc706-cxp_4r_fmc-sd Hydra build #198793 of artiq:zynq-beta:zc706-cxp_4r_fmc-sd
Hydra zc706-nist_clock_master_100mhz-gateware Hydra build #198807 of artiq:zynq-beta:zc706-nist_clock_master_100mhz-gateware
Hydra zc706-nist_clock-fsbl-sd Hydra build #198796 of artiq:zynq-beta:zc706-nist_clock-fsbl-sd
Hydra zc706-nist_clock-jtag Hydra build #198798 of artiq:zynq-beta:zc706-nist_clock-jtag
Hydra zc706-nist_clock-sd Hydra build #198799 of artiq:zynq-beta:zc706-nist_clock-sd
Hydra zc706-nist_clock_master-fsbl-sd Hydra build #198801 of artiq:zynq-beta:zc706-nist_clock_master-fsbl-sd
Hydra zc706-nist_clock_master-jtag Hydra build #198803 of artiq:zynq-beta:zc706-nist_clock_master-jtag
Hydra zc706-nist_clock_master-sd Hydra build #198804 of artiq:zynq-beta:zc706-nist_clock_master-sd
Hydra zc706-nist_clock_master_100mhz-fsbl-sd Hydra build #198806 of artiq:zynq-beta:zc706-nist_clock_master_100mhz-fsbl-sd
Hydra zc706-nist_clock_master_100mhz-sd Hydra build #198809 of artiq:zynq-beta:zc706-nist_clock_master_100mhz-sd
Hydra zc706-nist_clock_satellite_100mhz-fsbl-sd Hydra build #198816 of artiq:zynq-beta:zc706-nist_clock_satellite_100mhz-fsbl-sd
Hydra zc706-nist_clock_satellite_100mhz-jtag Hydra build #198818 of artiq:zynq-beta:zc706-nist_clock_satellite_100mhz-jtag
Hydra zc706-nist_clock_satellite_100mhz-sd Hydra build #198819 of artiq:zynq-beta:zc706-nist_clock_satellite_100mhz-sd
Hydra zc706-nist_qc2-fsbl-sd Hydra build #198821 of artiq:zynq-beta:zc706-nist_qc2-fsbl-sd
Hydra zc706-nist_qc2-sd Hydra build #198824 of artiq:zynq-beta:zc706-nist_qc2-sd
Hydra zc706-nist_qc2_satellite-fsbl-sd Hydra build #198836 of artiq:zynq-beta:zc706-nist_qc2_satellite-fsbl-sd
Hydra zc706-nist_qc2_satellite-jtag Hydra build #198838 of artiq:zynq-beta:zc706-nist_qc2_satellite-jtag
Hydra zc706-nist_qc2_satellite-sd Hydra build #198839 of artiq:zynq-beta:zc706-nist_qc2_satellite-sd
Hydra zc706-nist_qc2_satellite_100mhz-fsbl-sd Hydra build #198841 of artiq:zynq-beta:zc706-nist_qc2_satellite_100mhz-fsbl-sd
Hydra zc706-nist_qc2_satellite_100mhz-jtag Hydra build #198843 of artiq:zynq-beta:zc706-nist_qc2_satellite_100mhz-jtag
Hydra zc706-nist_qc2_satellite_100mhz-sd Hydra build #198844 of artiq:zynq-beta:zc706-nist_qc2_satellite_100mhz-sd
Hydra zc706-nist_clock_satellite-gateware Hydra build #198812 of artiq:zynq-beta:zc706-nist_clock_satellite-gateware
Hydra zc706-nist_clock_satellite-jtag Hydra build #198813 of artiq:zynq-beta:zc706-nist_clock_satellite-jtag
Hydra zc706-nist_clock_satellite-fsbl-sd Hydra build #198811 of artiq:zynq-beta:zc706-nist_clock_satellite-fsbl-sd
Hydra zc706-nist_clock_satellite-sd Hydra build #198814 of artiq:zynq-beta:zc706-nist_clock_satellite-sd
Hydra zc706-nist_qc2_master-gateware Hydra build #198827 of artiq:zynq-beta:zc706-nist_qc2_master-gateware
Hydra zc706-nist_qc2_master-jtag Hydra build #198828 of artiq:zynq-beta:zc706-nist_qc2_master-jtag
Hydra zc706-nist_qc2_master-fsbl-sd Hydra build #198826 of artiq:zynq-beta:zc706-nist_qc2_master-fsbl-sd
Hydra zc706-nist_qc2_master-sd Hydra build #198829 of artiq:zynq-beta:zc706-nist_qc2_master-sd
Hydra kasli_soc-demo-gateware Hydra build #198727 of artiq:zynq-beta:kasli_soc-demo-gateware
Hydra kasli_soc-demo-jtag Hydra build #198728 of artiq:zynq-beta:kasli_soc-demo-jtag
Hydra kasli_soc-demo-sd Hydra build #198729 of artiq:zynq-beta:kasli_soc-demo-sd
Hydra zc706-nist_qc2_master_100mhz-gateware Hydra build #198832 of artiq:zynq-beta:zc706-nist_qc2_master_100mhz-gateware
Hydra zc706-nist_qc2_master_100mhz-fsbl-sd Hydra build #198831 of artiq:zynq-beta:zc706-nist_qc2_master_100mhz-fsbl-sd
Hydra zc706-nist_qc2_master_100mhz-jtag Hydra build #198833 of artiq:zynq-beta:zc706-nist_qc2_master_100mhz-jtag
Hydra zc706-nist_qc2_master_100mhz-sd Hydra build #198834 of artiq:zynq-beta:zc706-nist_qc2_master_100mhz-sd
Hydra kasli_soc-master-gateware Hydra build #198731 of artiq:zynq-beta:kasli_soc-master-gateware
Hydra kasli_soc-master-jtag Hydra build #198732 of artiq:zynq-beta:kasli_soc-master-jtag
Hydra kasli_soc-master-sd Hydra build #198733 of artiq:zynq-beta:kasli_soc-master-sd
Hydra kasli_soc-satellite-gateware Hydra build #198735 of artiq:zynq-beta:kasli_soc-satellite-gateware
Hydra kasli_soc-satellite-jtag Hydra build #198736 of artiq:zynq-beta:kasli_soc-satellite-jtag
Hydra kasli_soc-satellite-sd Hydra build #198737 of artiq:zynq-beta:kasli_soc-satellite-sd
Hydra zc706-acpki-hitl-tests Hydra build #198738 of artiq:zynq-beta:zc706-acpki-hitl-tests
Hydra zc706-hitl-tests Hydra build #198794 of artiq:zynq-beta:zc706-hitl-tests

This commit was merged in pull request #470.
This commit is contained in:
2026-04-16 17:12:48 +08:00
committed by sb10q
parent bb9e3f49c6
commit 281fffb208

View File

@@ -330,7 +330,6 @@ pub extern "C" fn batch_end() {
asm::sev();
// start cleaning up before reading status
OUT_BUFFER.running = BATCH_DISABLED;
L2_TEXT_TABLE.remap_section(&__rtio_page as *const _ as u32, &__rtio_page as *const _ as u32);
let status = loop {
let status = IN_BUFFER.reply_status.get();
@@ -339,6 +338,7 @@ pub extern "C" fn batch_end() {
break status & !(1 << 16);
}
};
OUT_BUFFER.running = BATCH_DISABLED;
if status != 0 {
let ptr = IN_BUFFER.reply_batch_cnt.get();
let target = OUT_BUFFER.transactions[ptr as usize].request_target >> 8;