Merge branch 'master' into isa/arm64
[lunaix-os.git] / lunaix-os / LConfig
index 3d0a17981535328734ca7a741a1ab436bcd90438..1c151e3c7ce94dd8b5611b9e488d79998c756093 100644 (file)
@@ -1,9 +1,10 @@
 import time
 
-include("kernel/LConfig")
-include("arch/LConfig")
+include("kernel")
+include("arch")
+include("hal")
 
-@Term("Version")
+@Term("Kernel Version")
 @ReadOnly
 def lunaix_ver():
     """
@@ -13,9 +14,9 @@ def lunaix_ver():
     type(str)
     
     seq_num = int(time.time() / 3600)
-    default("dev-2024_%d"%(seq_num))
+    default("%s dev-2024_%d"%(v(arch), seq_num))
 
-@Collection
+@Collection("Kernel Debug and Testing")
 def debug_and_testing():
     """
     General settings for kernel debugging feature
@@ -29,4 +30,39 @@ def debug_and_testing():
               extermly unstable
         """
         type(bool)
-        default(False)
\ No newline at end of file
+        default(False)
+
+    @Term("Report on stalled thread")
+    def check_stall():
+        """
+        Check and report on any thread that spend too much time in kernel.
+        """
+
+        type(bool)
+        default(True)
+        
+    @Term("Max kernel time allowance")
+    def stall_timeout():
+        """
+        Set the maximum time (in seconds) spent in kernel before considered
+        to be stalled.
+        """
+
+        type(int)
+        default(10)
+
+        return v(check_stall)
+    
+    @Term("Max number of preemptions")
+    def stall_max_preempts():
+        """
+        Set the maximum number of preemptions that a task can take
+        before it is considered to be stucked in some loops.
+
+        Setting it to 0 disable this check
+        """
+
+        type(int)
+        default(0)
+
+        return v(check_stall)
\ No newline at end of file