Commit Graph

6 Commits

Author SHA1 Message Date
termux-pacman-bot
50282bfadb rebuild(packages/ghc): auto check by @termux-pacman-bot 2025-04-09 02:34:11 +00:00
termux-pacman-bot
263dc4c438 termux-pacman/auto-check-repo: preparing to recompile packages
[skip ci]
2025-04-09 02:34:09 +00:00
termux-pacman-bot
7a4ab56ecb bump(main/ghc): 9.12.2
Patched `rts` heap reservation logic on Android:

  * Need for patch

  - There seems to be a bug on Android. Sometimes simple commands like `ghc --help` usage 90% - 100% cpu and hangs.

  - It doesn't happen every time, but ~25% of the times (at least in my
    testing).

  * Cause of the bug

  - The function `osReserveHeapMemory` tries to allocate virtual space starting
    from `0x4200000000`. The allocated space has to start at an address >= this address.

  - If the kernel doesn't allocate inside this space, it keeps on repeating the
    `mmap` call with increasing starting point.

  - Now, on Android the kernel sometimes return an address above (as in counting)
    this `hint` address. It repeatedly returns the same address for subsequent calls.

  - Thus, an infinite loop occurs.

  References:
    - 383be28ffd/rts/posix/OSMem.c (L461)
    - https://github.com/termux/termux-packages/pull/22991#issuecomment-2759137291

  * Solution (proposed by Robert Kirkman):

  - It introduces a new helper function `osTryReserveHeapMemoryRecursive`.
    This transforms the heap reservation logic into a recursive one.

  - `osTryReserveHeapMemory()` is run multiple times without unmapping the
    undesired addresses. Thus, forcing the kernel to map subsequent calls of
    `mmap` to a new, unique address until an address above the `0x4200000000`
    mark is obtained.

  - After which each recursive call unmaps its undesired address before returning
    the desired address (in order from last mapped to first mapped).

  References:
    - https://gitlab.haskell.org/ghc/ghc/-/merge_requests/14164
    - https://github.com/termux/termux-packages/pull/22991#issuecomment-2761325484

Co-authored-by: Robert Kirkman <rkirkman@termux.dev>
Signed-off-by: Aditya Alok <alok@termux.dev>
2025-04-08 16:42:00 +00:00
termux-actions[bot]
9f67a9d5e4 packages/ghc&&packages/ghc-libs 2022-03-09 01:18:37 +00:00
termux-actions[bot]
a7676fa5ca packages/aspell-en&&packages/ghc 2022-01-30 04:47:22 +00:00
termux-actions[bot]
42285f3b56 packages/ghc 2022-01-04 11:32:19 +00:00