2020-01-18 09:38:21 +01:00
|
|
|
/*
|
2021-08-07 15:18:14 +02:00
|
|
|
* Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
|
2020-01-18 09:38:21 +01:00
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-01-18 09:38:21 +01:00
|
|
|
*/
|
|
|
|
|
|
2019-01-16 13:36:10 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
2019-01-30 18:26:19 +01:00
|
|
|
#include <AK/Badge.h>
|
2019-05-28 11:53:16 +02:00
|
|
|
#include <Kernel/Devices/CharacterDevice.h>
|
2021-07-18 09:10:27 +02:00
|
|
|
#include <Kernel/Locking/Mutex.h>
|
2019-01-16 13:36:10 +01:00
|
|
|
|
2020-02-16 01:27:42 +01:00
|
|
|
namespace Kernel {
|
|
|
|
|
|
2019-01-16 13:36:10 +01:00
|
|
|
class MasterPTY;
|
|
|
|
|
|
|
|
|
|
class PTYMultiplexer final : public CharacterDevice {
|
|
|
|
|
AK_MAKE_ETERNAL
|
|
|
|
|
public:
|
|
|
|
|
PTYMultiplexer();
|
|
|
|
|
virtual ~PTYMultiplexer() override;
|
|
|
|
|
|
2020-08-24 19:35:19 -06:00
|
|
|
static void initialize()
|
|
|
|
|
{
|
|
|
|
|
the();
|
|
|
|
|
}
|
2019-01-30 18:26:19 +01:00
|
|
|
static PTYMultiplexer& the();
|
|
|
|
|
|
2019-01-16 13:36:10 +01:00
|
|
|
// ^CharacterDevice
|
2019-06-21 18:37:47 +02:00
|
|
|
virtual KResultOr<NonnullRefPtr<FileDescription>> open(int options) override;
|
2021-03-17 13:18:51 +01:00
|
|
|
virtual KResultOr<size_t> read(FileDescription&, u64, UserOrKernelBuffer&, size_t) override { return 0; }
|
|
|
|
|
virtual KResultOr<size_t> write(FileDescription&, u64, const UserOrKernelBuffer&, size_t) override { return 0; }
|
2020-04-10 19:44:42 +10:00
|
|
|
virtual bool can_read(const FileDescription&, size_t) const override { return true; }
|
|
|
|
|
virtual bool can_write(const FileDescription&, size_t) const override { return true; }
|
2019-01-16 13:36:10 +01:00
|
|
|
|
2019-01-30 18:26:19 +01:00
|
|
|
void notify_master_destroyed(Badge<MasterPTY>, unsigned index);
|
|
|
|
|
|
2020-12-25 19:01:19 +02:00
|
|
|
// ^Device
|
|
|
|
|
virtual mode_t required_mode() const override { return 0666; }
|
2021-01-21 18:49:56 +01:00
|
|
|
virtual String device_name() const override { return "ptmx"; }
|
2020-12-25 19:01:19 +02:00
|
|
|
|
2019-01-16 13:36:10 +01:00
|
|
|
private:
|
2019-01-21 02:33:01 +01:00
|
|
|
// ^CharacterDevice
|
2021-07-11 01:46:09 +02:00
|
|
|
virtual StringView class_name() const override { return "PTYMultiplexer"; }
|
2019-01-21 02:33:01 +01:00
|
|
|
|
2021-08-07 15:08:32 +02:00
|
|
|
static constexpr size_t max_pty_pairs = 64;
|
2021-08-21 23:31:15 +02:00
|
|
|
MutexProtected<Vector<unsigned, max_pty_pairs>> m_freelist;
|
2019-01-16 13:36:10 +01:00
|
|
|
};
|
2020-02-16 01:27:42 +01:00
|
|
|
|
|
|
|
|
}
|