Commit graph

62653 commits

Author SHA1 Message Date
Sönke Holz
1d83f73ec5 Kernel/PCI: Stop using a dangling pointer in dmesgln_pci
VariadicFormatParams only stores pointers to the parameters, so
the device.device_name() parameter will dangle.

This fixes broken dmesgln_pci output on riscv64 GCC.
2024-09-07 12:52:52 -04:00
Nico Weber
b72136cad5 LibCompress: Remove needless check
I added this check in #18216 in commit 6d38824985.

Back then, I mentioned that `m_bit_codes` is only used for writing,
but only added reading support. `CanonicalCode::from_bytes()` sets
up both tables for reading and writing, so I needed the construction
of the writing tables to not crash. This check in
`CanonicalCode::write_symbol()` was dead code back then though.

Later, #24700 added support for writing WebP files, and it can create
canonical codes with more than 288 symbols. This works just fine, is
now under test, and this check in `write_symbol()` isn't needed
(and never was). So remove it again.

No behavior change.

(I saw this in the profiler once, so maybe a tiny speedup for
writing deflate-compressed data, but on the order of < 2%.)
2024-09-06 18:09:29 -04:00
Sönke Holz
b628ab0ae3 Kernel/riscv64: Add comment about the bss to the linker script 2024-09-06 16:02:08 -04:00
Sönke Holz
ed3fa378c5 Kernel/riscv64: Add FLAGS to the PHDRS linker script command
Otherwise validate_program_headers will complain about the kernel text
segment being executable and writable.
2024-09-06 16:02:08 -04:00
Liav A.
3e7eb30466 Utilities/du: Add an option to print the total size in the end
This is useful when using du on many files and wanting to get a total
size count in the end after iterating on all the directories and files.
2024-09-05 16:36:12 +02:00
Liav A.
c23005a3f0 Utiltities/elfdeps: Add an option to only print library paths
This is useful for argument passing to other utilities on the terminal.
2024-09-05 16:36:12 +02:00
Liav A.
0482f4e117 Kernel: Remove passing of register state to IRQ handlers
Linux did the same thing 18 years ago and their reasons for the change
are similar to ours - https://github.com/torvalds/linux/commit/7d12e78

Most interrupt handlers (i.e. IRQ handlers) never used the register
state reference anywhere so there's simply no need of passing it around.
I didn't measure the performance boost but surely this change can't make
things worse anyway.
2024-09-01 21:00:18 +02:00
Liav A.
fdf3e0aca1 Kernel: Don't assume sizes of needed buffers early in the execve syscall
Instead, start by trying to read a buffer with size of Elf_Ehdr, and
check it for the shebang sign. If it's indeed an executable with shebang
then read again from the file, now with PAGE_SIZE size, which should
suffice for finding the interpreter path.

However, if the executable is an ELF, we quickly validate it and then
pass the preliminary buffer to the find_elf_interpreter_for_executable
method.

That method calculates the last byte offset which is needed to read all
of the program headers, so we don't just assume 4096 bytes is sufficient
anymore. The same pattern is applied when loading the interpreter ELF
main header and its program headers.
2024-09-01 20:52:55 +02:00
Tim Ledbetter
f5cfee08d7 Ports/devilutionX: Update to version 1.5.3 2024-09-01 01:26:21 +02:00
brody-qq
44a2157e2e Kernel/Ext2FS: Reduce allocations in compute_block_list_impl()
In Ext2FSInode::compute_block_list_impl(), each call to
process_block_array() creates a new ByteBuffer, which leads to a
kmalloc() call. The ByteBuffer is then discarded when
process_block_array() exits, leading to a kfree() call.

This leads to repeated kmalloc() and kfree() calls as ByteBuffers are
created and destroyed each time process_block_array() is called.

This commit makes it so that only 1 ByteBuffer is created for each level
of inode indirect block (so only 3 ByteBuffers are created at most).
These ByteBuffers are re-used on each call to process_block_array().

