Rev |
Age |
Author |
Path |
Log message |
Diff |
4252 |
5666 d 18 h |
decky |
/trunk/kernel/ |
move event notification to the ipc directory (where it probably belogs to, side-by-side to IRQ notifications)
cleanup the notification code a little bit (there is probably no need to allocate two structured dynamically) |
|
4248 |
5666 d 22 h |
decky |
/trunk/kernel/generic/src/ipc/ |
avoid deadlock during cleanup
(the compare function which is called inside hash_table_remove acquires irq->lock) |
|
4173 |
5680 d 16 h |
jermar |
/trunk/ |
Revive kernel notifications. |
|
4041 |
5696 d 22 h |
jermar |
/trunk/kernel/generic/ |
If the server cannot receive a call because it supplied a bad userspace address, the kernel will immediately answer the call with EPARTY. |
|
4040 |
5698 d 0 h |
decky |
/trunk/kernel/generic/src/ipc/ |
add TODO |
|
3964 |
5708 d 0 h |
decky |
/trunk/kernel/ |
switch between the preference of kernel/uspace IRQ hash table |
|
3947 |
5710 d 20 h |
jermar |
/trunk/ |
This is the evil commit. In particular, it does:
- introduces more powerful pseudo code for userspace IRQ top-half handlers
- changes the internals of IRQ dispatching
- simplifies the kernel's i8042 driver
- adapts the uspace i8042 driver to make use of the new pseudocode
- breaks all other architectures except ia32
- breaks almost all existing drivers
- breaks switching between uspace and kernel drivers |
|
3930 |
5712 d 15 h |
jermar |
/trunk/kernel/ |
Adapt most of the kernel to ioport8_t, ioport16_t and ioport32_t types. |
|
3902 |
5716 d 22 h |
jermar |
/trunk/kernel/ |
Introduce a more platform-neutral name for programmed I/O.
The new API looks like pio_read_n() or pio_write_n(), where n is 8, 16 or 32.
The old API (i.e. inb(), inw(), inl(), outb() outw(), outl()) may have made
some people think that the interface is only to be used with the separate I/O
space. That's not the case. This API is to be implemented on all platforms
so that we can finally have really generic kernel device drivers. |
|
3875 |
5719 d 17 h |
decky |
/trunk/kernel/generic/ |
remove platform dependent constructs from generic code |
|
3870 |
5721 d 1 h |
decky |
/trunk/kernel/generic/src/ |
add includes necessary for LOG macro |
|
3867 |
5722 d 0 h |
svoboda |
/trunk/kernel/generic/src/ipc/ |
Bugfix: Check kbox, not regular box. In case where the debugger disconnected first and then the application terminated, the application task would not be cleaned up. |
|
3819 |
5737 d 17 h |
jermar |
/trunk/ |
Introduce a new syscall: SYS_IPC_FORWARD_SLOW. |
|
3657 |
5794 d 1 h |
vana |
/trunk/ |
Legacy IRQ support, uspace NS16550 support, some minor changes |
|
3620 |
5801 d 3 h |
svoboda |
/trunk/kernel/generic/ |
Move stuff related to kbox to a separate struct. |
|
3603 |
5802 d 15 h |
svoboda |
/trunk/ |
Stoppability sections must be much smaller (design error). Also fix deadlock in udebug_stop(). Fix pause functionality in tracer. |
|
3496 |
5832 d 17 h |
svoboda |
/trunk/kernel/generic/src/ipc/ |
Split and streamline kbox_thread_proc(). |
|
3495 |
5832 d 17 h |
svoboda |
/trunk/kernel/generic/src/ipc/ |
Synchronize properly when detaching kbox from within. |
|
3494 |
5834 d 17 h |
svoboda |
/trunk/kernel/generic/src/ipc/ |
Fix panic when debugged task quits. Also fix memory leak when debugger disconnects first. |
|
3476 |
5859 d 19 h |
jermar |
/trunk/kernel/generic/src/ipc/ |
Add comments documenting our treatment of the task's active call counter. |
|
3449 |
5866 d 17 h |
jermar |
/trunk/kernel/generic/src/ipc/ |
Fix task active call accounting for IPC_M_HUNGUP calls. |
|
3445 |
5867 d 17 h |
jermar |
/trunk/kernel/ |
Rename ipc/ipc_kbox.c to ipc/kbox.c. |
|
3441 |
5868 d 0 h |
svoboda |
/trunk/kernel/generic/src/ |
Use LOG() instead of printf() for debug messages. |
|
3438 |
5868 d 1 h |
svoboda |
/trunk/ |
Merge syscall tracer (trace) and relevant part of udebug interface from tracing to trunk. |
|
3395 |
5875 d 18 h |
jermar |
/trunk/kernel/generic/ |
Kernel's ipc_data_t and uspace's ipc_call_t must be in sync.
This commit fixes a problem introduced in revision 3362, when
ipc_data_t was enlarged by the caller_phone member. This resulted
in sys_ipc_wait_for_call() passing larger structure to uspace
than requested, leading to a random damage of userspace memory. |
|
3394 |
5876 d 16 h |
jermar |
/trunk/kernel/generic/src/ipc/ |
cstyle for ipc.c |
|
3370 |
5888 d 16 h |
jermar |
/trunk/kernel/generic/ |
Synchronous IPC must be interruptible. |
|
3363 |
5891 d 19 h |
jermar |
/trunk/kernel/generic/src/ipc/ |
Demasquerade the caller phone during ipc_answer_n() rather than in
ipc_wait_for_call(). |
|
3362 |
5891 d 19 h |
jermar |
/trunk/kernel/generic/ |
Fix processing of answers to forwarded masqueraded calls. |
|
3332 |
5900 d 0 h |
jermar |
/trunk/kernel/generic/src/ipc/ |
Fix types when processing IPC_M_DATA_WRITE arguments. |
|
3186 |
5953 d 19 h |
jermar |
/trunk/kernel/ |
Support for active mutexes. Active mutexes implement busy waiting, pretty much
in the same way as spinlocks, but can be passed to condition variables, which is
the motivation for this enhancement. |
|
3184 |
5954 d 22 h |
jermar |
/trunk/kernel/generic/src/ipc/ |
Fix a scary two-year old bug: do not attempt to initialize a call structure if
its allocation failed. |
|
3104 |
5971 d 6 h |
svoboda |
/trunk/kernel/ |
Declare arguments for memstr.h operations as pointers instead of uintptr_t. |
|
3090 |
5973 d 22 h |
decky |
/trunk/kernel/generic/src/ipc/ |
revert coding style change |
|
3054 |
5973 d 23 h |
decky |
/trunk/kernel/generic/src/ipc/ |
proper printf formatting |
|
3020 |
5979 d 17 h |
jermar |
/trunk/kernel/generic/ |
Turn phone->lock into mutex. |
|
2934 |
5992 d 19 h |
jermar |
/trunk/ |
Do not attempt to malloc() zero bytes of memory during VFS_READ at end of file. |
|
2802 |
6033 d 2 h |
jermar |
/trunk/kernel/generic/ |
Fix initialization of answerbox->task in ipc_answerbox_init.
Contributed by Jiri Svoboda. |
|
2745 |
6071 d 2 h |
decky |
/trunk/ |
code cleanup (mostly signed/unsigned)
allow extra compiler warnings |
|
2677 |
6128 d 21 h |
jermar |
/trunk/ |
Rename IPC_M_AS_AREA_SEND to IPC_M_SHARE_OUT. Rename IPC_M_AS_AREA_RECV to
IPC_M_SHARE_IN. Provide user-friendly wrappers for these methods so that even
dummies can get it right. Some applications using simpler protocols still use
these methods directly. |
|