mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 04:27:44 +00:00
Add a simple /bin/sysctl that wraps the files in /proc/sys.
This commit is contained in:
parent
f7cc454162
commit
7e044cf293
5 changed files with 151 additions and 4 deletions
|
@ -40,12 +40,14 @@ void StringBuilder::appendf(const char* fmt, ...)
|
||||||
ByteBuffer StringBuilder::to_byte_buffer()
|
ByteBuffer StringBuilder::to_byte_buffer()
|
||||||
{
|
{
|
||||||
m_buffer.trim(m_length);
|
m_buffer.trim(m_length);
|
||||||
return m_buffer;
|
return move(m_buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
String StringBuilder::build()
|
String StringBuilder::build()
|
||||||
{
|
{
|
||||||
return String((const char*)m_buffer.pointer(), m_length);
|
auto string = String((const char*)m_buffer.pointer(), m_length);
|
||||||
|
m_buffer.clear();
|
||||||
|
return string;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,6 +43,7 @@ cp -v ../Userland/touch mnt/bin/touch
|
||||||
cp -v ../Userland/sync mnt/bin/sync
|
cp -v ../Userland/sync mnt/bin/sync
|
||||||
cp -v ../Userland/more mnt/bin/more
|
cp -v ../Userland/more mnt/bin/more
|
||||||
cp -v ../Userland/guitest mnt/bin/guitest
|
cp -v ../Userland/guitest mnt/bin/guitest
|
||||||
|
cp -v ../Userland/sysctl mnt/bin/sysctl
|
||||||
cp -v ../Terminal/Terminal mnt/bin/Terminal
|
cp -v ../Terminal/Terminal mnt/bin/Terminal
|
||||||
sh sync-local.sh
|
sh sync-local.sh
|
||||||
cp -v kernel.map mnt/
|
cp -v kernel.map mnt/
|
||||||
|
|
1
Userland/.gitignore
vendored
1
Userland/.gitignore
vendored
|
@ -22,3 +22,4 @@ touch
|
||||||
sync
|
sync
|
||||||
more
|
more
|
||||||
guitest
|
guitest
|
||||||
|
sysctl
|
||||||
|
|
|
@ -19,7 +19,8 @@ OBJS = \
|
||||||
mkdir.o \
|
mkdir.o \
|
||||||
touch.o \
|
touch.o \
|
||||||
more.o \
|
more.o \
|
||||||
guitest.o
|
guitest.o \
|
||||||
|
sysctl.o
|
||||||
|
|
||||||
APPS = \
|
APPS = \
|
||||||
id \
|
id \
|
||||||
|
@ -43,7 +44,8 @@ APPS = \
|
||||||
touch \
|
touch \
|
||||||
sync \
|
sync \
|
||||||
more \
|
more \
|
||||||
guitest
|
guitest \
|
||||||
|
sysctl
|
||||||
|
|
||||||
ARCH_FLAGS =
|
ARCH_FLAGS =
|
||||||
STANDARD_FLAGS = -std=c++17 -nostdinc++ -nostdlib -nostdinc
|
STANDARD_FLAGS = -std=c++17 -nostdinc++ -nostdlib -nostdinc
|
||||||
|
@ -129,6 +131,9 @@ more: more.o
|
||||||
guitest: guitest.o
|
guitest: guitest.o
|
||||||
$(LD) -o $@ $(LDFLAGS) $< ../LibC/LibC.a
|
$(LD) -o $@ $(LDFLAGS) $< ../LibC/LibC.a
|
||||||
|
|
||||||
|
sysctl: sysctl.o
|
||||||
|
$(LD) -o $@ $(LDFLAGS) $< ../LibC/LibC.a
|
||||||
|
|
||||||
.cpp.o:
|
.cpp.o:
|
||||||
@echo "CXX $<"; $(CXX) $(CXXFLAGS) -o $@ -c $<
|
@echo "CXX $<"; $(CXX) $(CXXFLAGS) -o $@ -c $<
|
||||||
|
|
||||||
|
|
138
Userland/sysctl.cpp
Normal file
138
Userland/sysctl.cpp
Normal file
|
@ -0,0 +1,138 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <dirent.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <getopt.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <AK/AKString.h>
|
||||||
|
#include <AK/StringBuilder.h>
|
||||||
|
#include <AK/Vector.h>
|
||||||
|
|
||||||
|
static bool flag_show_all = false;
|
||||||
|
static int show_all();
|
||||||
|
static int handle_var(const char*);
|
||||||
|
|
||||||
|
static void usage()
|
||||||
|
{
|
||||||
|
printf("usage: sysctl [-a] [variable[=value]]\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char** argv)
|
||||||
|
{
|
||||||
|
int opt;
|
||||||
|
while ((opt = getopt(argc, argv, "a")) != -1) {
|
||||||
|
switch (opt) {
|
||||||
|
case 'a':
|
||||||
|
flag_show_all = true;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
usage();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (flag_show_all)
|
||||||
|
return show_all();
|
||||||
|
|
||||||
|
if (optind >= argc) {
|
||||||
|
usage();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char* var = argv[optind];
|
||||||
|
|
||||||
|
return handle_var(var);
|
||||||
|
}
|
||||||
|
|
||||||
|
int show_all()
|
||||||
|
{
|
||||||
|
DIR* dirp = opendir("/proc/sys");
|
||||||
|
if (!dirp) {
|
||||||
|
perror("opendir");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
char pathbuf[256];
|
||||||
|
|
||||||
|
while (auto* de = readdir(dirp)) {
|
||||||
|
if (de->d_name[0] == '.')
|
||||||
|
continue;
|
||||||
|
sprintf(pathbuf, "/proc/sys/%s", de->d_name);
|
||||||
|
int fd = open(pathbuf, O_RDONLY);
|
||||||
|
if (fd < 0) {
|
||||||
|
perror("open");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
char buffer[1024];
|
||||||
|
int nread = read(fd, buffer, sizeof(buffer));
|
||||||
|
close(fd);
|
||||||
|
if (nread < 0) {
|
||||||
|
perror("read");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
buffer[nread] = '\0';
|
||||||
|
printf("%s = %s", de->d_name, buffer);
|
||||||
|
if (nread && buffer[nread - 1] != '\n')
|
||||||
|
printf("\n");
|
||||||
|
}
|
||||||
|
closedir(dirp);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static String read_var(const String& name)
|
||||||
|
{
|
||||||
|
StringBuilder builder;
|
||||||
|
builder.append("/proc/sys/");
|
||||||
|
builder.append(name);
|
||||||
|
auto path = builder.build();
|
||||||
|
int fd = open(path.characters(), O_RDONLY);
|
||||||
|
if (fd < 0) {
|
||||||
|
perror("open");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
char buffer[1024];
|
||||||
|
int nread = read(fd, buffer, sizeof(buffer));
|
||||||
|
close(fd);
|
||||||
|
if (nread < 0) {
|
||||||
|
perror("read");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
return String(buffer, nread, Chomp);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void write_var(const String& name, const String& value)
|
||||||
|
{
|
||||||
|
StringBuilder builder;
|
||||||
|
builder.append("/proc/sys/");
|
||||||
|
builder.append(name);
|
||||||
|
auto path = builder.build();
|
||||||
|
int fd = open(path.characters(), O_WRONLY);
|
||||||
|
if (fd < 0) {
|
||||||
|
perror("open");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
int nwritten = write(fd, value.characters(), value.length());
|
||||||
|
if (nwritten < 0) {
|
||||||
|
perror("read");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
close(fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
int handle_var(const char* var)
|
||||||
|
{
|
||||||
|
String spec(var, Chomp);
|
||||||
|
auto parts = spec.split('=');
|
||||||
|
String variable_name = parts[0];
|
||||||
|
bool is_write = parts.size() > 1;
|
||||||
|
|
||||||
|
if (!is_write) {
|
||||||
|
printf("%s = %s\n", variable_name.characters(), read_var(variable_name).characters());
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("%s = %s", variable_name.characters(), read_var(variable_name).characters());
|
||||||
|
write_var(variable_name, parts[1]);
|
||||||
|
printf(" -> %s\n", read_var(variable_name).characters());
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue