ladybird/Userland/Utilities/blockdev.cpp
Idan Horowitz 971ab3b919 Kernel: Use u64 instead of size_t in the STORAGE_DEVICE_GET_SIZE ioctl
This ensures the device size doesn't get truncated on i686.
2022-01-25 22:41:17 +02:00

57 lines
1.4 KiB
C++

/*
* Copyright (c) 2021, David Isaksson <davidisaksson93@gmail.com>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibCore/ArgsParser.h>
#include <LibCore/System.h>
#include <LibMain/Main.h>
#include <fcntl.h>
#include <stdio.h>
#include <sys/ioctl.h>
static void fetch_ioctl(int fd, int request)
{
u64 value;
if (ioctl(fd, request, &value) < 0) {
perror("ioctl");
exit(1);
}
outln("{}", value);
}
ErrorOr<int> serenity_main(Main::Arguments arguments)
{
TRY(Core::System::unveil("/dev", "r"));
TRY(Core::System::unveil(nullptr, nullptr));
TRY(Core::System::pledge("stdio rpath"));
const char* device = nullptr;
bool flag_get_disk_size = false;
bool flag_get_block_size = false;
Core::ArgsParser args_parser;
args_parser.set_general_help("Call block device ioctls");
args_parser.add_option(flag_get_disk_size, "Get size in bytes", "size", 's');
args_parser.add_option(flag_get_block_size, "Get block size in bytes", "block-size", 'b');
args_parser.add_positional_argument(device, "Device to query", "device");
args_parser.parse(arguments);
int fd = open(device, O_RDONLY);
if (fd < 0) {
perror("open");
return 1;
}
if (flag_get_disk_size) {
fetch_ioctl(fd, STORAGE_DEVICE_GET_SIZE);
}
if (flag_get_block_size) {
fetch_ioctl(fd, STORAGE_DEVICE_GET_BLOCK_SIZE);
}
return 0;
}