libk  Hex Artifact Content

Artifact 9bf0ba9bf335a14181352610e983f3a716532589ea7520bdbc6128f93b028a84:

  • File mod/kcore/syscall.fn.x86.lin.64.s — part of check-in [e50a476efe] at 2019-08-22 02:52:20 on branch trunk — removed sneaky segfault in x86-64 syscall fn where %r8 (the register that contains the pointer to the syscall arguments from the C syscall wrapper, which need to be copied into the correct registers before the kernel is invoked) gets overwritten if the syscall valency > 5, because of overlapping ccall and syscall ABI argument registers - r8 is clobbered by argument 5 and any further attempts to use it as a ptr segfault at best. also modified the report function so that it immediate cancels compilation if a sub-process reports failure. changed allocator function signatures so they can return a condition code if the kernel reports an error; updated example code so it compiles and runs without fault. (user: lexi, size: 2358) [annotate] [blame] [check-ins using]

A hex dump of this file is not available. Please download the raw binary file and generate a hex dump yourself.