mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 13:32:45 +00:00 
			
		
		
		
	Kernel/SysFS: Fix parent directory hierarchy with symbolic links
We should actually start counting from the parent directory and not from the symbolic link as it will represent a wrong count of hops from the actual mountpoint. The symlinks in /sys/dev/block and /sys/dev/char worked only by luck, because I have set it to the wrong parent directory which is the /sys/dev directory, so with the symlink it was 3 hops to /sys, together with the root directory, therefore, everything seemed to work. Now that the device symlinks in /sys/dev/block and /sys/dev/char are set to the right parent directory and we start measure hops from root directory with the parent directory of a symlink, everything seem to work correctly now.
This commit is contained in:
		
							parent
							
								
									7e6e7d67a9
								
							
						
					
					
						commit
						60f7d61ad2
					
				
					 5 changed files with 30 additions and 8 deletions
				
			
		|  | @ -11,17 +11,32 @@ | |||
| 
 | ||||
| namespace Kernel { | ||||
| 
 | ||||
| ErrorOr<NonnullRefPtr<SysFSSymbolicLinkDeviceComponent>> SysFSSymbolicLinkDeviceComponent::try_create(SysFSDeviceIdentifiersDirectory const& parent_directory, Device const& device, SysFSComponent const& pointed_component) | ||||
| ErrorOr<NonnullRefPtr<SysFSSymbolicLinkDeviceComponent>> SysFSSymbolicLinkDeviceComponent::try_create(SysFSCharacterDevicesDirectory const& parent_directory, Device const& device, SysFSComponent const& pointed_component) | ||||
| { | ||||
|     auto device_name = TRY(KString::formatted("{}:{}", device.major(), device.minor())); | ||||
|     return adopt_nonnull_ref_or_enomem(new (nothrow) SysFSSymbolicLinkDeviceComponent(parent_directory, move(device_name), device, pointed_component)); | ||||
| } | ||||
| SysFSSymbolicLinkDeviceComponent::SysFSSymbolicLinkDeviceComponent(SysFSDeviceIdentifiersDirectory const& parent_directory, NonnullOwnPtr<KString> major_minor_formatted_device_name, Device const& device, SysFSComponent const& pointed_component) | ||||
| 
 | ||||
| ErrorOr<NonnullRefPtr<SysFSSymbolicLinkDeviceComponent>> SysFSSymbolicLinkDeviceComponent::try_create(SysFSBlockDevicesDirectory const& parent_directory, Device const& device, SysFSComponent const& pointed_component) | ||||
| { | ||||
|     auto device_name = TRY(KString::formatted("{}:{}", device.major(), device.minor())); | ||||
|     return adopt_nonnull_ref_or_enomem(new (nothrow) SysFSSymbolicLinkDeviceComponent(parent_directory, move(device_name), device, pointed_component)); | ||||
| } | ||||
| 
 | ||||
| SysFSSymbolicLinkDeviceComponent::SysFSSymbolicLinkDeviceComponent(SysFSCharacterDevicesDirectory const& parent_directory, NonnullOwnPtr<KString> major_minor_formatted_device_name, Device const& device, SysFSComponent const& pointed_component) | ||||
|     : SysFSSymbolicLink(parent_directory, pointed_component) | ||||
|     , m_block_device(device.is_block_device()) | ||||
|     , m_major_minor_formatted_device_name(move(major_minor_formatted_device_name)) | ||||
| { | ||||
|     VERIFY(device.is_block_device() || device.is_character_device()); | ||||
|     VERIFY(device.is_character_device()); | ||||
| } | ||||
| 
 | ||||
| SysFSSymbolicLinkDeviceComponent::SysFSSymbolicLinkDeviceComponent(SysFSBlockDevicesDirectory const& parent_directory, NonnullOwnPtr<KString> major_minor_formatted_device_name, Device const& device, SysFSComponent const& pointed_component) | ||||
|     : SysFSSymbolicLink(parent_directory, pointed_component) | ||||
|     , m_block_device(device.is_block_device()) | ||||
|     , m_major_minor_formatted_device_name(move(major_minor_formatted_device_name)) | ||||
| { | ||||
|     VERIFY(device.is_block_device()); | ||||
| } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Liav A
						Liav A