mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 02:12:09 -05:00
ed0e7b53a5
Currently, when passing buffers into VirtIOQueues, we use scatter-gather lists, which contain an internal vector of buffers. This vector is allocated, filled and the destroy whenever we try to provide buffers into a virtqueue, which would happen a lot in performance cricital code (the main transport mechanism for certain paravirtualized devices). This commit moves it over to using VirtIOQueueChains and building the chain in place in the VirtIOQueue. Also included are a bunch of fixups for the VirtIO Console device, making it use an internal VM::RingBuffer instead.
49 lines
1.5 KiB
C++
49 lines
1.5 KiB
C++
/*
|
|
* Copyright (c) 2021, the SerenityOS developers.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <Kernel/Devices/CharacterDevice.h>
|
|
#include <Kernel/VM/RingBuffer.h>
|
|
#include <Kernel/VirtIO/VirtIO.h>
|
|
|
|
namespace Kernel {
|
|
|
|
#define VIRTIO_CONSOLE_F_SIZE (1 << 0)
|
|
#define VIRTIO_CONSOLE_F_MULTIPORT (1 << 1)
|
|
#define VIRTIO_CONSOLE_F_EMERG_WRITE (1 << 2)
|
|
|
|
#define RECEIVEQ 0
|
|
#define TRANSMITQ 1
|
|
|
|
class VirtIOConsole final : public CharacterDevice
|
|
, public VirtIODevice {
|
|
public:
|
|
VirtIOConsole(PCI::Address);
|
|
virtual ~VirtIOConsole() override;
|
|
|
|
private:
|
|
constexpr static size_t RINGBUFFER_SIZE = 2 * PAGE_SIZE;
|
|
virtual const char* class_name() const override { return m_class_name.characters(); }
|
|
|
|
virtual bool can_read(const FileDescription&, size_t) const override;
|
|
virtual KResultOr<size_t> read(FileDescription&, u64, UserOrKernelBuffer&, size_t) override;
|
|
virtual bool can_write(const FileDescription&, size_t) const override;
|
|
virtual KResultOr<size_t> write(FileDescription&, u64, const UserOrKernelBuffer&, size_t) override;
|
|
|
|
virtual mode_t required_mode() const override { return 0666; }
|
|
|
|
virtual bool handle_device_config_change() override;
|
|
virtual String device_name() const override { return String::formatted("hvc{}", minor()); }
|
|
virtual void handle_queue_update(u16 queue_index) override;
|
|
|
|
OwnPtr<RingBuffer> m_receive_buffer;
|
|
OwnPtr<RingBuffer> m_transmit_buffer;
|
|
|
|
static unsigned next_device_id;
|
|
};
|
|
|
|
}
|