bump rustc, llvm #348

Merged
sb10q merged 11 commits from srenblad/artiq-zynq:bump_to_llvm13 into master 2024-12-23 10:46:46 +08:00
2 changed files with 4 additions and 0 deletions
Showing only changes of commit 81eba30a29 - Show all commits

View File

@ -2,6 +2,7 @@
use alloc::vec::Vec; use alloc::vec::Vec;
use core_io::{Error as IoError, Read, Write}; use core_io::{Error as IoError, Read, Write};
use core::arch::asm;
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct Cursor<T> { pub struct Cursor<T> {
@ -47,6 +48,7 @@ impl<T: AsRef<[u8]>> Read for Cursor<T> {
let len = buf.len().min(data.len()); let len = buf.len().min(data.len());
// ``copy_from_slice`` generates AXI bursts, use a regular loop instead // ``copy_from_slice`` generates AXI bursts, use a regular loop instead
for i in 0..len { for i in 0..len {
unsafe { asm!("", options(preserves_flags, nostack, readonly)); }
buf[i] = data[i]; buf[i] = data[i];
} }
self.pos += len; self.pos += len;
@ -59,6 +61,7 @@ impl Write for Cursor<&mut [u8]> {
let data = &mut self.inner[self.pos..]; let data = &mut self.inner[self.pos..];
let len = buf.len().min(data.len()); let len = buf.len().min(data.len());
for i in 0..len { for i in 0..len {
unsafe { asm!("", options(preserves_flags, nostack, readonly)); }
Review

I think we can get rid of this hack altogether since memory is copied elsewhere when accessing the DRTIO aux buffers?
But this could be another PR.

I think we can get rid of this hack altogether since memory is copied elsewhere when accessing the DRTIO aux buffers? But this could be another PR.
data[i] = buf[i]; data[i] = buf[i];
} }
self.pos += len; self.pos += len;

View File

@ -1,5 +1,6 @@
#![no_std] #![no_std]
#![feature(never_type)] #![feature(never_type)]
#![feature(asm)]
#[cfg(feature = "alloc")] #[cfg(feature = "alloc")]
extern crate alloc; extern crate alloc;