This reduces the number of kmalloc() and kfree() calls during
compute_block_list_impl(), especially for larger files.
2024-08-30 22:22:13 +02:00
Dan Klishch
500ff2a7ed AK: Declare AK::Coroutine<T>::CoroutinePromiseBase::unhandled_exception
For some reason, Clang wants AK to work with exceptions enabled so much
that it produces a very annoying warning complaining about the absence
of (completely useless in our setup) unhandled_exception method in
promise type for every coroutine declared. We work around this during
build by suppressing -Wcoroutine-missing-unhandled-exception in
Meta/CMake/common_compile_options.cmake. However, the flag is only added
if build is using Clang. If one builds coroutine code with GCC but still
uses clangd, clangd, obviously, doesn't pick up warning suppression and
annoys user with a squiggly yellow line under each coroutine function
declaration.
2024-08-29 13:28:42 +02:00
Dan Klishch
3d3dd46618 AK: Rename AsyncStreamBuffer -> StreamBuffer
There is not nearly enough async-specific stuff in AsyncStreamBuffer for
it to carry "Async" prefix.
2024-08-29 13:28:42 +02:00
Dan Klishch
c3e13ce420 AK: Do not return value from void must_sync<void>(...) 2024-08-29 13:28:42 +02:00
Sönke Holz
a9a63c0f7c CI: Build riscv64 in CI
Don't run any tests on riscv64 for now, since some tests still fail
(mostly due to missing generic AK/Math.h implementations).
2024-08-27 12:03:49 +02:00
Dan Klishch
3ead8e8f4f AK: Make workaround for broken coroutine type deduction more specific
This bug was fixed on GCC trunk.
2024-08-26 17:47:03 +02:00
MacDue
ba21a17b75 shot: Use "popup" window type for screenshot area selection
This allows the selection to appear above all normal window types
including the task bar.
2024-08-25 15:34:38 +01:00
Alec Murphy
d73bad14ea LibIMAP+Mail: Show unseen message count for mailboxes
This PR implements the standard behavior of displaying the mailbox name
and parenthesized unseen message count in bold when the unseen message
count is greater than zero.
2024-08-24 21:52:44 -04:00
A* Ulven
4ac1ad48a2 LibVT: Handle concealed ANSI escape codes 2024-08-24 12:38:35 -04:00
Alec Murphy
99b01816ad Base: Add poweroff alias to shellrc
Just a little QoL improvement for muscle memory :^)
2024-08-23 22:16:50 +02:00
Nico Weber
af0fe2374d Tests: Modernize TestDeflate a bit
- Use TRY_OR_FAIL() instead of MUST() in a few places
- Use for-each loop in two tests
- Use StringView literals instead of u8 arrays in a few places

No behavior change.
2024-08-23 14:54:37 -04:00
Lucas CHOLLET
3fc784c442 AK/FuzzyMatch: Return the best possible score in case of equality
This fixes cases where fuzzy matching would return a better score for
a different pattern than a needle perfectly matching the haystack.

As an example, when searching for "fire" in emojis, "Fire Engine" would
have scored 168, while "Fire" was giving only 160.
This patch makes the latter have the best possible score.
2024-08-23 14:14:05 -04:00
Lucas CHOLLET
79431198ac AK/FuzzyMatch: Const qualify a u8 pointer 2024-08-23 14:14:05 -04:00
Lucas CHOLLET
dff57085ef AK/FuzzyMatch: Remove unnecessary const qualifier
These variables are already `constexpr`.
2024-08-23 14:14:05 -04:00
Nico Weber
18c9afe0c2 Meta: Make unzip buildable on lagom
Useful for profiling deflate performance for enwik8.zip.
2024-08-23 14:10:37 -04:00
Dan Klishch
32a8ef390b LibCrypto: Make dummy authenticated text length 16 bytes in GCM
Some callers of this API needlessly provide very large output buffer
even when input is small. Since we throw away all authentication-related
information here anyway, let's make the buffer (that gets
authenticated!) as small as possible.
2024-08-22 11:55:11 +02:00
Marek Knápek
07a58d2707 LibCrypto: Implement AES by using x86 intrinsics 2024-08-21 08:19:35 -04:00
Sönke Holz
75ccee81be Kernel: Use the correct ip in the dispatch_signal debug output
The signal handler RegisterState is in 'regs', not 'm_regs'.
2024-08-21 08:17:17 -04:00
Sönke Holz
7b0553eb13 Kernel/x86: Add missing rcx + r11 clobber to Syscall::invoke with 4 args
The 4-arg version was missing those.
2024-08-21 08:17:17 -04:00
Sönke Holz
d9c098f103 Kernel/x86: Use iretq instead of sysretq for sys$sigreturn
Using sysretq clobbers rcx and r11 as this instruction loads the rip and
rflags from those registers. This is fine for normal syscalls.

Signal dispatching works like this:
The kernel makes userspace jump to the signal trampoline when a signal
is dispatched. That trampoline then executes the sigreturn syscall after
calling the signal handler to continue executing the code before the
signal was dispatched.

Since e71c320154 the sigreturn syscall is done via the syscall
instruction (and int 0x82 support was removed in the next commit),
which causes the kernel to currently use sysretq to return to userspace.
But signals can happen at any time, not just during syscalls, so the
sigreturn syscall shouldn't clobber the contents of those registers when
returning to userspace.
2024-08-21 08:17:17 -04:00
Lucas CHOLLET
b806c52bd3 ImageViewer: Set scaling mode's default value to "Box Sampling"
This provides a way better experience when visualizing images. At some
point, we should probably remove the option to control it from the GUI.
2024-08-21 07:38:52 -04:00
Rishan Thangaraj
f5cb280608 TextEditor: Port TextEditor to GML Compiler 2024-08-21 07:36:23 -04:00
Hendiadyoin1
f5d2671718 Kernel/USBMS: Query and use the Block Limits VPD page
This allows us to properly limit our block requests to the device's
capabilities, and choose more optimal block counts for I/O operations.
In theory, as Qemu  only advertises a block limit above our current
internal block size limit of u16::max and does not advertise any optimal
transfer lengths.
2024-08-20 22:06:51 -04:00
Hendiadyoin1
0d2e8ec96f Kernel/USBMS: Inquire and wait for the storage device to become ready
This is apparently what bootloaders do before using a USB storage device
so we should likely do so as well, especially when no BIOS is present,
like on riscv.

