mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-26 19:32:06 -05:00
b2e502e533
Replace the class-based snooze alarm mechanism with a per-thread callback. This makes it easy to block the current thread on an arbitrary condition: void SomeDevice::wait_for_irq() { m_interrupted = false; current->block_until([this] { return m_interrupted; }); } void SomeDevice::handle_irq() { m_interrupted = true; } Use this in the SB16 driver, and in NetworkTask :^)
42 lines
1.1 KiB
C++
42 lines
1.1 KiB
C++
#pragma once
|
|
|
|
#include <AK/CircularQueue.h>
|
|
#include <Kernel/Devices/CharacterDevice.h>
|
|
#include <Kernel/IRQHandler.h>
|
|
#include <Kernel/VM/PhysicalAddress.h>
|
|
#include <Kernel/VM/PhysicalPage.h>
|
|
|
|
class SB16;
|
|
|
|
class SB16 final : public IRQHandler
|
|
, public CharacterDevice {
|
|
public:
|
|
SB16();
|
|
virtual ~SB16() override;
|
|
|
|
static SB16& the();
|
|
|
|
// ^CharacterDevice
|
|
virtual bool can_read(FileDescription&) const override;
|
|
virtual ssize_t read(FileDescription&, u8*, ssize_t) override;
|
|
virtual ssize_t write(FileDescription&, const u8*, ssize_t) override;
|
|
virtual bool can_write(FileDescription&) const override { return true; }
|
|
|
|
private:
|
|
// ^IRQHandler
|
|
virtual void handle_irq() override;
|
|
|
|
// ^CharacterDevice
|
|
virtual const char* class_name() const override { return "SB16"; }
|
|
|
|
void initialize();
|
|
void wait_for_irq();
|
|
void dma_start(uint32_t length);
|
|
void set_sample_rate(uint16_t hz);
|
|
void dsp_write(u8 value);
|
|
u8 dsp_read();
|
|
|
|
RefPtr<PhysicalPage> m_dma_buffer_page;
|
|
bool m_interrupted { false };
|
|
int m_major_version { 0 };
|
|
};
|