From 7f7ad11943050676adc02d8f98ca6f66ff1dc397 Mon Sep 17 00:00:00 2001 From: Tim Crawford Date: Fri, 13 Dec 2024 17:21:20 -0700 Subject: [PATCH 1/3] tool: Format code Signed-off-by: Tim Crawford --- tool/src/access/hid.rs | 5 +- tool/src/access/lpc/direct.rs | 24 +-- tool/src/access/lpc/linux.rs | 30 +--- tool/src/access/lpc/sim.rs | 20 +-- tool/src/access/mod.rs | 10 +- tool/src/ec.rs | 135 +++++---------- tool/src/legacy.rs | 11 +- tool/src/lib.rs | 3 +- tool/src/main.rs | 299 ++++++++++++++++++---------------- tool/src/pmc.rs | 6 +- tool/src/spi.rs | 100 ++++++------ tool/src/timeout.rs | 4 +- 12 files changed, 275 insertions(+), 372 deletions(-) diff --git a/tool/src/access/hid.rs b/tool/src/access/hid.rs index 28fd89aaf..8f0f4eba4 100644 --- a/tool/src/access/hid.rs +++ b/tool/src/access/hid.rs @@ -2,10 +2,7 @@ use hidapi::HidDevice; -use crate::{ - Access, - Error, -}; +use crate::{Access, Error}; /// Use USB HID access, only for USB ECs pub struct AccessHid { diff --git a/tool/src/access/lpc/direct.rs b/tool/src/access/lpc/direct.rs index 9c53dbed2..2c4a4e5c0 100644 --- a/tool/src/access/lpc/direct.rs +++ b/tool/src/access/lpc/direct.rs @@ -2,13 +2,7 @@ use hwio::{Io, Pio}; -use crate::{ - Access, - Error, - SuperIo, - Timeout, - timeout, -}; +use crate::{timeout, Access, Error, SuperIo, Timeout}; use super::*; @@ -24,9 +18,7 @@ impl AccessLpcDirect { pub unsafe fn new(timeout: T) -> Result { // Make sure EC ID matches let mut sio = SuperIo::new(0x2E); - let id = - (sio.read(0x20) as u16) << 8 | - (sio.read(0x21) as u16); + let id = (sio.read(0x20) as u16) << 8 | (sio.read(0x21) as u16); match id { 0x5570 | 0x8587 => (), _ => return Err(Error::SuperIoId(id)), @@ -41,24 +33,18 @@ impl AccessLpcDirect { /// Read from the command space unsafe fn read_cmd(&mut self, addr: u8) -> u8 { - Pio::::new( - self.cmd + (addr as u16) - ).read() + Pio::::new(self.cmd + (addr as u16)).read() } /// Write to the command space unsafe fn write_cmd(&mut self, addr: u8, data: u8) { - Pio::::new( - self.cmd + (addr as u16) - ).write(data) + Pio::::new(self.cmd + (addr as u16)).write(data) } /// Read from the debug space //TODO: better public interface pub unsafe fn read_debug(&mut self, addr: u8) -> u8 { - Pio::::new( - self.dbg + (addr as u16) - ).read() + Pio::::new(self.dbg + (addr as u16)).read() } /// Returns Ok if a command can be sent diff --git a/tool/src/access/lpc/linux.rs b/tool/src/access/lpc/linux.rs index f26a24806..b4dd46cd9 100644 --- a/tool/src/access/lpc/linux.rs +++ b/tool/src/access/lpc/linux.rs @@ -2,25 +2,13 @@ use std::{ fs, - io::{ - self, - Read, - Write, - Seek, - SeekFrom, - }, + io::{self, Read, Seek, SeekFrom, Write}, os::unix::io::AsRawFd, path::Path, time::Duration, }; -use crate::{ - Access, - Error, - StdTimeout, - Timeout, - timeout, -}; +use crate::{timeout, Access, Error, StdTimeout, Timeout}; use super::*; @@ -35,7 +23,7 @@ impl PortLock { if end < start { return Err(io::Error::new( io::ErrorKind::InvalidInput, - "PortLock::new: end < start" + "PortLock::new: end < start", )); } let len = (end - start) + 1; @@ -57,18 +45,14 @@ impl PortLock { return Err(io::Error::last_os_error()); } - Ok(Self { - start, - len, - file, - }) + Ok(Self { start, len, file }) } fn seek(&mut self, offset: u16) -> io::Result<()> { if offset >= self.len { return Err(io::Error::new( io::ErrorKind::InvalidInput, - "PortLock::seek: offset >= len" + "PortLock::seek: offset >= len", )); } let port = self.start + offset; @@ -76,7 +60,7 @@ impl PortLock { if pos != port as u64 { return Err(io::Error::new( io::ErrorKind::UnexpectedEof, - "PortLock::seek: failed to seek to port" + "PortLock::seek: failed to seek to port", )); } Ok(()) @@ -106,7 +90,7 @@ impl AccessLpcLinux { /// Locks ports and then returns access object pub unsafe fn new(timeout: Duration) -> Result { // TODO: is there a better way to probe before running a command? - if ! Path::new("/sys/bus/acpi/devices/17761776:00").is_dir() { + if !Path::new("/sys/bus/acpi/devices/17761776:00").is_dir() { return Err(Error::Io(io::Error::new( io::ErrorKind::NotFound, "Failed to find System76 ACPI device", diff --git a/tool/src/access/lpc/sim.rs b/tool/src/access/lpc/sim.rs index 46f3b243c..b563054e8 100644 --- a/tool/src/access/lpc/sim.rs +++ b/tool/src/access/lpc/sim.rs @@ -1,18 +1,8 @@ // SPDX-License-Identifier: MIT -use std::{ - io, - net::UdpSocket, - time::Duration, -}; - -use crate::{ - Access, - Error, - StdTimeout, - Timeout, - timeout, -}; +use std::{io, net::UdpSocket, time::Duration}; + +use crate::{timeout, Access, Error, StdTimeout, Timeout}; use super::*; @@ -39,7 +29,7 @@ impl AccessLpcSim { if self.socket.send(&request)? != request.len() { return Err(io::Error::new( io::ErrorKind::UnexpectedEof, - "Socket request incorrect size" + "Socket request incorrect size", )); } @@ -47,7 +37,7 @@ impl AccessLpcSim { if self.socket.recv(&mut response)? != response.len() { return Err(io::Error::new( io::ErrorKind::UnexpectedEof, - "Socket response incorrect size" + "Socket response incorrect size", )); } diff --git a/tool/src/access/mod.rs b/tool/src/access/mod.rs index 32ebcb8c0..dad443340 100644 --- a/tool/src/access/mod.rs +++ b/tool/src/access/mod.rs @@ -11,15 +11,9 @@ pub use self::hid::AccessHid; #[cfg(feature = "hidapi")] mod hid; -#[cfg(any( - feature = "redox_hwio", - all(feature = "std", target_os = "linux") -))] +#[cfg(any(feature = "redox_hwio", all(feature = "std", target_os = "linux")))] pub use self::lpc::*; -#[cfg(any( - feature = "redox_hwio", - all(feature = "std", target_os = "linux") -))] +#[cfg(any(feature = "redox_hwio", all(feature = "std", target_os = "linux")))] mod lpc; /// Access method for running an EC command diff --git a/tool/src/ec.rs b/tool/src/ec.rs index 0bd793784..ae2111954 100644 --- a/tool/src/ec.rs +++ b/tool/src/ec.rs @@ -1,18 +1,10 @@ // SPDX-License-Identifier: MIT #[cfg(not(feature = "std"))] -use alloc::{ - boxed::Box, - vec, -}; +use alloc::{boxed::Box, vec}; use core::convert::TryFrom; -use crate::{ - Access, - Error, - Spi, - SpiTarget, -}; +use crate::{Access, Error, Spi, SpiTarget}; #[derive(Clone, Copy, Debug, Eq, PartialEq)] #[repr(u8)] @@ -83,10 +75,7 @@ impl Ec { /// Probes for a compatible EC pub unsafe fn new(access: A) -> Result { // Create EC struct with provided access method and timeout - let mut ec = Ec { - access, - version: 0, - }; + let mut ec = Ec { access, version: 0 }; // Read version of protocol ec.version = ec.probe()?; @@ -188,117 +177,76 @@ impl Ec { /// Read fan duty cycle by fan index pub unsafe fn fan_get(&mut self, index: u8) -> Result { - let mut data = [ - index, - 0 - ]; + let mut data = [index, 0]; self.command(Cmd::FanGet, &mut data)?; Ok(data[1]) } /// Set fan duty cycle by fan index pub unsafe fn fan_set(&mut self, index: u8, duty: u8) -> Result<(), Error> { - let mut data = [ - index, - duty - ]; + let mut data = [index, duty]; self.command(Cmd::FanSet, &mut data) } /// Read keymap data by layout, output pin, and input pin pub unsafe fn keymap_get(&mut self, layer: u8, output: u8, input: u8) -> Result { - let mut data = [ - layer, - output, - input, - 0, - 0 - ]; + let mut data = [layer, output, input, 0, 0]; self.command(Cmd::KeymapGet, &mut data)?; - Ok( - (data[3] as u16) | - ((data[4] as u16) << 8) - ) + Ok((data[3] as u16) | ((data[4] as u16) << 8)) } /// Set keymap data by layout, output pin, and input pin - pub unsafe fn keymap_set(&mut self, layer: u8, output: u8, input: u8, value: u16) -> Result<(), Error> { - let mut data = [ - layer, - output, - input, - value as u8, - (value >> 8) as u8 - ]; + pub unsafe fn keymap_set( + &mut self, + layer: u8, + output: u8, + input: u8, + value: u16, + ) -> Result<(), Error> { + let mut data = [layer, output, input, value as u8, (value >> 8) as u8]; self.command(Cmd::KeymapSet, &mut data) } // Get LED value by index pub unsafe fn led_get_value(&mut self, index: u8) -> Result<(u8, u8), Error> { - let mut data = [ - index, - 0, - 0, - ]; + let mut data = [index, 0, 0]; self.command(Cmd::LedGetValue, &mut data)?; Ok((data[1], data[2])) } // Set LED value by index pub unsafe fn led_set_value(&mut self, index: u8, value: u8) -> Result<(), Error> { - let mut data = [ - index, - value, - ]; + let mut data = [index, value]; self.command(Cmd::LedSetValue, &mut data) } // Get LED color by index pub unsafe fn led_get_color(&mut self, index: u8) -> Result<(u8, u8, u8), Error> { - let mut data = [ - index, - 0, - 0, - 0, - ]; + let mut data = [index, 0, 0, 0]; self.command(Cmd::LedGetColor, &mut data)?; - Ok(( - data[1], - data[2], - data[3], - )) + Ok((data[1], data[2], data[3])) } // Set LED color by index - pub unsafe fn led_set_color(&mut self, index: u8, red: u8, green: u8, blue: u8) -> Result<(), Error> { - let mut data = [ - index, - red, - green, - blue, - ]; + pub unsafe fn led_set_color( + &mut self, + index: u8, + red: u8, + green: u8, + blue: u8, + ) -> Result<(), Error> { + let mut data = [index, red, green, blue]; self.command(Cmd::LedSetColor, &mut data) } pub unsafe fn led_get_mode(&mut self, layer: u8) -> Result<(u8, u8), Error> { - let mut data = [ - layer, - 0, - 0, - ]; + let mut data = [layer, 0, 0]; self.command(Cmd::LedGetMode, &mut data)?; - Ok(( - data[1], - data[2] - )) + Ok((data[1], data[2])) } pub unsafe fn led_set_mode(&mut self, layer: u8, mode: u8, speed: u8) -> Result<(), Error> { - let mut data = [ - layer, - mode, - speed, - ]; + let mut data = [layer, mode, speed]; self.command(Cmd::LedSetMode, &mut data) } @@ -316,23 +264,24 @@ impl Ec { /// Get security state pub unsafe fn security_get(&mut self) -> Result { - let mut data = [0]; - self.command(Cmd::SecurityGet, &mut data)?; - SecurityState::try_from(data[0]) + let mut data = [0]; + self.command(Cmd::SecurityGet, &mut data)?; + SecurityState::try_from(data[0]) } /// Set security state pub unsafe fn security_set(&mut self, state: SecurityState) -> Result<(), Error> { - let mut data = [state as u8]; - self.command(Cmd::SecuritySet, &mut data) + let mut data = [state as u8]; + self.command(Cmd::SecuritySet, &mut data) } pub fn into_dyn(self) -> Ec> - where A: 'static { + where + A: 'static, + { Ec { access: Box::new(self.access), version: self.version, - } } } @@ -364,7 +313,7 @@ impl<'a, A: Access> EcSpi<'a, A> { SpiTarget::Main => (), SpiTarget::Backup => { flags |= CMD_SPI_FLAG_BACKUP; - }, + } } flags @@ -394,7 +343,8 @@ impl<'a, A: Access> Spi for EcSpi<'a, A> { for chunk in data.chunks_mut(self.buffer.len() - 2) { self.buffer[0] = flags; self.buffer[1] = chunk.len() as u8; - self.ec.command(Cmd::Spi, &mut self.buffer[..(chunk.len() + 2)])?; + self.ec + .command(Cmd::Spi, &mut self.buffer[..(chunk.len() + 2)])?; if self.buffer[1] != chunk.len() as u8 { return Err(Error::Verify); } @@ -414,7 +364,8 @@ impl<'a, A: Access> Spi for EcSpi<'a, A> { for i in 0..chunk.len() { self.buffer[i + 2] = chunk[i]; } - self.ec.command(Cmd::Spi, &mut self.buffer[..(chunk.len() + 2)])?; + self.ec + .command(Cmd::Spi, &mut self.buffer[..(chunk.len() + 2)])?; if self.buffer[1] != chunk.len() as u8 { return Err(Error::Verify); } diff --git a/tool/src/legacy.rs b/tool/src/legacy.rs index bc698bc6e..1ebc6cbea 100644 --- a/tool/src/legacy.rs +++ b/tool/src/legacy.rs @@ -1,11 +1,6 @@ // SPDX-License-Identifier: MIT -use crate::{ - Error, - Pmc, - SuperIo, - Timeout, -}; +use crate::{Error, Pmc, SuperIo, Timeout}; /// Run some EC commands on previous proprietary firmware pub struct EcLegacy { @@ -17,9 +12,7 @@ impl EcLegacy { pub unsafe fn new(primary: bool, timeout: T) -> Result { let mut sio = SuperIo::new(if primary { 0x2E } else { 0x4E }); - let id = - (sio.read(0x20) as u16) << 8 | - (sio.read(0x21) as u16); + let id = (sio.read(0x20) as u16) << 8 | (sio.read(0x21) as u16); match id { 0x5570 | 0x8587 => (), diff --git a/tool/src/lib.rs b/tool/src/lib.rs index 5afcac464..72bd0df64 100644 --- a/tool/src/lib.rs +++ b/tool/src/lib.rs @@ -16,7 +16,6 @@ #![allow(clippy::missing_safety_doc)] #![allow(clippy::needless_range_loop)] - #![cfg_attr(not(feature = "std"), no_std)] #[cfg(not(feature = "std"))] @@ -52,7 +51,7 @@ pub use self::super_io::SuperIo; #[cfg(feature = "redox_hwio")] mod super_io; -pub use self::timeout::Timeout; #[cfg(feature = "std")] pub use self::timeout::StdTimeout; +pub use self::timeout::Timeout; mod timeout; diff --git a/tool/src/main.rs b/tool/src/main.rs index a31da3fe9..b49747761 100644 --- a/tool/src/main.rs +++ b/tool/src/main.rs @@ -4,27 +4,11 @@ use clap::Parser; use ectool::{ - Access, - AccessHid, - AccessLpcLinux, - AccessLpcSim, - Ec, - Error, - Firmware, - SecurityState, - StdTimeout, - Spi, - SpiRom, - SpiTarget, + Access, AccessHid, AccessLpcLinux, AccessLpcSim, Ec, Error, Firmware, SecurityState, Spi, + SpiRom, SpiTarget, StdTimeout, }; use hidapi::HidApi; -use std::{ - fs, - process, - str, - time::Duration, - thread, -}; +use std::{fs, process, str, thread, time::Duration}; unsafe fn console(ec: &mut Ec>) -> Result<(), Error> { //TODO: driver support for reading debug region? @@ -38,7 +22,9 @@ unsafe fn console(ec: &mut Ec>) -> Result<(), Error> { } else { while head != tail { head += 1; - if head >= 256 { head = 1; } + if head >= 256 { + head = 1; + } let c = access.read_debug(head as u8)?; print!("{}", c as char); } @@ -46,14 +32,21 @@ unsafe fn console(ec: &mut Ec>) -> Result<(), Error> { } } -unsafe fn flash_read(spi: &mut SpiRom, rom: &mut [u8], sector_size: usize) -> Result<(), Error> { +unsafe fn flash_read( + spi: &mut SpiRom, + rom: &mut [u8], + sector_size: usize, +) -> Result<(), Error> { let mut address = 0; while address < rom.len() { eprint!("\rSPI Read {}K", address / 1024); let next_address = address + sector_size; let count = spi.read_at(address as u32, &mut rom[address..next_address])?; if count != sector_size { - eprintln!("\ncount {} did not match sector size {}", count, sector_size); + eprintln!( + "\ncount {} did not match sector size {}", + count, sector_size + ); return Err(Error::Verify); } address = next_address; @@ -62,7 +55,12 @@ unsafe fn flash_read(spi: &mut SpiRom, rom: &mut [u8], se Ok(()) } -unsafe fn flash_inner(ec: &mut Ec>, firmware: &Firmware, target: SpiTarget, scratch: bool) -> Result<(), Error> { +unsafe fn flash_inner( + ec: &mut Ec>, + firmware: &Firmware, + target: SpiTarget, + scratch: bool, +) -> Result<(), Error> { let new_rom = firmware.data.to_vec(); // XXX: Get flash size programatically? @@ -73,10 +71,7 @@ unsafe fn flash_inner(ec: &mut Ec>, firmware: &Firmware, target: } let mut spi_bus = ec.spi(target, scratch)?; - let mut spi = SpiRom::new( - &mut spi_bus, - StdTimeout::new(Duration::new(1, 0)) - ); + let mut spi = SpiRom::new(&mut spi_bus, StdTimeout::new(Duration::new(1, 0))); let sector_size = spi.sector_size(); let mut rom = vec![0xFF; rom_size]; @@ -109,14 +104,17 @@ unsafe fn flash_inner(ec: &mut Ec>, firmware: &Firmware, target: } } - if ! matches { - if ! erased { + if !matches { + if !erased { spi.erase_sector(address as u32)?; } - if ! new_erased { + if !new_erased { let count = spi.write_at(address as u32, &new_rom[address..next_address])?; if count != sector_size { - eprintln!("\nWrite count {} did not match sector size {}", count, sector_size); + eprintln!( + "\nWrite count {} did not match sector size {}", + count, sector_size + ); return Err(Error::Verify); } } @@ -130,7 +128,10 @@ unsafe fn flash_inner(ec: &mut Ec>, firmware: &Firmware, target: flash_read(&mut spi, &mut rom, sector_size)?; for i in 0..rom.len() { if rom[i] != new_rom[i] { - eprintln!("Failed to program: {:X} is {:X} instead of {:X}", i, rom[i], new_rom[i]); + eprintln!( + "Failed to program: {:X} is {:X} instead of {:X}", + i, rom[i], new_rom[i] + ); return Err(Error::Verify); } } @@ -159,7 +160,10 @@ unsafe fn flash(ec: &mut Ec>, path: &str, target: SpiTarget) -> let ec_board = &data[..size]; println!("ec board: {:?}", str::from_utf8(ec_board)); - assert!(ec_board == firmware.board, "file board does not match ec board"); + assert!( + ec_board == firmware.board, + "file board does not match ec board" + ); } { @@ -277,14 +281,25 @@ unsafe fn fan_set(ec: &mut Ec>, index: u8, duty: u8) -> Result<( ec.fan_set(index, duty) } -unsafe fn keymap_get(ec: &mut Ec>, layer: u8, output: u8, input: u8) -> Result<(), Error> { +unsafe fn keymap_get( + ec: &mut Ec>, + layer: u8, + output: u8, + input: u8, +) -> Result<(), Error> { let value = ec.keymap_get(layer, output, input)?; println!("{:04X}", value); Ok(()) } -unsafe fn keymap_set(ec: &mut Ec>, layer: u8, output: u8, input: u8, value: u16) -> Result<(), Error> { +unsafe fn keymap_set( + ec: &mut Ec>, + layer: u8, + output: u8, + input: u8, + value: u16, +) -> Result<(), Error> { ec.keymap_set(layer, output, input, value) } @@ -311,7 +326,6 @@ fn parse_color(s: &str) -> Result<(u8, u8, u8), String> { } } - #[derive(Parser)] #[clap(rename_all = "snake_case")] enum SubCommand { @@ -373,11 +387,7 @@ enum AccessMode { #[derive(Parser)] #[clap(name = "system76_ectool")] struct Args { - #[clap( - long = "access", - value_enum, - default_value = "lpc-linux", - )] + #[clap(long = "access", value_enum, default_value = "lpc-linux")] access: AccessMode, #[clap(subcommand)] subcommand: SubCommand, @@ -392,11 +402,11 @@ fn main() { AccessMode::LpcLinux => { let access = AccessLpcLinux::new(Duration::new(1, 0))?; Ok(Ec::new(access)?.into_dyn()) - }, + } AccessMode::LpcSim => { let access = AccessLpcSim::new(Duration::new(1, 0))?; Ok(Ec::new(access)?.into_dyn()) - }, + } AccessMode::Hid => { let api = HidApi::new()?; for info in api.device_list() { @@ -436,33 +446,29 @@ fn main() { Err(err) => { eprintln!("failed to read console: {:X?}", err); process::exit(1); - }, - }, - SubCommand::Fan { index, duty } => { - match duty { - Some(duty) => match unsafe { fan_set(&mut ec, index, duty) } { - Ok(()) => (), - Err(err) => { - eprintln!("failed to set fan {} to {}: {:X?}", index, duty, err); - process::exit(1); - }, - }, - None => match unsafe { fan_get(&mut ec, index) } { - Ok(()) => (), - Err(err) => { - eprintln!("failed to get fan {}: {:X?}", index, err); - process::exit(1); - }, - }, } }, - SubCommand::Flash { path } => { - match unsafe { flash(&mut ec, &path, SpiTarget::Main) } { + SubCommand::Fan { index, duty } => match duty { + Some(duty) => match unsafe { fan_set(&mut ec, index, duty) } { Ok(()) => (), Err(err) => { - eprintln!("failed to flash '{}': {:X?}", path, err); + eprintln!("failed to set fan {} to {}: {:X?}", index, duty, err); process::exit(1); - }, + } + }, + None => match unsafe { fan_get(&mut ec, index) } { + Ok(()) => (), + Err(err) => { + eprintln!("failed to get fan {}: {:X?}", index, err); + process::exit(1); + } + }, + }, + SubCommand::Flash { path } => match unsafe { flash(&mut ec, &path, SpiTarget::Main) } { + Ok(()) => (), + Err(err) => { + eprintln!("failed to flash '{}': {:X?}", path, err); + process::exit(1); } }, SubCommand::FlashBackup { path } => { @@ -471,39 +477,48 @@ fn main() { Err(err) => { eprintln!("failed to flash '{}': {:X?}", path, err); process::exit(1); - }, + } } - }, + } SubCommand::Info => match unsafe { info(&mut ec) } { Ok(()) => (), Err(err) => { eprintln!("failed to read info: {:X?}", err); process::exit(1); - }, + } }, - SubCommand::Keymap { layer, output, input, value } => { - match value { - Some(value_str) => match u16::from_str_radix(value_str.trim_start_matches("0x"), 16) { - Ok(value) => match unsafe { keymap_set(&mut ec, layer, output, input, value) } { - Ok(()) => (), - Err(err) => { - eprintln!("failed to set keymap {}, {}, {} to {}: {:X?}", layer, output, input, value, err); - process::exit(1); - }, - }, - Err(err) => { - eprintln!("failed to parse value: '{}': {}", value_str, err); - process::exit(1); - } - }, - None => match unsafe { keymap_get(&mut ec, layer, output, input) } { + SubCommand::Keymap { + layer, + output, + input, + value, + } => match value { + Some(value_str) => match u16::from_str_radix(value_str.trim_start_matches("0x"), 16) { + Ok(value) => match unsafe { keymap_set(&mut ec, layer, output, input, value) } { Ok(()) => (), Err(err) => { - eprintln!("failed to get keymap {}, {}, {}: {:X?}", layer, output, input, err); + eprintln!( + "failed to set keymap {}, {}, {} to {}: {:X?}", + layer, output, input, value, err + ); process::exit(1); - }, + } }, - } + Err(err) => { + eprintln!("failed to parse value: '{}': {}", value_str, err); + process::exit(1); + } + }, + None => match unsafe { keymap_get(&mut ec, layer, output, input) } { + Ok(()) => (), + Err(err) => { + eprintln!( + "failed to get keymap {}, {}, {}: {:X?}", + layer, output, input, err + ); + process::exit(1); + } + }, }, SubCommand::LedColor { index, value } => { if let Some(value) = value { @@ -513,7 +528,7 @@ fn main() { Err(err) => { eprintln!("failed to set color {}: {:X?}", value, err); process::exit(1); - }, + } } } else { match unsafe { ec.led_get_color(index) } { @@ -521,10 +536,10 @@ fn main() { Err(err) => { eprintln!("failed to get color: {:X?}", err); process::exit(1); - }, + } } } - }, + } SubCommand::LedValue { index, value } => { if let Some(value) = value { match unsafe { ec.led_set_value(index, value) } { @@ -532,111 +547,115 @@ fn main() { Err(err) => { eprintln!("failed to set value {}: {:X?}", value, err); process::exit(1); - }, + } } } else { match unsafe { ec.led_get_value(index) } { Ok((value, max)) => { println!("value: {}", value); println!("max: {}", max); - }, + } Err(err) => { eprintln!("failed to get value: {:X?}", err); process::exit(1); - }, + } } } - }, + } SubCommand::LedMode { layer, mode, speed } => { if let (Some(mode), Some(speed)) = (mode, speed) { match unsafe { ec.led_set_mode(layer, mode, speed) } { Ok(()) => (), Err(err) => { - eprintln!("failed to set layer {} mode {} at speed {}: {:X?}", layer, mode, speed, err); + eprintln!( + "failed to set layer {} mode {} at speed {}: {:X?}", + layer, mode, speed, err + ); process::exit(1); - }, + } } } else { match unsafe { ec.led_get_mode(layer) } { Ok((mode, speed)) => { println!("mode: {}", mode); println!("speed: {}", speed); - }, + } Err(err) => { eprintln!("failed to get mode for layer {}: {:X?}", layer, err); process::exit(1); - }, + } } } - }, + } SubCommand::LedSave => match unsafe { ec.led_save() } { Ok(()) => (), Err(err) => { eprintln!("failed to save LED settings: {:X?}", err); process::exit(1); - }, + } }, SubCommand::Reset => match unsafe { ec.reset() } { Ok(()) => (), Err(err) => { eprintln!("failed to reset device: {:X?}", err); process::exit(1); - }, + } }, SubCommand::Matrix => match unsafe { matrix(&mut ec) } { Ok(()) => (), Err(err) => { eprintln!("failed to read matrix: {:X?}", err); process::exit(1); - }, - }, - SubCommand::Print { message } => for arg in message { - let mut arg = arg.to_owned(); - arg.push('\n'); - match unsafe { print(&mut ec, arg.as_bytes()) } { - Ok(()) => (), - Err(err) => { - eprintln!("failed to print '{}': {:X?}", arg, err); - process::exit(1); - }, } }, - SubCommand::SetNoInput { value } => { - match unsafe { ec.set_no_input(value) } { - Ok(()) => (), - Err(err) => { - eprintln!("failed to set no_input mode: {:X?}", err); - process::exit(1); + SubCommand::Print { message } => { + for arg in message { + let mut arg = arg.to_owned(); + arg.push('\n'); + match unsafe { print(&mut ec, arg.as_bytes()) } { + Ok(()) => (), + Err(err) => { + eprintln!("failed to print '{}': {:X?}", arg, err); + process::exit(1); + } } } + } + SubCommand::SetNoInput { value } => match unsafe { ec.set_no_input(value) } { + Ok(()) => (), + Err(err) => { + eprintln!("failed to set no_input mode: {:X?}", err); + process::exit(1); + } }, - SubCommand::Security { state } => { - match state { - Some(value) => { - let state = match value.as_str() { - "lock" => SecurityState::PrepareLock, - "unlock" => SecurityState::PrepareUnlock, - _ => { - eprintln!("invalid security state '{}': must be 'lock' or 'unlock'", value); - process::exit(1); - } - }; - match unsafe { security_set(&mut ec, state) } { - Ok(()) => (), - Err(err) => { - eprintln!("failed to set security state to '{}': {:X?}", value, err); - process::exit(1); - }, + SubCommand::Security { state } => match state { + Some(value) => { + let state = match value.as_str() { + "lock" => SecurityState::PrepareLock, + "unlock" => SecurityState::PrepareUnlock, + _ => { + eprintln!( + "invalid security state '{}': must be 'lock' or 'unlock'", + value + ); + process::exit(1); } - }, - None => match unsafe { security_get(&mut ec) } { + }; + match unsafe { security_set(&mut ec, state) } { Ok(()) => (), Err(err) => { - eprintln!("failed to get security state: {:X?}", err); + eprintln!("failed to set security state to '{}': {:X?}", value, err); process::exit(1); - }, - }, + } + } } + None => match unsafe { security_get(&mut ec) } { + Ok(()) => (), + Err(err) => { + eprintln!("failed to get security state: {:X?}", err); + process::exit(1); + } + }, }, } } diff --git a/tool/src/pmc.rs b/tool/src/pmc.rs index 6ebbc6360..d5ddfb457 100644 --- a/tool/src/pmc.rs +++ b/tool/src/pmc.rs @@ -2,11 +2,7 @@ use hwio::{Io, Pio}; -use crate::{ - Error, - Timeout, - timeout -}; +use crate::{timeout, Error, Timeout}; /// Standard ACPI EC interface pub struct Pmc { diff --git a/tool/src/spi.rs b/tool/src/spi.rs index abb6fe858..719dd437d 100644 --- a/tool/src/spi.rs +++ b/tool/src/spi.rs @@ -1,9 +1,6 @@ // SPDX-License-Identifier: MIT -use crate::{ - Error, - Timeout, -}; +use crate::{Error, Timeout}; /// SPI bus transactions pub trait Spi { @@ -38,10 +35,7 @@ pub struct SpiRom<'a, S: Spi, T: Timeout> { impl<'a, S: Spi, T: Timeout> SpiRom<'a, S, T> { /// Create a SPI ROM using the specified SPI bus and timeout pub fn new(spi: &'a mut S, timeout: T) -> Self { - Self { - spi, - timeout, - } + Self { spi, timeout } } /// Get sector size in bytes @@ -153,55 +147,55 @@ impl<'a, S: Spi, T: Timeout> SpiRom<'a, S, T> { //TODO: automatically detect write command match self.spi.target() { - SpiTarget::Main => for (i, word) in data.chunks(2).enumerate() { - #[allow(clippy::get_first)] - let low = *word.get(0).unwrap_or(&0xFF); - let high = *word.get(1).unwrap_or(&0xFF); - - self.spi.reset()?; - if i == 0 { - self.spi.write(&[ - 0xAD, - (address >> 16) as u8, - (address >> 8) as u8, - address as u8, - low, - high - ])?; - } else { + SpiTarget::Main => { + for (i, word) in data.chunks(2).enumerate() { + #[allow(clippy::get_first)] + let low = *word.get(0).unwrap_or(&0xFF); + let high = *word.get(1).unwrap_or(&0xFF); + + self.spi.reset()?; + if i == 0 { + self.spi.write(&[ + 0xAD, + (address >> 16) as u8, + (address >> 8) as u8, + address as u8, + low, + high, + ])?; + } else { + self.spi.write(&[0xAD, low, high])?; + } + + // Poll status for busy unset + self.status_wait(1, 0)?; + } + } + SpiTarget::Backup => { + for (i, page) in data.chunks(256).enumerate() { + let page_address = address + i as u32 * 256; + if page_address % 256 != 0 { + return Err(Error::Parameter); + } + + if i > 0 { + // Write enable clears after each page is written + self.write_enable()?; + } + + self.spi.reset()?; self.spi.write(&[ - 0xAD, - low, - high + 0xF2, + (page_address >> 16) as u8, + (page_address >> 8) as u8, + page_address as u8, ])?; - } - - // Poll status for busy unset - self.status_wait(1, 0)?; - }, - SpiTarget::Backup => for (i, page) in data.chunks(256).enumerate() { - let page_address = address + i as u32 * 256; - if page_address % 256 != 0 { - return Err(Error::Parameter); - } + self.spi.write(page)?; - if i > 0 { - // Write enable clears after each page is written - self.write_enable()?; + // Poll status for busy unset + self.status_wait(1, 0)?; } - - self.spi.reset()?; - self.spi.write(&[ - 0xF2, - (page_address >> 16) as u8, - (page_address >> 8) as u8, - page_address as u8, - ])?; - self.spi.write(page)?; - - // Poll status for busy unset - self.status_wait(1, 0)?; - }, + } } self.write_disable()?; diff --git a/tool/src/timeout.rs b/tool/src/timeout.rs index 5ee7919ba..78364e708 100644 --- a/tool/src/timeout.rs +++ b/tool/src/timeout.rs @@ -12,7 +12,7 @@ macro_rules! timeout { Ok(ok) => { result = Ok(ok); break; - }, + } Err(err) => match err { $crate::Error::WouldBlock => (), _ => { @@ -48,7 +48,7 @@ impl StdTimeout { pub fn new(duration: Duration) -> Self { StdTimeout { instant: Instant::now(), - duration + duration, } } } From 264f34badfe840e8452b339bdfb4c560a0bf67a1 Mon Sep 17 00:00:00 2001 From: Tim Crawford Date: Fri, 13 Dec 2024 17:33:02 -0700 Subject: [PATCH 2/3] tool: Update deps Signed-off-by: Tim Crawford --- tool/Cargo.lock | 88 ++++++++++++++++++++++++++----------------------- 1 file changed, 47 insertions(+), 41 deletions(-) diff --git a/tool/Cargo.lock b/tool/Cargo.lock index e2a6083fb..6ae4898d5 100644 --- a/tool/Cargo.lock +++ b/tool/Cargo.lock @@ -4,9 +4,9 @@ version = 3 [[package]] name = "anstream" -version = "0.6.14" +version = "0.6.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "418c75fa768af9c03be99d17643f93f79bbba589895012a80e3452a19ddda15b" +checksum = "8acc5369981196006228e28809f761875c0327210a891e941f4c683b3a99529b" dependencies = [ "anstyle", "anstyle-parse", @@ -19,33 +19,33 @@ dependencies = [ [[package]] name = "anstyle" -version = "1.0.7" +version = "1.0.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "038dfcf04a5feb68e9c60b21c9625a54c2c0616e79b72b0fd87075a056ae1d1b" +checksum = "55cc3b69f167a1ef2e161439aa98aed94e6028e5f9a59be9a6ffb47aef1651f9" [[package]] name = "anstyle-parse" -version = "0.2.4" +version = "0.2.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c03a11a9034d92058ceb6ee011ce58af4a9bf61491aa7e1e59ecd24bd40d22d4" +checksum = "3b2d16507662817a6a20a9ea92df6652ee4f94f914589377d69f3b21bc5798a9" dependencies = [ "utf8parse", ] [[package]] name = "anstyle-query" -version = "1.1.0" +version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ad186efb764318d35165f1758e7dcef3b10628e26d41a44bc5550652e6804391" +checksum = "79947af37f4177cfead1110013d678905c37501914fba0efea834c3fe9a8d60c" dependencies = [ "windows-sys", ] [[package]] name = "anstyle-wincon" -version = "3.0.3" +version = "3.0.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61a38449feb7068f52bb06c12759005cf459ee52bb4adc1d5a7c4322d716fb19" +checksum = "2109dbce0e72be3ec00bed26e6a7479ca384ad226efdd66db8fa2e3a38c83125" dependencies = [ "anstyle", "windows-sys", @@ -53,18 +53,18 @@ dependencies = [ [[package]] name = "cc" -version = "1.0.83" +version = "1.2.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1174fb0b6ec23863f8b971027804a42614e347eafb0a95bf0b12cdae21fc4d0" +checksum = "9157bbaa6b165880c27a4293a474c91cdcf265cc68cc829bf10be0964a391caf" dependencies = [ - "libc", + "shlex", ] [[package]] name = "clap" -version = "4.5.8" +version = "4.5.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "84b3edb18336f4df585bc9aa31dd99c036dfa5dc5e9a2939a722a188f3a8970d" +checksum = "3135e7ec2ef7b10c6ed8950f0f792ed96ee093fa088608f1c76e569722700c84" dependencies = [ "clap_builder", "clap_derive", @@ -72,9 +72,9 @@ dependencies = [ [[package]] name = "clap_builder" -version = "4.5.8" +version = "4.5.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c1c09dd5ada6c6c78075d6fd0da3f90d8080651e2d6cc8eb2f1aaa4034ced708" +checksum = "30582fc632330df2bd26877bde0c1f4470d57c582bbc070376afcd04d8cb4838" dependencies = [ "anstream", "anstyle", @@ -84,9 +84,9 @@ dependencies = [ [[package]] name = "clap_derive" -version = "4.5.8" +version = "4.5.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2bac35c6dafb060fd4d275d9a4ffae97917c13a6327903a8be2153cd964f7085" +checksum = "4ac6a0c7b1a9e9a5186361f67dfa1b88213572f427fb9ab038efb2bd8c582dab" dependencies = [ "heck", "proc-macro2", @@ -96,21 +96,21 @@ dependencies = [ [[package]] name = "clap_lex" -version = "0.7.1" +version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4b82cf0babdbd58558212896d1a4272303a57bdb245c2bf1147185fb45640e70" +checksum = "f46ad14479a25103f283c0f10005961cf086d8dc42205bb44c46ac563475dca6" [[package]] name = "colorchoice" -version = "1.0.1" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b6a852b24ab71dffc585bcb46eaf7959d175cb865a7152e35b348d1b2960422" +checksum = "5b63caa9aa9397e2d9480a9b13673856c78d8ac123288526c37d7839f2a86990" [[package]] name = "downcast-rs" -version = "1.2.0" +version = "1.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9ea835d29036a4087793836fa931b08837ad5e957da9e23886b29586fb9b6650" +checksum = "75b325c5dbd37f80359721ad39aca5a29fb04c89279657cffdda8736d0c0b9d2" [[package]] name = "heck" @@ -132,36 +132,36 @@ dependencies = [ [[package]] name = "is_terminal_polyfill" -version = "1.70.0" +version = "1.70.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f8478577c03552c21db0e2724ffb8986a5ce7af88107e6be5d2ee6e158c12800" +checksum = "7943c866cc5cd64cbc25b2e01621d07fa8eb2a1a23160ee81ce38704e97b8ecf" [[package]] name = "libc" -version = "0.2.148" +version = "0.2.168" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9cdc71e17332e86d2e1d38c1f99edcb6288ee11b815fb1a4b049eaa2114d369b" +checksum = "5aaeb2981e0606ca11d79718f8bb01164f1d6ed75080182d3abf017e6d244b6d" [[package]] name = "pkg-config" -version = "0.3.27" +version = "0.3.31" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26072860ba924cbfa98ea39c8c19b4dd6a4a25423dbdf219c1eca91aa0cf6964" +checksum = "953ec861398dccce10c670dfeaf3ec4911ca479e9c02154b3a215178c5f566f2" [[package]] name = "proc-macro2" -version = "1.0.86" +version = "1.0.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5e719e8df665df0d1c8fbfd238015744736151d4445ec0836b8e628aae103b77" +checksum = "37d3544b3f2748c54e147655edb5025752e2303145b5aefb3c3ea2c78b973bb0" dependencies = [ "unicode-ident", ] [[package]] name = "quote" -version = "1.0.33" +version = "1.0.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae" +checksum = "b5b9d34b8991d19d98081b46eacdd8eb58c6f2b201139f7c5f643cc155a633af" dependencies = [ "proc-macro2", ] @@ -172,6 +172,12 @@ version = "0.1.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8eb516ad341a84372b5b15a5a35cf136ba901a639c8536f521b108253d7fce74" +[[package]] +name = "shlex" +version = "1.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64" + [[package]] name = "strsim" version = "0.11.1" @@ -180,9 +186,9 @@ checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f" [[package]] name = "syn" -version = "2.0.43" +version = "2.0.90" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ee659fb5f3d355364e1f3e5bc10fb82068efbf824a1e9d1c9504244a6469ad53" +checksum = "919d3b74a5dd0ccd15aeb8f93e7006bd9e14c295087c9896a110f490752bcf31" dependencies = [ "proc-macro2", "quote", @@ -202,9 +208,9 @@ dependencies = [ [[package]] name = "unicode-ident" -version = "1.0.12" +version = "1.0.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" +checksum = "adb9e6ca4f869e1180728b7950e35922a7fc6397f7b641499e8f3ef06e50dc83" [[package]] name = "utf8parse" @@ -236,9 +242,9 @@ checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" [[package]] name = "windows-sys" -version = "0.52.0" +version = "0.59.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" +checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b" dependencies = [ "windows-targets", ] From a86508381198359f258694adb1b01fc93a4121ef Mon Sep 17 00:00:00 2001 From: Tim Crawford Date: Fri, 13 Dec 2024 17:47:28 -0700 Subject: [PATCH 3/3] tool: Restrict port IO interfaces to x86 Signed-off-by: Tim Crawford --- tool/Cargo.toml | 4 +++- tool/src/access/mod.rs | 10 ++++++++-- tool/src/lib.rs | 41 +++++++++++++++++++++++++++++------------ 3 files changed, 40 insertions(+), 15 deletions(-) diff --git a/tool/Cargo.toml b/tool/Cargo.toml index dd1fd3849..4a829ad44 100644 --- a/tool/Cargo.toml +++ b/tool/Cargo.toml @@ -20,9 +20,11 @@ clap = { version = "4.5", features = ["derive"], optional = true } libc = { version = "0.2", optional = true } # NOTE: Upgrading to 2.x blocked on Ubuntu shipping newer hidapi hidapi = { version = "1.5", default-features = false, features = ["linux-shared-hidraw"], optional = true } -redox_hwio = { version = "0.1.6", default-features = false, optional = true } downcast-rs = { version = "1.2.0", default-features = false } +[target.'cfg(any(target_arch = "x86", target_arch = "x86_64"))'.dependencies] +redox_hwio = { version = "0.1.6", default-features = false, optional = true } + [features] default = ["std", "hidapi", "clap"] std = ["libc", "downcast-rs/std"] diff --git a/tool/src/access/mod.rs b/tool/src/access/mod.rs index dad443340..da6bc5e7f 100644 --- a/tool/src/access/mod.rs +++ b/tool/src/access/mod.rs @@ -11,9 +11,15 @@ pub use self::hid::AccessHid; #[cfg(feature = "hidapi")] mod hid; -#[cfg(any(feature = "redox_hwio", all(feature = "std", target_os = "linux")))] +#[cfg(all( + any(target_arch = "x86", target_arch = "x86_64"), + any(feature = "redox_hwio", all(feature = "std", target_os = "linux")) +))] pub use self::lpc::*; -#[cfg(any(feature = "redox_hwio", all(feature = "std", target_os = "linux")))] +#[cfg(all( + any(target_arch = "x86", target_arch = "x86_64"), + any(feature = "redox_hwio", all(feature = "std", target_os = "linux")) +))] mod lpc; /// Access method for running an EC command diff --git a/tool/src/lib.rs b/tool/src/lib.rs index 72bd0df64..129a662bb 100644 --- a/tool/src/lib.rs +++ b/tool/src/lib.rs @@ -6,13 +6,12 @@ //! //! There are some differences between targets and features that are listed below: //! - `AccessHid` requires the `hidapi` feature. Only functional on USB ECs. -//! - `AccessLpcDirect` requires the `redox_hwio` feature and a nightly compiler. This method is +//! - `AccessLpcDirect` requires the `redox_hwio` feature and an x86 target. This method is //! only recommended for use in firmware with LPC ECs, as mutual exclusion is not guaranteed. -//! - `AccessLpcLinux` requires the `std` feature and `linux` target_os. Recommended for LPC ECs, -//! as this method can utilize mutual exclusion. -//! - `EcLegacy`, `Pmc`, and `SuperIo` all require the `redox_hwio` feature and a nightly -//! compiler. It is only recommended to use these in firmware, as mutual exclusion is not -//! guaranteed. +//! - `AccessLpcLinux` requires the `std` feature, `linux` target_os, and x86 target. Recommended +//! for LPC ECs, as this method can utilize mutual exclusion. +//! - `EcLegacy`, `Pmc`, and `SuperIo` all require the `redox_hwio` feature and an x86 target. +//! It is only recommended to use these in firmware, as mutual exclusion is not guaranteed. #![allow(clippy::missing_safety_doc)] #![allow(clippy::needless_range_loop)] @@ -33,22 +32,40 @@ mod error; pub use self::firmware::Firmware; mod firmware; -#[cfg(feature = "redox_hwio")] +#[cfg(all( + feature = "redox_hwio", + any(target_arch = "x86", target_arch = "x86_64") +))] pub use self::legacy::EcLegacy; -#[cfg(feature = "redox_hwio")] +#[cfg(all( + feature = "redox_hwio", + any(target_arch = "x86", target_arch = "x86_64") +))] mod legacy; -#[cfg(feature = "redox_hwio")] +#[cfg(all( + feature = "redox_hwio", + any(target_arch = "x86", target_arch = "x86_64") +))] pub use self::pmc::Pmc; -#[cfg(feature = "redox_hwio")] +#[cfg(all( + feature = "redox_hwio", + any(target_arch = "x86", target_arch = "x86_64") +))] mod pmc; pub use self::spi::{Spi, SpiRom, SpiTarget}; mod spi; -#[cfg(feature = "redox_hwio")] +#[cfg(all( + feature = "redox_hwio", + any(target_arch = "x86", target_arch = "x86_64") +))] pub use self::super_io::SuperIo; -#[cfg(feature = "redox_hwio")] +#[cfg(all( + feature = "redox_hwio", + any(target_arch = "x86", target_arch = "x86_64") +))] mod super_io; #[cfg(feature = "std")]