diff options
author | Danilo Krummrich <dakr@kernel.org> | 2025-06-21 21:43:34 +0200 |
---|---|---|
committer | Danilo Krummrich <dakr@kernel.org> | 2025-07-09 00:04:33 +0200 |
commit | 5f512533b7aa780488c15e001791d1b8000ad50e (patch) | |
tree | 110aa0d2182656b8aa0dca299732d472e2d1fc3a | |
parent | 18ebb25dfa18c09474fed78b20808fa445370666 (diff) |
samples: rust: pci: reset pci-testdev in unbind()
Reset the pci-testdev when the driver is unbound from its device.
Link: https://lore.kernel.org/r/20250621195118.124245-9-dakr@kernel.org
Signed-off-by: Danilo Krummrich <dakr@kernel.org>
-rw-r--r-- | samples/rust/rust_driver_pci.rs | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/samples/rust/rust_driver_pci.rs b/samples/rust/rust_driver_pci.rs index 5c35f1414172..606946ff4d7f 100644 --- a/samples/rust/rust_driver_pci.rs +++ b/samples/rust/rust_driver_pci.rs @@ -18,7 +18,7 @@ impl Regs { type Bar0 = pci::Bar<{ Regs::END }>; -#[derive(Debug)] +#[derive(Copy, Clone, Debug)] struct TestIndex(u8); impl TestIndex { @@ -30,6 +30,7 @@ struct SampleDriver { pdev: ARef<pci::Device>, #[pin] bar: Devres<Bar0>, + index: TestIndex, } kernel::pci_device_table!( @@ -79,6 +80,7 @@ impl pci::Driver for SampleDriver { try_pin_init!(Self { pdev: pdev.into(), bar <- pdev.iomap_region_sized::<{ Regs::END }>(0, c_str!("rust_driver_pci")), + index: *info, }), GFP_KERNEL, )?; @@ -92,6 +94,13 @@ impl pci::Driver for SampleDriver { Ok(drvdata) } + + fn unbind(pdev: &pci::Device<Core>, this: Pin<&Self>) { + if let Ok(bar) = this.bar.access(pdev.as_ref()) { + // Reset pci-testdev by writing a new test index. + bar.write8(this.index.0, Regs::TEST); + } + } } #[pinned_drop] |