Upgrades Rust to 1.72.0 & nightly-2023-08-25 (#32961)

* allow pedantic invalid cast lint

* allow lint with false-positive triggered by `test-case` crate

* nightly `fmt` correction

* adapt to rust layout changes

* remove dubious test

* Use transmute instead of pointer cast and de/ref when check_aligned is false.

* Renames clippy::integer_arithmetic to clippy::arithmetic_side_effects.

* bump rust nightly to 2023-08-25

* Upgrades Rust to 1.72.0

---------

Co-authored-by: Trent Nelson <trent@solana.com>
This commit is contained in:
Alexander Meißner 2023-09-01 09:26:13 +02:00 committed by GitHub
parent 114b5b95dd
commit 9e703f85de
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
151 changed files with 167 additions and 198 deletions

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[macro_use] #[macro_use]
extern crate lazy_static; extern crate lazy_static;
#[macro_use] #[macro_use]

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[macro_use] #[macro_use]
extern crate log; extern crate log;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
clap::{crate_description, crate_name, value_t, values_t_or_exit, App, Arg}, clap::{crate_description, crate_name, value_t, values_t_or_exit, App, Arg},
log::*, log::*,

View File

@ -694,6 +694,7 @@ pub mod tests {
fn set_data_len_unsafe(&self, new_data_len: u64) { fn set_data_len_unsafe(&self, new_data_len: u64) {
// UNSAFE: cast away & (= const ref) to &mut to force to mutate append-only (=read-only) AppendVec // UNSAFE: cast away & (= const ref) to &mut to force to mutate append-only (=read-only) AppendVec
unsafe { unsafe {
#[allow(invalid_reference_casting)]
std::ptr::write( std::ptr::write(
std::mem::transmute::<*const u64, *mut u64>(&self.meta.data_len), std::mem::transmute::<*const u64, *mut u64>(&self.meta.data_len),
new_data_len, new_data_len,
@ -711,6 +712,7 @@ pub mod tests {
fn set_executable_as_byte(&self, new_executable_byte: u8) { fn set_executable_as_byte(&self, new_executable_byte: u8) {
// UNSAFE: Force to interpret mmap-backed &bool as &u8 to write some crafted value; // UNSAFE: Force to interpret mmap-backed &bool as &u8 to write some crafted value;
unsafe { unsafe {
#[allow(invalid_reference_casting)]
std::ptr::write( std::ptr::write(
std::mem::transmute::<*const bool, *mut u8>(&self.account_meta.executable), std::mem::transmute::<*const bool, *mut u8>(&self.account_meta.executable),
new_executable_byte, new_executable_byte,

View File

@ -1,5 +1,5 @@
#![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[macro_use] #[macro_use]
extern crate lazy_static; extern crate lazy_static;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
clap::{crate_description, crate_name, Arg, ArgEnum, Command}, clap::{crate_description, crate_name, Arg, ArgEnum, Command},
crossbeam_channel::{unbounded, Receiver}, crossbeam_channel::{unbounded, Receiver},

View File

@ -1,2 +1,2 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod banks_server; pub mod banks_server;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
clap::{crate_description, crate_name, Arg, Command}, clap::{crate_description, crate_name, Arg, Command},

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod bench; pub mod bench;
pub mod bench_tps_client; pub mod bench_tps_client;
pub mod cli; pub mod cli;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
clap::value_t, clap::value_t,
log::*, log::*,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
serial_test::serial, serial_test::serial,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
mod bucket; mod bucket;
pub mod bucket_api; pub mod bucket_api;
mod bucket_item; mod bucket_item;

View File

@ -1,4 +1,4 @@
FROM solanalabs/rust:1.69.0 FROM solanalabs/rust:1.72.0
ARG date ARG date
RUN set -x \ RUN set -x \

View File

@ -1,6 +1,6 @@
# Note: when the rust version is changed also modify # Note: when the rust version is changed also modify
# ci/rust-version.sh to pick up the new image tag # ci/rust-version.sh to pick up the new image tag
FROM rust:1.69.0 FROM rust:1.72.0
RUN set -x \ RUN set -x \
&& apt update \ && apt update \

View File

@ -29,7 +29,7 @@ fi
if [[ -n $RUST_NIGHTLY_VERSION ]]; then if [[ -n $RUST_NIGHTLY_VERSION ]]; then
nightly_version="$RUST_NIGHTLY_VERSION" nightly_version="$RUST_NIGHTLY_VERSION"
else else
nightly_version=2023-04-19 nightly_version=2023-08-25
fi fi

View File

@ -73,7 +73,7 @@ nightly_clippy_allows=(--allow=clippy::redundant_clone)
_ scripts/cargo-for-all-lock-files.sh -- "+${rust_nightly}" clippy --workspace --all-targets --features dummy-for-ci-check -- \ _ scripts/cargo-for-all-lock-files.sh -- "+${rust_nightly}" clippy --workspace --all-targets --features dummy-for-ci-check -- \
--deny=warnings \ --deny=warnings \
--deny=clippy::default_trait_access \ --deny=clippy::default_trait_access \
--deny=clippy::integer_arithmetic \ --deny=clippy::arithmetic_side_effects \
--deny=clippy::manual_let_else \ --deny=clippy::manual_let_else \
--deny=clippy::used_underscore_binding \ --deny=clippy::used_underscore_binding \
"${nightly_clippy_allows[@]}" "${nightly_clippy_allows[@]}"
@ -87,7 +87,7 @@ _ scripts/cargo-for-all-lock-files.sh -- "+${rust_nightly}" clippy --workspace -
_ scripts/cargo-for-all-lock-files.sh -- clippy --workspace --tests --bins --examples --features dummy-for-ci-check -- \ _ scripts/cargo-for-all-lock-files.sh -- clippy --workspace --tests --bins --examples --features dummy-for-ci-check -- \
--deny=warnings \ --deny=warnings \
--deny=clippy::default_trait_access \ --deny=clippy::default_trait_access \
--deny=clippy::integer_arithmetic \ --deny=clippy::arithmetic_side_effects \
--deny=clippy::manual_let_else \ --deny=clippy::manual_let_else \
--deny=clippy::used_underscore_binding --deny=clippy::used_underscore_binding

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
mod cli_output; mod cli_output;
pub mod cli_version; pub mod cli_version;
pub mod display; pub mod display;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
macro_rules! ACCOUNT_STRING { macro_rules! ACCOUNT_STRING {
() => { () => {
r#", one of: r#", one of:

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
solana_cli::{ solana_cli::{
check_balance, check_balance,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
serde_json::Value, serde_json::Value,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
solana_cli::cli::{process_command, CliCommand, CliConfig}, solana_cli::cli::{process_command, CliCommand, CliConfig},
solana_faucet::faucet::run_local_faucet, solana_faucet::faucet::run_local_faucet,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![allow(clippy::redundant_closure)] #![allow(clippy::redundant_closure)]
use { use {
assert_matches::assert_matches, assert_matches::assert_matches,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![allow(clippy::redundant_closure)] #![allow(clippy::redundant_closure)]
use { use {
solana_cli::{ solana_cli::{

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
solana_cli::{ solana_cli::{
check_balance, check_balance,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod connection_cache; pub mod connection_cache;
pub mod nonblocking; pub mod nonblocking;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
log::*, log::*,
solana_measure::measure::Measure, solana_measure::measure::Measure,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod client_connection; pub mod client_connection;
pub mod connection_cache; pub mod connection_cache;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![feature(test)] #![feature(test)]
extern crate test; extern crate test;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![feature(test)] #![feature(test)]
use { use {

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![feature(test)] #![feature(test)]
extern crate test; extern crate test;

View File

@ -1,5 +1,5 @@
#![feature(test)] #![feature(test)]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_core; extern crate solana_core;
extern crate test; extern crate test;

View File

@ -1,5 +1,5 @@
#![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![recursion_limit = "2048"] #![recursion_limit = "2048"]
//! The `solana` library implements the Solana high-performance blockchain architecture. //! The `solana` library implements the Solana high-performance blockchain architecture.
//! It includes a full Rust implementation of the architecture (see //! It includes a full Rust implementation of the architecture (see

View File

@ -1,3 +1,6 @@
// REMOVE once https://github.com/rust-lang/rust-clippy/issues/11153 is fixed
#![allow(clippy::items_after_test_module)]
use { use {
crate::snapshot_utils::create_tmp_accounts_dir_for_tests, crate::snapshot_utils::create_tmp_accounts_dir_for_tests,
log::*, log::*,
@ -665,7 +668,7 @@ fn test_epoch_accounts_hash_and_warping() {
// https://github.com/rust-lang/rust/pull/88582 // https://github.com/rust-lang/rust/pull/88582
// https://github.com/jhpratt/rust/blob/727a4fc7e3f836938dfeb4a2ab237cfca612222d/library/core/src/num/uint_macros.rs#L1811-L1837 // https://github.com/jhpratt/rust/blob/727a4fc7e3f836938dfeb4a2ab237cfca612222d/library/core/src/num/uint_macros.rs#L1811-L1837
const fn next_multiple_of(lhs: u64, rhs: u64) -> u64 { const fn next_multiple_of(lhs: u64, rhs: u64) -> u64 {
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
match lhs % rhs { match lhs % rhs {
0 => lhs, 0 => lhs,
r => lhs + (rhs - r), r => lhs + (rhs - r),

View File

@ -71,7 +71,7 @@
//! ``` //! ```
//! time: 4007, tip converged: 10, trunk id: 3830, trunk time: 3827, trunk converged 100, trunk height 348 //! time: 4007, tip converged: 10, trunk id: 3830, trunk time: 3827, trunk converged 100, trunk height 348
//! ``` //! ```
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate rand; extern crate rand;
use { use {

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
// Long-running ledger_cleanup tests // Long-running ledger_cleanup tests
#[cfg(test)] #[cfg(test)]

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
crate::snapshot_utils::create_tmp_accounts_dir_for_tests, crate::snapshot_utils::create_tmp_accounts_dir_for_tests,

View File

@ -1,5 +1,5 @@
#![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod block_cost_limits; pub mod block_cost_limits;
pub mod cost_model; pub mod cost_model;

View File

@ -1,2 +1,2 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod cli; pub mod cli;

View File

@ -38,7 +38,7 @@
//! solana-dos $COMMON --valid-blockhash --transaction-type account-creation //! solana-dos $COMMON --valid-blockhash --transaction-type account-creation
//! ``` //! ```
//! //!
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
crossbeam_channel::{select, tick, unbounded, Receiver, Sender}, crossbeam_channel::{select, tick, unbounded, Receiver, Sender},
itertools::Itertools, itertools::Itertools,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
console::Emoji, console::Emoji,
indicatif::{ProgressBar, ProgressStyle}, indicatif::{ProgressBar, ProgressStyle},

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod entry; pub mod entry;
pub mod poh; pub mod poh;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod address_generator; pub mod address_generator;
pub mod genesis_accounts; pub mod genesis_accounts;
pub mod stakes; pub mod stakes;

View File

@ -1,5 +1,5 @@
//! A command-line executable for generating the chain's genesis config. //! A command-line executable for generating the chain's genesis config.
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
base64::{prelude::BASE64_STANDARD, Engine}, base64::{prelude::BASE64_STANDARD, Engine},

View File

@ -1,5 +1,5 @@
#![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod cluster_info; pub mod cluster_info;
pub mod cluster_info_metrics; pub mod cluster_info_metrics;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
bincode::serialized_size, bincode::serialized_size,
log::*, log::*,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[macro_use] #[macro_use]
extern crate log; extern crate log;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[macro_use] #[macro_use]
extern crate lazy_static; extern crate lazy_static;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
bip39::{Mnemonic, MnemonicType, Seed}, bip39::{Mnemonic, MnemonicType, Seed},
clap::{crate_description, crate_name, Arg, ArgMatches, Command}, clap::{crate_description, crate_name, Arg, ArgMatches, Command},

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
crate::{args::*, bigtable::*, ledger_path::*, ledger_utils::*, output::*, program::*}, crate::{args::*, bigtable::*, ledger_path::*, ledger_utils::*, output::*, program::*},
chrono::{DateTime, Utc}, chrono::{DateTime, Utc},

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![feature(test)] #![feature(test)]
extern crate solana_ledger; extern crate solana_ledger;
extern crate test; extern crate test;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![feature(test)] #![feature(test)]
extern crate test; extern crate test;

View File

@ -1,5 +1,5 @@
#![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod bank_forks_utils; pub mod bank_forks_utils;
pub mod bigtable_delete; pub mod bigtable_delete;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
solana_entry::entry::Entry, solana_entry::entry::Entry,
solana_ledger::shred::{ solana_ledger::shred::{

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod cluster; pub mod cluster;
pub mod cluster_tests; pub mod cluster_tests;
pub mod integration_tests; pub mod integration_tests;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
assert_matches::assert_matches, assert_matches::assert_matches,
crossbeam_channel::{unbounded, Receiver}, crossbeam_channel::{unbounded, Receiver},

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate byte_unit; extern crate byte_unit;
use { use {

View File

@ -1,3 +1,3 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod macros; pub mod macros;
pub mod measure; pub mod measure;

View File

@ -208,7 +208,7 @@ impl<const ALIGN: usize, T: AsRef<[u8]>> From<T> for AlignedMemory<ALIGN> {
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use {super::*, std::io::Write}; use {super::*, std::io::Write};
fn do_test<const ALIGN: usize>() { fn do_test<const ALIGN: usize>() {

View File

@ -1,4 +1,4 @@
#![deny(clippy::integer_arithmetic)] #![deny(clippy::arithmetic_side_effects)]
pub mod aligned_memory; pub mod aligned_memory;
/// Returns true if `ptr` is aligned to `align`. /// Returns true if `ptr` is aligned to `align`.

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[cfg(target_os = "solana")] #[cfg(target_os = "solana")]
#[macro_use] #[macro_use]

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod counter; pub mod counter;
pub mod datapoint; pub mod datapoint;
pub mod metrics; pub mod metrics;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
clap::{crate_description, crate_name, crate_version, Arg, ArgMatches, Command}, clap::{crate_description, crate_name, crate_version, Arg, ArgMatches, Command},
rand::{thread_rng, Rng}, rand::{thread_rng, Rng},

View File

@ -1,5 +1,5 @@
//! The `net_utils` module assists with networking //! The `net_utils` module assists with networking
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
crossbeam_channel::unbounded, crossbeam_channel::unbounded,
log::*, log::*,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![feature(test)] #![feature(test)]
extern crate test; extern crate test;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![feature(test)] #![feature(test)]
extern crate test; extern crate test;

View File

@ -64,7 +64,7 @@ impl<const K: usize, T: ?Sized + Hash> Deduper<K, T> {
// Returns true if the data is duplicate. // Returns true if the data is duplicate.
#[must_use] #[must_use]
#[allow(clippy::integer_arithmetic)] #[allow(clippy::arithmetic_side_effects)]
pub fn dedup(&self, data: &T) -> bool { pub fn dedup(&self, data: &T) -> bool {
let mut out = true; let mut out = true;
let hashers = self.state.iter().map(RandomState::build_hasher); let hashers = self.state.iter().map(RandomState::build_hasher);
@ -114,7 +114,7 @@ pub fn dedup_packets_and_count_discards<const K: usize>(
} }
#[cfg(test)] #[cfg(test)]
#[allow(clippy::integer_arithmetic)] #[allow(clippy::arithmetic_side_effects)]
mod tests { mod tests {
use { use {
super::*, super::*,

View File

@ -676,7 +676,7 @@ pub fn ed25519_verify(
} }
#[cfg(test)] #[cfg(test)]
#[allow(clippy::integer_arithmetic)] #[allow(clippy::arithmetic_side_effects)]
mod tests { mod tests {
use { use {
super::*, super::*,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[cfg(any(target_arch = "x86", target_arch = "x86_64"))] #[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
use solana_entry::entry::{self, create_ticks, init_poh, EntrySlice, VerifyRecyclers}; use solana_entry::entry::{self, create_ticks, init_poh, EntrySlice, VerifyRecyclers};
#[cfg(not(any(target_arch = "x86", target_arch = "x86_64")))] #[cfg(not(any(target_arch = "x86", target_arch = "x86_64")))]

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod leader_bank_notifier; pub mod leader_bank_notifier;
pub mod poh_recorder; pub mod poh_recorder;
pub mod poh_service; pub mod poh_service;

View File

@ -1,5 +1,5 @@
#![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))]
#![deny(clippy::integer_arithmetic)] #![deny(clippy::arithmetic_side_effects)]
#![deny(clippy::indexing_slicing)] #![deny(clippy::indexing_slicing)]
#![recursion_limit = "2048"] #![recursion_limit = "2048"]

View File

@ -1,5 +1,5 @@
//! The solana-program-test provides a BanksClient-based test framework SBF programs //! The solana-program-test provides a BanksClient-based test framework SBF programs
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
// Export tokio for test clients // Export tokio for test clients
pub use tokio; pub use tokio;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
bincode::deserialize, bincode::deserialize,
log::debug, log::debug,

View File

@ -1,4 +1,4 @@
#![deny(clippy::integer_arithmetic)] #![deny(clippy::arithmetic_side_effects)]
#![deny(clippy::indexing_slicing)] #![deny(clippy::indexing_slicing)]
pub mod serialization; pub mod serialization;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
byteorder::{ByteOrder, LittleEndian}, byteorder::{ByteOrder, LittleEndian},

View File

@ -1632,7 +1632,7 @@ fn account_realloc_region<'a>(
} }
#[allow(clippy::indexing_slicing)] #[allow(clippy::indexing_slicing)]
#[allow(clippy::integer_arithmetic)] #[allow(clippy::arithmetic_side_effects)]
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use { use {

View File

@ -367,11 +367,13 @@ fn translate_type_inner<'a, T>(
check_aligned: bool, check_aligned: bool,
) -> Result<&'a mut T, Error> { ) -> Result<&'a mut T, Error> {
let host_addr = translate(memory_mapping, access_type, vm_addr, size_of::<T>() as u64)?; let host_addr = translate(memory_mapping, access_type, vm_addr, size_of::<T>() as u64)?;
if !check_aligned {
if check_aligned && !address_is_aligned::<T>(host_addr) { Ok(unsafe { std::mem::transmute::<u64, &mut T>(host_addr) })
return Err(SyscallError::UnalignedPointer.into()); } else if !address_is_aligned::<T>(host_addr) {
Err(SyscallError::UnalignedPointer.into())
} else {
Ok(unsafe { &mut *(host_addr as *mut T) })
} }
Ok(unsafe { &mut *(host_addr as *mut T) })
} }
fn translate_type_mut<'a, T>( fn translate_type_mut<'a, T>(
memory_mapping: &MemoryMapping, memory_mapping: &MemoryMapping,
@ -1879,7 +1881,7 @@ declare_syscall!(
); );
#[cfg(test)] #[cfg(test)]
#[allow(clippy::integer_arithmetic)] #[allow(clippy::arithmetic_side_effects)]
#[allow(clippy::indexing_slicing)] #[allow(clippy::indexing_slicing)]
mod tests { mod tests {
#[allow(deprecated)] #[allow(deprecated)]

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod config_instruction; pub mod config_instruction;
pub mod config_processor; pub mod config_processor;
pub mod date_instruction; pub mod date_instruction;

View File

@ -1,7 +1,7 @@
#![feature(test)] #![feature(test)]
#![cfg(feature = "sbf_c")] #![cfg(feature = "sbf_c")]
#![allow(clippy::uninlined_format_args)] #![allow(clippy::uninlined_format_args)]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
solana_rbpf::memory_region::MemoryState, solana_rbpf::memory_region::MemoryState,

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF program tests loop iteration //! Example Rust-based SBF program tests loop iteration
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::{custom_heap_default, custom_panic_default, entrypoint::SUCCESS}; use solana_program::{custom_heap_default, custom_panic_default, entrypoint::SUCCESS};

View File

@ -1,6 +1,6 @@
//! Solana Rust-based SBF program utility functions and types //! Solana Rust-based SBF program utility functions and types
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF program that test dynamic memory allocation //! Example Rust-based SBF program that test dynamic memory allocation
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[macro_use] #[macro_use]
extern crate alloc; extern crate alloc;

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF that tests out using a custom heap //! Example Rust-based SBF that tests out using a custom heap
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
solana_program::{ solana_program::{

View File

@ -1,7 +1,7 @@
//! Example Rust-based SBF program that supports the deprecated loader //! Example Rust-based SBF program that supports the deprecated loader
#![allow(unreachable_code)] #![allow(unreachable_code)]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::{ use solana_program::{

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF program that tests duplicate accounts passed via accounts //! Example Rust-based SBF program that tests duplicate accounts passed via accounts
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::{ use solana_program::{

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF program that moves a lamport from one account to another //! Example Rust-based SBF program that moves a lamport from one account to another
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::{account_info::AccountInfo, entrypoint::ProgramResult, pubkey::Pubkey}; use solana_program::{account_info::AccountInfo, entrypoint::ProgramResult, pubkey::Pubkey};

View File

@ -1,7 +1,7 @@
//! Example Rust-based SBF program that issues a cross-program-invocation //! Example Rust-based SBF program that issues a cross-program-invocation
#![cfg(feature = "program")] #![cfg(feature = "program")]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
crate::instructions::*, crate::instructions::*,

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF program tests loop iteration //! Example Rust-based SBF program tests loop iteration
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::{ use solana_program::{

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF program tests loop iteration //! Example Rust-based SBF program tests loop iteration
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::log::*; use solana_program::log::*;

View File

@ -1,6 +1,6 @@
//! Solana Rust-based SBF program utility functions and types //! Solana Rust-based SBF program utility functions and types
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::{log::sol_log_64, msg}; use solana_program::{log::sol_log_64, msg};

View File

@ -1,6 +1,6 @@
//! Example Rust-based SBF program tests loop iteration //! Example Rust-based SBF program tests loop iteration
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;

View File

@ -1,7 +1,7 @@
//! Example Rust-based SBF sanity program that prints out the parameters passed to it //! Example Rust-based SBF sanity program that prints out the parameters passed to it
#![allow(unreachable_code)] #![allow(unreachable_code)]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
extern crate solana_program; extern crate solana_program;
use solana_program::{ use solana_program::{

View File

@ -1,7 +1,7 @@
//! Example Rust-based SBF program that queries sibling instructions //! Example Rust-based SBF program that queries sibling instructions
#![cfg(feature = "program")] #![cfg(feature = "program")]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use solana_program::{ use solana_program::{
account_info::AccountInfo, account_info::AccountInfo,

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use { use {
solana_program::{ solana_program::{

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
use solana_program::{account_info::AccountInfo, entrypoint::ProgramResult, pubkey::Pubkey}; use solana_program::{account_info::AccountInfo, entrypoint::ProgramResult, pubkey::Pubkey};

View File

@ -1,5 +1,5 @@
#![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))]
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#[deprecated( #[deprecated(
since = "1.8.0", since = "1.8.0",
note = "Please use `solana_sdk::stake::program::id` or `solana_program::stake::program::id` instead" note = "Please use `solana_sdk::stake::program::id` or `solana_program::stake::program::id` instead"

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod system_instruction; pub mod system_instruction;
pub mod system_processor; pub mod system_processor;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod nonblocking; pub mod nonblocking;
pub mod pubsub_client; pub mod pubsub_client;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod nonblocking; pub mod nonblocking;
pub mod quic_client; pub mod quic_client;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
#![allow(dead_code)] #![allow(dead_code)]
pub mod ledger; pub mod ledger;
pub mod ledger_error; pub mod ledger_error;

View File

@ -1,4 +1,4 @@
#![allow(clippy::integer_arithmetic)] #![allow(clippy::arithmetic_side_effects)]
pub mod client_error; pub mod client_error;
pub mod config; pub mod config;

Some files were not shown because too many files have changed in this diff Show More