Co-Authored-By: Sönke Holz <sholz8530@gmail.com>
2024-08-20 22:06:51 -04:00
Hendiadyoin1
e3567969d4 Kernel/USBMS: Add and use a send_scsi_command helper
This makes sending commands less repetitive
2024-08-20 22:06:51 -04:00
Hendiadyoin1
0866adde12 Kernel/USB: Be a bit more const-correct with USB transfers 2024-08-20 22:06:51 -04:00
Sönke Holz
13e789a261 Kernel/riscv64: Verify the FDT magic before copying it 2024-08-20 21:52:12 -04:00
Hendiadyoin1
f74f80e13b Kernel/aarch64: Use the FDT to get the device/boot info
This removes the old hacky multiboot memory map and instead uses the
FDT to get the actual memory map.
2024-08-20 21:52:12 -04:00
Hendiadyoin1
55a22ad393 Kernel/aarch64: Save the device tree 2024-08-20 21:52:12 -04:00
Sönke Holz
77a44df92b Meta: Download and use the Raspberry Pi 3 devicetree for running in qemu 2024-08-20 21:52:12 -04:00
Sönke Holz
c990c85d52 Meta: Use the correct build directory environment variable in run.py 2024-08-20 21:52:12 -04:00
Hendiadyoin1
e0a177061e Kernel/Firmware+riscv64: Move devicetree handling to Firmware directory
This also adds a `verify_fdt` method which will be used in later commits
2024-08-20 21:52:12 -04:00
Sönke Holz
1ffb7afba7 Kernel/aarch64: Make the kernel bootable from any physical load address
Instead calculate the load offset at runtime.

The mapping of the initial stack is now done explicitly. It was
previously included in the 2 MiB-aligned kernel range.

We need to use kernel8.img now, as we no longer hard-code the physical
addresses of all sections in the linker script. QEMU would otherwise
try to load us at KERNEL_MAPPING_BASE.
2024-08-20 21:52:12 -04:00
Sönke Holz
ba27989da1 Kernel/aarch64: Use MM's virtual_to_low_physical for Mailbox::send_queue
This is slightly better than assuming that cutting off the high 32 bits
results in the physical address. This worked for now because the kernel
(and stack) is mapped at KERNEL_MAPPING_BASE + PHYSICAL_LOAD_ADDR and
KERNEL_MAPPING_BASE & 0xffff'ffff == 0.

The next commit will move the kernel to KERNEL_MAPPINGS_BASE + 0, so
we need to get the physical address in a slightly less hacky way.
2024-08-20 21:52:12 -04:00
Sönke Holz
194d9df34f Kernel/Memory: Handle devicetree memory nodes with more than one region 2024-08-20 21:52:12 -04:00
Sönke Holz
ab44530304 Kernel/Memory: Remove x86 LAPIC address hack
MM is now able to handle MMIO after our "highest_phyisical_address".
2024-08-20 21:52:12 -04:00
Sönke Holz
810f2e7f29 Kernel/aarch64: Include .bss* sections in the linker script 2024-08-20 21:52:12 -04:00
A* Ulven
e863ba629e Documentation: Correct fuse2fs instructions for Fedora
`fuse2fs` comes from the `e2fsprogs` package in Fedora.
https://src.fedoraproject.org/rpms/e2fsprogs
2024-08-20 21:48:29 -04:00
Nico Weber
5b15951518 Meta: Port recent changes to the GN build
59aaef08d9 LibMedia: Rename LibVideo to LibMedia
aa2f5df0a9 AK: Add a helper to detect which CPU features are supported
0bbf42bca7 LibJS: Introduce the CanonicalizeKeyedCollectionKey AO
e06d74c314 LibWeb: Give DOM Elements a CountersSet
07fe3e57c6 LibWeb: Implement CounterStyleValue
1bc896fa60 LibWeb: Implement counter-[increment,reset,set] properties
78a22f5098 LibWeb: Replace templated retarget function with a regul...
e4fa0e7f63 LibWeb: Implement fetch record from the fetch spec
a8c4f34bff LibWeb: Create separate DedicatedWorkerGlobalScope class

Also add Services to include_dirs for LibWeb. This is necessary
due to the <WebWorker/DedicatedWorkerHost.h> include added in #24870.
2024-08-20 21:45:17 -04:00
Nico Weber
a3258d4094 LibGfx/ICC: Tolerate v2 profiles with D65 PCS illuminant
They do happen in practice.

We might have to do more to do actual color conversions with
these profiles, but for now let's at least load them.

Fixes rendering of a few images in my thesis in LibPDF.
The images were created in OmniGraffle in 2008, then saved as
PDF, then converted to eps using LaTeX tooling.
2024-08-20 09:43:06 -04:00
Stanisław Wiśniewski
02fd9b7d02 LibCore: Use forward() instead of move() for forwarding reference
Caught by clang-tidy `bugprone-move-forwarding-reference`
2024-08-20 09:12:50 -04:00