From 515c21857b3c848b104f0a86b664b505cb3cb8b9 Mon Sep 17 00:00:00 2001 From: thealmarty <“thealmartyblog@gmail.com”> Date: Wed, 24 Apr 2024 08:21:59 -0700 Subject: [PATCH 1/2] Change memory to little endian format. --- machine/src/core.rs | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/machine/src/core.rs b/machine/src/core.rs index 51120003..d753bb29 100644 --- a/machine/src/core.rs +++ b/machine/src/core.rs @@ -3,7 +3,7 @@ use core::cmp::Ordering; use core::ops::{Add, BitAnd, BitOr, BitXor, Div, Index, IndexMut, Mul, Shl, Shr, Sub}; use p3_field::{Field, PrimeField}; -// Currently stored in big-endian form. +// Stored in little-endian form, to avoid conversion between the compiler and the VM, and to be consistent with our file format. #[derive(Copy, Clone, Debug, Default)] pub struct Word(pub [F; MEMORY_CELL_BYTES]); @@ -18,6 +18,7 @@ pub fn addr_of_word(addr: u32) -> u32 { (addr & !3) as u32 } +/// Check that an address is a multiple of 4. pub fn is_mul_4(addr: u32) -> bool { addr.rem_euclid(4) == 0 } @@ -26,7 +27,7 @@ pub fn is_mul_4(addr: u32) -> bool { impl Word { pub fn from_u8(byte: u8) -> Self { let mut result = [0; MEMORY_CELL_BYTES]; - result[MEMORY_CELL_BYTES - 1] = byte; + result[0] = byte; Self(result) } } @@ -35,7 +36,7 @@ impl Word { pub fn sign_extend_byte(byte: u8) -> Self { let sign = byte as i8 >> 7; let mut result: [u8; MEMORY_CELL_BYTES] = [sign as u8; MEMORY_CELL_BYTES]; - result[3] = byte; + result[0] = byte; Self(result) } } @@ -56,7 +57,7 @@ impl Word { { let mut result: [T; MEMORY_CELL_BYTES] = [T::default(); MEMORY_CELL_BYTES]; for (i, item) in self.0.iter().enumerate() { - result[i] = f(*item); + result[3 - i] = f(*item); } Word(result) } @@ -76,7 +77,7 @@ impl Into for Word { fn into(self) -> u32 { let mut result = 0u32; for i in 0..MEMORY_CELL_BYTES { - result += (self[MEMORY_CELL_BYTES - i - 1] as u32) << (i * 8); + result += (self[i] as u32) << (i * 8); } result } @@ -86,7 +87,7 @@ impl From for Word { fn from(value: u32) -> Self { let mut result = Word::::default(); for i in 0..MEMORY_CELL_BYTES { - result[MEMORY_CELL_BYTES - i - 1] = ((value >> (i * 8)) & 0xFF) as u8; + result[i] = ((value >> (i * 8)) & 0xFF) as u8; } result } @@ -272,7 +273,7 @@ impl BitOr for Word { impl From for Word { fn from(bytes: F) -> Self { - Self([F::zero(), F::zero(), F::zero(), bytes]) + Self([bytes, F::zero(), F::zero(), F::zero()]) } } From 2fbea654f28576feaec0f2fe95c7b10e0b7fb001 Mon Sep 17 00:00:00 2001 From: thealmarty <“thealmartyblog@gmail.com”> Date: Wed, 24 Apr 2024 09:00:14 -0700 Subject: [PATCH 2/2] wip --- alu_u32/src/add/mod.rs | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/alu_u32/src/add/mod.rs b/alu_u32/src/add/mod.rs index 1c8b7ba1..f7e97064 100644 --- a/alu_u32/src/add/mod.rs +++ b/alu_u32/src/add/mod.rs @@ -103,17 +103,17 @@ impl Add32Chip { let mut carry_1 = 0; let mut carry_2 = 0; - if b[3] as u32 + c[3] as u32 > 255 { + if b[0] as u32 + c[0] as u32 > 255 { carry_1 = 1; - cols.carry[0] = F::one(); + cols.carry[3] = F::one(); } - if b[2] as u32 + c[2] as u32 + carry_1 > 255 { + if b[1] as u32 + c[1] as u32 + carry_1 > 255 { carry_2 = 1; - cols.carry[1] = F::one(); - } - if b[1] as u32 + c[1] as u32 + carry_2 > 255 { cols.carry[2] = F::one(); } + if b[2] as u32 + c[2] as u32 + carry_2 > 255 { + cols.carry[1] = F::one(); + } cols.is_real = F::one(); } }