mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 10:52:44 +00:00 
			
		
		
		
	 d1371d66f7
			
		
	
	
		d1371d66f7
		
	
	
	
	
		
			
			This patch switches away from {Nonnull,}LockRefPtr to the non-locking
smart pointers throughout the kernel.
I've looked at the handful of places where these were being persisted
and I don't see any race situations.
Note that the process file descriptor table (Process::m_fds) was already
guarded via MutexProtected.
		
	
			
		
			
				
	
	
		
			35 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022, Liav A. <liavalb@hotmail.co.il>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <Kernel/Devices/CharacterDevice.h>
 | |
| 
 | |
| namespace Kernel {
 | |
| 
 | |
| class SelfTTYDevice final : public CharacterDevice {
 | |
|     friend class DeviceManagement;
 | |
| 
 | |
| public:
 | |
|     static NonnullLockRefPtr<SelfTTYDevice> must_create();
 | |
|     virtual ~SelfTTYDevice() override;
 | |
| 
 | |
| private:
 | |
|     SelfTTYDevice();
 | |
| 
 | |
|     // ^Device
 | |
|     virtual bool is_openable_by_jailed_processes() const override { return true; }
 | |
| 
 | |
|     // ^CharacterDevice
 | |
|     virtual ErrorOr<NonnullRefPtr<OpenFileDescription>> open(int options) override;
 | |
|     virtual ErrorOr<size_t> read(OpenFileDescription&, u64, UserOrKernelBuffer&, size_t) override;
 | |
|     virtual ErrorOr<size_t> write(OpenFileDescription&, u64, UserOrKernelBuffer const&, size_t) override;
 | |
|     virtual bool can_read(OpenFileDescription const&, u64) const override;
 | |
|     virtual bool can_write(OpenFileDescription const&, u64) const override;
 | |
|     virtual StringView class_name() const override { return "SelfTTYDevice"sv; }
 | |
| };
 | |
| 
 | |
| }
 |