1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- use alloc::sync::Arc;
- use system_error::SystemError;
- use crate::driver::base::device::{
- bus::Bus,
- driver::{driver_manager, Driver},
- };
- use super::{serio_bus, serio_device::SerioDevice};
- pub trait SerioDriver: Driver {
-
- fn write_wakeup(&self, device: &Arc<dyn SerioDevice>) -> Result<(), SystemError>;
-
-
-
-
-
-
-
-
-
-
-
-
- fn interrupt(
- &self,
- device: &Arc<dyn SerioDevice>,
- data: u8,
- flag: u8,
- ) -> Result<(), SystemError>;
-
- fn connect(&self, device: &Arc<dyn SerioDevice>) -> Result<(), SystemError>;
-
- fn reconnect(&self, device: &Arc<dyn SerioDevice>) -> Result<(), SystemError>;
-
- fn fast_reconnect(&self, device: &Arc<dyn SerioDevice>) -> Result<(), SystemError>;
-
- fn disconnect(&self, device: &Arc<dyn SerioDevice>) -> Result<(), SystemError>;
-
- fn cleanup(&self, device: &Arc<dyn SerioDevice>) -> Result<(), SystemError>;
- }
- #[inline(always)]
- pub fn serio_driver_manager() -> &'static SerioDriverManager {
- &SerioDriverManager
- }
- pub struct SerioDriverManager;
- #[allow(dead_code)]
- impl SerioDriverManager {
-
-
-
-
-
-
-
-
- pub fn register(&self, driver: Arc<dyn SerioDriver>) -> Result<(), SystemError> {
- driver.set_bus(Some(Arc::downgrade(&(serio_bus() as Arc<dyn Bus>))));
- return driver_manager().register(driver as Arc<dyn Driver>);
- }
-
-
-
-
-
-
-
-
- #[allow(dead_code)]
- pub fn unregister(&self, driver: &Arc<dyn SerioDriver>) {
- driver_manager().unregister(&(driver.clone() as Arc<dyn Driver>));
- }
- }
|