aboutsummaryrefslogtreecommitdiff
path: root/core/thread/thread.odin
Commit message (Collapse)AuthorAgeFilesLines
* thread: fix aligned loading of unaligned addressesLaytan Laats2026-01-111-21/+24
|
* Further overhaul of package line comments.Jeroen van Rijn2025-10-091-1/+1
|
* Add doc line to `core:thread`gingerBill2025-10-091-0/+1
|
* Expand `self_cleanup` documentation.Jeroen van Rijn2025-06-241-12/+24
|
* CommentJeroen van Rijn2025-06-121-1/+2
|
* Early out and propagate `nil` in `create*`Jeroen van Rijn2025-04-171-13/+25
| | | | | If allocation of a `^Thread` failed, `create*` now properly return `nil`, so you can assert on that instead of calling `thread.destroy` on a null pointer, say.
* Fix #5049Jeroen van Rijn2025-04-171-2/+4
| | | | Keep in mind that `thread.create` needs an allocator to be set, as it returns `^Thread`.
* Use more atomic handling of thread flagsFeoramund2024-09-091-6/+6
| | | | This can prevent a data race on Linux with `Self_Cleanup`.
* [thread]: Document all functions in core:threadflysand72024-07-211-39/+242
|
* wasi: make the demo run on wasi and run it in CILaytan Laats2024-06-291-1/+5
|
* Add `#no_broadcast` procedure parameter to disallow automatic array ↵gingerBill2024-03-211-1/+1
| | | | programming broadcasting on procedure arguments
* Replace `core:*` to `base:*` where appropriategingerBill2024-01-281-2/+2
|
* Allow larger thread poly dataLaytan Laats2023-11-151-38/+55
| | | | | | | | The poly data currently has the restriction of being less than a pointer's size, but there is much more space in the `Thread.user_args` array which can be utilized, this commit allows you to pass types that are larger than pointer length as long as the total size of the poly data is less than that of the `Thread.user_args`.
* [core]: Remove `do` keyword from the core libraryflysand72023-11-111-6/+18
|
* [core:thread] Seeing if this fixes network testshikari2023-06-071-9/+14
|
* [core:thread] Added `self_cleanup` flag to properly auto-clean threadshikari2023-06-071-99/+27
|
* [thread] Refactor handling of 'init_context' + add doc comments for itTetralux2023-06-031-0/+63
|
* Fix join_multiple typoThimilius2022-05-111-1/+1
|
* Add `id` to `thread.Thread`gingerBill2021-10-241-0/+1
|
* Add `thread.create_and_start_with_*` proceduresgingerBill2021-10-111-0/+107
|
* Remove unneeded semicolons from the core librarygingerBill2021-08-311-1/+1
|
* Remove unneeded semicolons from the core librarygingerBill2021-08-311-93/+93
|
* Enforce `core:builtin` and `core:intrinsics` for importsgingerBill2021-08-211-1/+1
|
* Default to pthreads in sync2 for *nixgingerBill2021-04-131-1/+0
|
* Remove thread stuff from sync2; Cleanup package threadgingerBill2021-04-111-29/+40
|
* Fix typogingerBill2020-11-301-3/+3
|
* Fix `thread.run_with_poly_data*`gingerBill2020-11-301-28/+42
|
* Fix sync.Channel code; add `thread.run_with_poly_data` and ↵gingerBill2020-11-101-7/+93
| | | | `run_with_poly_data(2|3|4)` procedures
* Update package syncgingerBill2020-08-021-1/+1
|
* Add sync.OncegingerBill2020-07-141-0/+30
|
* Update `sys/unix`; Rename `thread.create_and_start`gingerBill2020-06-271-1/+2
|
* Remove unused imports in thread.odingingerBill2020-06-221-2/+0
|
* Add `thread.run*` shorthand procedures; `Thread.init_context` use new ↵gingerBill2020-06-221-2/+40
| | | | `Maybe` concept
* Add `thread.Pool` with example in demo.odin; Update linalg to support ↵gingerBill2020-01-021-3/+3
| | | | handness changes for projection matrices
* Implement core:thread and core:sync on Unix using pthreadsTetralux2019-12-011-0/+15
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Also do some cleanup and refactoring of the thread, sync and time APIs. - remove 'semaphore_release' because 'post' and 'wait' is easier to understand - change 'semaphore_wait' to '*_wait_for' to match Condition - pthreads can be given a stack, but doing so requires the user to set up the guard pages manually. BE WARNED. The alignment requirements of the stack are also platform-dependant; it may need to be page size aligned on some systems. Unclear which systems, however. See 'os.get_page_size', and 'mem.make_aligned'. HOWEVER: I was unable to get custom stacks with guard pages working reliably, so while you can do it, the API does not support it. - add 'os.get_page_size', 'mem.make_aligned', and 'mem.new_aligned'. - removed thread return values because windows and linux are not consistent; windows returns 'i32' and pthreads return 'void*'; besides which, if you really wanted to communicate how the thread exited, you probably wouldn't do it with the thread's exit code. - fixed 'thread.is_done' on Windows; it didn't report true immediately after calling 'thread.join'. - moved time related stuff out of 'core:os' to 'core:time'. - add 'mem.align_backward' - fixed default allocator alignment The heap on Windows, and calloc on Linux, both have no facility to request alignment. It's a bit of hack, but the heap_allocator now overallocates; `size + alignment` bytes, and aligns things to at least 2. It does both of these things to ensure that there is at least two bytes before the payload, which it uses to store how much padding it needed to insert in order to fulfil the alignment requested. - make conditions more sane by matching the Windows behaviour. The fact that they were signalled now lingers until a thread tries to wait, causing them to just pass by uninterrupted, without sleeping or locking the underlying mutex, as it would otherwise need to do. This means that a thread no longer has to be waiting in order to be signalled, which avoids timing bugs that causes deadlocks that are hard to debug and fix. See the comment on the `sync.Condition.flag` field. - add thread priority: `thread.create(worker_proc, .High)`
* Fix delayed assert collectiongingerBill2018-05-271-79/+0
|
* Add basic package support (no IR support yet)gingerBill2018-05-261-4/+1
|
* Parse directories to be packagesgingerBill2018-05-211-0/+82