Procházet zdrojové kódy

rust: pl011: simplify handling of the FIFO enabled bit in LCR

Use ==/!= instead of going through bool and xor.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Paolo Bonzini před 8 měsíci
rodič
revize
bf9987c06e
2 změnil soubory, kde provedl 2 přidání a 10 odebrání
  1. 2 4
      rust/hw/char/pl011/src/device.rs
  2. 0 6
      rust/hw/char/pl011/src/lib.rs

+ 2 - 4
rust/hw/char/pl011/src/device.rs

@@ -302,9 +302,7 @@ pub fn write(&mut self, offset: hwaddr, value: u64) {
             Ok(LCR_H) => {
             Ok(LCR_H) => {
                 let new_val: registers::LineControl = value.into();
                 let new_val: registers::LineControl = value.into();
                 // Reset the FIFO state on FIFO enable or disable
                 // Reset the FIFO state on FIFO enable or disable
-                if bool::from(self.line_control.fifos_enabled())
-                    ^ bool::from(new_val.fifos_enabled())
-                {
+                if self.line_control.fifos_enabled() != new_val.fifos_enabled() {
                     self.reset_rx_fifo();
                     self.reset_rx_fifo();
                     self.reset_tx_fifo();
                     self.reset_tx_fifo();
                 }
                 }
@@ -497,7 +495,7 @@ pub fn event(&mut self, event: QEMUChrEvent) {
 
 
     #[inline]
     #[inline]
     pub fn fifo_enabled(&self) -> bool {
     pub fn fifo_enabled(&self) -> bool {
-        matches!(self.line_control.fifos_enabled(), registers::Mode::FIFO)
+        self.line_control.fifos_enabled() == registers::Mode::FIFO
     }
     }
 
 
     #[inline]
     #[inline]

+ 0 - 6
rust/hw/char/pl011/src/lib.rs

@@ -419,12 +419,6 @@ pub enum Mode {
         FIFO = 1,
         FIFO = 1,
     }
     }
 
 
-    impl From<Mode> for bool {
-        fn from(val: Mode) -> Self {
-            matches!(val, Mode::FIFO)
-        }
-    }
-
     #[bitsize(2)]
     #[bitsize(2)]
     #[derive(Clone, Copy, Debug, Eq, FromBits, PartialEq)]
     #[derive(Clone, Copy, Debug, Eq, FromBits, PartialEq)]
     /// `WLEN` Word length, field of [Line Control register](LineControl).
     /// `WLEN` Word length, field of [Line Control register](LineControl).