Skip to content

Commit

Permalink
rustc_codegen_ssa: derive copy and clone for various enums
Browse files Browse the repository at this point in the history
  • Loading branch information
tmiasko committed May 25, 2022
1 parent f4c92cc commit ef83e68
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 19 deletions.
21 changes: 2 additions & 19 deletions compiler/rustc_codegen_gcc/src/builder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -61,23 +61,6 @@ enum ExtremumOperation {
Min,
}

trait EnumClone {
fn clone(&self) -> Self;
}

impl EnumClone for AtomicOrdering {
fn clone(&self) -> Self {
match *self {
AtomicOrdering::Unordered => AtomicOrdering::Unordered,
AtomicOrdering::Relaxed => AtomicOrdering::Relaxed,
AtomicOrdering::Acquire => AtomicOrdering::Acquire,
AtomicOrdering::Release => AtomicOrdering::Release,
AtomicOrdering::AcquireRelease => AtomicOrdering::AcquireRelease,
AtomicOrdering::SequentiallyConsistent => AtomicOrdering::SequentiallyConsistent,
}
}
}

pub struct Builder<'a: 'gcc, 'gcc, 'tcx> {
pub cx: &'a CodegenCx<'gcc, 'tcx>,
pub block: Block<'gcc>,
Expand All @@ -102,9 +85,9 @@ impl<'a, 'gcc, 'tcx> Builder<'a, 'gcc, 'tcx> {
match order {
// TODO(antoyo): does this make sense?
AtomicOrdering::AcquireRelease | AtomicOrdering::Release => AtomicOrdering::Acquire,
_ => order.clone(),
_ => order,
};
let previous_value = self.atomic_load(dst.get_type(), dst, load_ordering.clone(), Size::from_bytes(size));
let previous_value = self.atomic_load(dst.get_type(), dst, load_ordering, Size::from_bytes(size));
let previous_var = func.new_local(None, previous_value.get_type(), "previous_value");
let return_value = func.new_local(None, previous_value.get_type(), "return_value");
self.llbb().add_assignment(None, previous_var, previous_value);
Expand Down
5 changes: 5 additions & 0 deletions compiler/rustc_codegen_ssa/src/common.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ use rustc_span::Span;
use crate::base;
use crate::traits::*;

#[derive(Copy, Clone)]
pub enum IntPredicate {
IntEQ,
IntNE,
Expand All @@ -24,6 +25,7 @@ pub enum IntPredicate {
IntSLE,
}

#[derive(Copy, Clone)]
pub enum RealPredicate {
RealPredicateFalse,
RealOEQ,
Expand All @@ -43,6 +45,7 @@ pub enum RealPredicate {
RealPredicateTrue,
}

#[derive(Copy, Clone)]
pub enum AtomicRmwBinOp {
AtomicXchg,
AtomicAdd,
Expand All @@ -57,6 +60,7 @@ pub enum AtomicRmwBinOp {
AtomicUMin,
}

#[derive(Copy, Clone)]
pub enum AtomicOrdering {
Unordered,
Relaxed,
Expand All @@ -66,6 +70,7 @@ pub enum AtomicOrdering {
SequentiallyConsistent,
}

#[derive(Copy, Clone)]
pub enum SynchronizationScope {
SingleThread,
CrossThread,
Expand Down

0 comments on commit ef83e68

Please sign in to comment.