Mutex_Acquire(&pty->InputMutex);
Length = _rb_read(pty->InputData, INPUT_RINGBUFFER_LEN, &pty->InputReadPos, &pty->InputWritePos,
Buffer, Length);
+ if( Length && pty->ServerNode )
+ VFS_MarkFull(pty->ServerNode, 0);
Mutex_Release(&pty->InputMutex);
if(pty->InputReadPos == pty->InputWritePos)
}
// Write to either FIFO or directly to output function
- if( pty->OutputFcn )
- {
+ if( pty->OutputFcn ) {
pty->OutputFcn(pty->OutputHandle, Length, Buffer);
+ return Length;
}
- else
- {
- // Write to output ringbuffer
- Length = _rb_write(pty->OutputData, OUTPUT_RINGBUFFER_LEN,
- &pty->OutputReadPos, &pty->OutputWritePos,
- Buffer, Length);
- VFS_MarkAvaliable(pty->ServerNode, 1);
+
+ // FIFO
+ tTime timeout_z, *timeout = (Flags & VFS_IOFLAG_NOBLOCK) ? &timeout_z : NULL;
+ int rv;
+
+ rv = VFS_SelectNode(Node, VFS_SELECT_WRITE, timeout, "PTY_WriteClient");
+ if(!rv ) {
+ errno = (timeout ? EWOULDBLOCK : EINTR);
+ return -1;
}
+ // Write to output ringbuffer
+ Length = _rb_write(pty->OutputData, OUTPUT_RINGBUFFER_LEN,
+ &pty->OutputReadPos, &pty->OutputWritePos,
+ Buffer, Length);
+ VFS_MarkAvaliable(pty->ServerNode, 1);
+ if( (pty->OutputWritePos + 1) % OUTPUT_RINGBUFFER_LEN == pty->OutputReadPos )
+ VFS_MarkFull(Node, 1);
+
return Length;
}
size_t PTY_ReadServer(tVFS_Node *Node, off_t Offset, size_t Length, void *Buffer, Uint Flags)
{
tPTY *pty = Node->ImplPtr;
+ if( !pty ) {
+ errno = EIO;
+ return -1;
+ }
// TODO: Prevent two servers fighting over client's output
if( pty->OutputFcn )
//\! Write to the client's input
size_t PTY_WriteServer(tVFS_Node *Node, off_t Offset, size_t Length, const void *Buffer, Uint Flags)
{
- return PTY_SendInput(Node->ImplPtr, Buffer, Length);
+ tPTY *pty = Node->ImplPtr;
+ if( !pty ) {
+ errno = EIO;
+ return -1;
+ }
+
+ tTime timeout_z = 0, *timeout = (Flags & VFS_IOFLAG_NOBLOCK) ? &timeout_z : NULL;
+ int rv = VFS_SelectNode(Node, VFS_SELECT_WRITE, timeout, "PTY_WriteServer");
+ if(!rv) {
+ errno = (timeout ? EWOULDBLOCK : EINTR);
+ return -1;
+ }
+ size_t used = 0;
+ do {
+ used += PTY_SendInput(Node->ImplPtr, Buffer, Length);
+ } while( used < Length && !(Flags & VFS_IOFLAG_NOBLOCK) );
+
+ if( (pty->InputWritePos+1)%INPUT_RINGBUFFER_LEN == pty->InputReadPos )
+ VFS_MarkFull(Node, 1);
+ return used;
}
void PTY_CloseServer(tVFS_Node *Node)
USRLIBS += libreadline.so libnet.so liburi.so libpsocket.so
USRLIBS += libimage_sif.so libunicode.so
+EXTLIBS := libspiderscript
+# zlib libpng
+
USRAPPS := init login CLIShell cat ls mount automounter
USRAPPS += bomb lspci
USRAPPS += ip dhcpclient ping telnet irc wget telnetd
USRAPPS += axwin3 gui_ate gui_shell
-ALL_DYNMODS = $(addprefix all-,$(DYNMODS))
-ALL_MODULES := $(addprefix all-,$(MODULES))
-ALL_USRLIBS := $(addprefix all-,$(USRLIBS))
-ALL_USRAPPS := $(addprefix all-,$(USRAPPS))
-CLEAN_DYNMODS := $(addprefix clean-,$(DYNMODS))
-CLEAN_MODULES := $(addprefix clean-,$(MODULES))
-CLEAN_USRLIBS := $(addprefix clean-,$(USRLIBS))
-CLEAN_USRAPPS := $(addprefix clean-,$(USRAPPS))
-INSTALL_DYNMODS := $(addprefix install-,$(DYNMODS))
-INSTALL_MODULES := $(addprefix install-,$(MODULES))
-INSTALL_USRLIBS := $(addprefix install-,$(USRLIBS))
-INSTALL_USRAPPS := $(addprefix install-,$(USRAPPS))
-AI_DYNMODS := $(addprefix allinstall-,$(DYNMODS))
-AI_MODULES := $(addprefix allinstall-,$(MODULES))
-AI_USRLIBS := $(addprefix allinstall-,$(USRLIBS))
-AI_USRAPPS := $(addprefix allinstall-,$(USRAPPS))
+define targetclasses
+ AI_$1 := $$(addprefix allinstall-,$$($1))
+ ALL_$1 := $$(addprefix all-,$$($1))
+ CLEAN_$1 := $$(addprefix clean-,$$($1))
+ INSTALL_$1 := $$(addprefix install-,$$($1))
+endef
+
+$(eval $(call targetclasses,DYNMODS))
+$(eval $(call targetclasses,MODULES))
+$(eval $(call targetclasses,USRLIBS))
+$(eval $(call targetclasses,EXTLIBS))
+$(eval $(call targetclasses,USRAPPS))
+
+targetvars := $$(AI_$1) $$(ALL_$1) $$(CLEAN_$1) $$(INSTALL_$1)
.PHONY: all clean install \
- kmode all-kmode clean-kmode \
- all-user clean-user \
- utest mtest \
- $(ALL_MODULES) all-Kernel $(ALL_USRLIBS) $(ALL_USRAPPS) \
- $(AI_MODULES) allinstall-Kernel $(AI_USRLIBS) $(AI_USRAPPS) \
- $(CLEAN_MODULES) clean-Kernel $(CLEAN_USRLIBS) $(CLEAN_USRAPPS) \
- $(INSTALL_MODULES) install-Kernel $(INSTALL_USRLIBS) $(INSTALL_USRAPPS)
-
-kmode: $(AI_MODULES) $(AI_DYNMODS) allinstall-Kernel
-all-kmode: $(ALL_MODULES) $(ALL_DYNMODS) all-Kernel
+ ai-kmode all-kmode clean-kmode install-kmode \
+ ai-user all-user clean-user install-user \
+ utest mtest
+
+.PHONY: allinstall-Kernel all-Kernel clean-Kernel install-Kernel \
+ $(call targetvars,DYNMODS) \
+ $(call targetvars,MODULES) \
+ $(call targetvars,USRLIBS) \
+ $(call targetvars,EXTLIBS) \
+ $(call targetvars,USRAPPS)
+
+ai-kmode: $(AI_MODULES) allinstall-Kernel $(AI_DYNMODS)
+all-kmode: $(ALL_MODULES) all-Kernel $(ALL_DYNMODS)
clean-kmode: $(CLEAN_MODULES) $(CLEAN_DYNMODS) clean-Kernel
+install-kmode: $(INSTALL_MODULES) install-Kernel $(INSTALL_DYNMODS)
-all-user: $(ALL_USRLIBS) $(ALL_USRAPPS)
-clean-user: $(CLEAN_USRLIBS) $(CLEAN_USRAPPS)
+ai-user: $(AI_USRLIBS) $(AI_EXTLIBS) $(AI_USRAPPS)
+all-user: $(ALL_USRLIBS) $(ALL_EXTLIBS) $(ALL_USRAPPS)
+clean-user: $(CLEAN_USRLIBS) $(CLEAN_EXTLIBS) $(CLEAN_USRAPPS)
+install-user: $(INSTALL_USRLIBS) $(INSTALL_EXTLIBS) $(INSTALL_USRAPPS)
-all: SyscallList $(ALL_USRLIBS) $(ALL_USRAPPS) $(ALL_MODULES) all-Kernel $(ALL_DYNMODS)
-all-install: install-Filesystem SyscallList $(AI_USRLIBS) $(AI_USRAPPS) $(AI_MODULES) allinstall-Kernel $(AI_DYNMODS)
-clean: $(CLEAN_DYNMODS) $(CLEAN_MODULES) clean-Kernel $(CLEAN_USRLIBS) $(CLEAN_USRAPPS)
-install: install-Filesystem SyscallList $(INSTALL_USRLIBS) $(INSTALL_USRAPPS) $(INSTALL_DYNMODS) $(INSTALL_MODULES) install-Kernel
+all: SyscallList all-user all-kmode
+all-install: install-Filesystem SyscallList ai-user ai-kmode
+clean: clean-kmode clean-user
+install: install-Filesystem SyscallList install-user install-kmode
utest: $(USRLIBS:%=utest-%)
_build_stmod := BUILDTYPE=static $(SUBMAKE) -C KernelLand/Modules/
_build_kernel := $(SUBMAKE) -C KernelLand/Kernel
-# Compile Only
-$(ALL_DYNMODS): all-%:
- +@echo === Dynamic Module: $* && $(_build_dynmod)$* all
-$(ALL_MODULES): all-%:
- +@echo === Module: $* && $(_build_stmod)$* all
+define rules
+$$(ALL_$1): all-%:
+ +@echo === $2 && $3 all
+$$(AI_$1): allinstall-%:
+ +@echo === $2 && $3 all install
+$$(CLEAN_$1): clean-%:
+ +@echo === $2 && $3 clean
+$$(INSTALL_$1): install-%:
+ +@$3 install
+endef
+
+$(eval $(call rules,DYNMODS,Dynamic Module: $$*,$(_build_dynmod)$$*))
+$(eval $(call rules,MODULES,Module: $$*,$(_build_stmod)$$*))
+$(eval $(call rules,USRLIBS,User Library: $$*,$(SUBMAKE) -C Usermode/Libraries/$$*_src))
+$(eval $(call rules,EXTLIBS,External Library: $$*,$(SUBMAKE) -C Externals/$$*))
+$(eval $(call rules,USRAPPS,User Application: $$*,$(SUBMAKE) -C Usermode/Applications/$$*_src))
all-Kernel:
+@echo === Kernel && $(_build_kernel) all
-$(ALL_USRLIBS): all-%:
- +@echo === User Library: $* && $(SUBMAKE) all -C Usermode/Libraries/$*_src
-$(ALL_USRAPPS): all-%:
- +@echo === User Application: $* && $(SUBMAKE) all -C Usermode/Applications/$*_src
-
-# Compile & Install
-$(AI_DYNMODS): allinstall-%:
- +@echo === Dynamic Module: $* && $(_build_dynmod)$* all install
-$(AI_MODULES): allinstall-%:
- +@echo === Module: $* && $(_build_stmod)$* all install
allinstall-Kernel:
+@echo === Kernel && $(_build_kernel) all install
-$(AI_USRLIBS): allinstall-%:
- +@echo === User Library: $* && $(SUBMAKE) all install -C Usermode/Libraries/$*_src
-$(AI_USRAPPS): allinstall-%:
- +@echo === User Application: $* && $(SUBMAKE) all install -C Usermode/Applications/$*_src
-
-# Clean up compilation
-$(CLEAN_DYNMODS): clean-%:
- +@$(_build_dynmod)$* clean
-$(CLEAN_MODULES): clean-%:
- +@$(_build_stmod)$* clean
clean-Kernel:
+@$(_build_kernel) clean
-$(CLEAN_USRLIBS): clean-%:
- +@$(SUBMAKE) clean -C Usermode/Libraries/$*_src
-$(CLEAN_USRAPPS): clean-%:
- +@$(SUBMAKE) clean -C Usermode/Applications/$*_src
-
-# Install
-ifeq ($(ARCH),host)
-install-%:
-
-else
-$(INSTALL_DYNMODS): install-%:
- @$(_build_dynmod)$* install
-$(INSTALL_MODULES): install-%:
- @$(_build_stmod)$* install
-install-Filesystem:
- @$(SUBMAKE) install -C Usermode/Filesystem
install-Kernel:
@$(_build_kernel) install
-$(INSTALL_USRLIBS): install-%:
- @$(SUBMAKE) install -C Usermode/Libraries/$*_src
-$(INSTALL_USRAPPS): install-%:
- @$(SUBMAKE) install -C Usermode/Applications/$*_src
-endif
+install-Filesystem:
+ @$(SUBMAKE) install -C Usermode/Filesystem