mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 19:07:35 +00:00
Kernel/USB: Add a crude USB MassStorage driver :^)
This commit is contained in:
parent
c230a0d96f
commit
29292bbdbf
8 changed files with 615 additions and 0 deletions
38
Kernel/Bus/USB/Drivers/MassStorage/MassStorageDriver.h
Normal file
38
Kernel/Bus/USB/Drivers/MassStorage/MassStorageDriver.h
Normal file
|
@ -0,0 +1,38 @@
|
|||
/*
|
||||
* Copyright (c) 2023, Leon Albrecht <leon.a@serenityos.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <Kernel/Bus/USB/Drivers/USBDriver.h>
|
||||
#include <Kernel/Bus/USB/USBInterface.h>
|
||||
#include <Kernel/Bus/USB/USBManagement.h>
|
||||
#include <Kernel/Devices/Storage/USB/BulkSCSIInterface.h>
|
||||
|
||||
namespace Kernel::USB {
|
||||
|
||||
class MassStorageDriver final : public Driver {
|
||||
public:
|
||||
MassStorageDriver()
|
||||
: Driver("USB MassStorage"sv)
|
||||
{
|
||||
}
|
||||
|
||||
static void init();
|
||||
|
||||
virtual ~MassStorageDriver() override = default;
|
||||
|
||||
virtual ErrorOr<void> probe(USB::Device&) override;
|
||||
virtual void detach(USB::Device&) override;
|
||||
|
||||
private:
|
||||
BulkSCSIInterface::List m_interfaces;
|
||||
|
||||
ErrorOr<void> checkout_interface(USB::Device&, USBInterface const&);
|
||||
|
||||
ErrorOr<void> initialise_bulk_only_device(USB::Device&, USBInterface const&);
|
||||
};
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue