Skip to content

Commit

Permalink
Fix clippy warnings
Browse files Browse the repository at this point in the history
Fix:
- clippy::needless_borrow

Silence:
- clippy::manual_flatten

Not addressed:
- deprecated

`llvm_asm!()` is deprecated, but must be used. The new `asm!()` does not
allow using `ebx` [1], which holds the argument for the SMMSTORE command.

[1]: rust-lang/rust#84658

Signed-off-by: Tim Crawford <tcrawford@system76.com>
  • Loading branch information
crawfxrd committed Oct 26, 2021
1 parent aa3cc19 commit b32baed
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 9 deletions.
17 changes: 9 additions & 8 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
#![no_std]
#![feature(llvm_asm)]
#![allow(clippy::missing_safety_doc)]
#![allow(clippy::manual_flatten)]

#[macro_use]
extern crate alloc;
Expand Down Expand Up @@ -144,7 +145,7 @@ impl Iterator for Smmstore {

/// Check if SMMSTORE data is corrupted.
pub fn is_corrupted(data: &[u8]) -> bool {
let smmstore = Smmstore::from_raw(&data);
let smmstore = Smmstore::from_raw(data);
for entry in smmstore {
if let Err(_err) = entry {
return true;
Expand All @@ -159,7 +160,7 @@ pub fn is_corrupted(data: &[u8]) -> bool {
/// No error is returned if a corrupted entry is encountered. Instead, the used
/// size up to the corrupted entry is returned.
pub fn used_size(data: &[u8]) -> usize {
let smmstore = Smmstore::from_raw(&data);
let smmstore = Smmstore::from_raw(data);

let mut used = 0;
for entry in smmstore {
Expand All @@ -180,7 +181,7 @@ pub fn count_duplicates(data: &[u8]) -> usize {
let mut kv = BTreeMap::<Vec<u8>, Vec<u8>>::new();
let mut duplicates = 0;

let smmstore = Smmstore::from_raw(&data);
let smmstore = Smmstore::from_raw(data);
for entry in smmstore {
if let Ok(entry) = entry {
if kv.insert(entry.key, entry.value).is_some() {
Expand All @@ -199,7 +200,7 @@ pub fn count_duplicates(data: &[u8]) -> usize {
pub fn deserialize(data: &[u8]) -> BTreeMap::<Vec<u8>, Vec<u8>> {
let mut kv = BTreeMap::<Vec<u8>, Vec<u8>>::new();

let smmstore = Smmstore::from_raw(&data);
let smmstore = Smmstore::from_raw(data);
for entry in smmstore {
if let Ok(entry) = entry {
kv.insert(entry.key, entry.value);
Expand Down Expand Up @@ -232,11 +233,11 @@ pub fn serialize(data: BTreeMap::<Vec<u8>, Vec<u8>>) -> Vec<u8> {
}

// Key
raw.extend_from_slice(&key);
raw.extend_from_slice(key);
offset += key.len();

// Value
raw.extend_from_slice(&value);
raw.extend_from_slice(value);
offset += value.len();

// NULL byte
Expand All @@ -256,9 +257,9 @@ pub fn serialize(data: BTreeMap::<Vec<u8>, Vec<u8>>) -> Vec<u8> {

/// Convenience function to create new region of same size with compacted data.
pub fn compact(data: &[u8]) -> Vec<u8> {
let compact = serialize(deserialize(&data));
let compact = serialize(deserialize(data));
let mut new_data = vec![0xFF; data.len()];
new_data[..compact.len()].copy_from_slice(&compact.as_slice());
new_data[..compact.len()].copy_from_slice(compact.as_slice());
new_data
}

Expand Down
2 changes: 1 addition & 1 deletion src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ fn smmstore() -> Result<()> {
let compact = smmstore::deserialize(&data);
for (key, value) in compact.iter() {
if key.len() > mem::size_of::<Guid>() && !value.is_empty() {
let res = unsafe { smmstore::smmstore_append(&key, &value) };
let res = unsafe { smmstore::smmstore_append(key, value) };
res?;
}
}
Expand Down

0 comments on commit b32baed

Please sign in to comment.