summaryrefslogtreecommitdiff
path: root/stand/lua
diff options
context:
space:
mode:
authorKyle Evans <kevans@FreeBSD.org>2018-10-07 15:28:50 +0000
committerKyle Evans <kevans@FreeBSD.org>2018-10-07 15:28:50 +0000
commit1613f09199eb198b62f81df8fa92ec163a01c78f (patch)
tree7fd5b882dc7c034468c2d3d610361ae1deaa9f69 /stand/lua
parent3535cdc43e07efefbe6993e2a835896fd8fdbdce (diff)
downloadsrc-test2-1613f09199eb198b62f81df8fa92ec163a01c78f.tar.gz
src-test2-1613f09199eb198b62f81df8fa92ec163a01c78f.zip
Notes
Diffstat (limited to 'stand/lua')
-rw-r--r--stand/lua/core.lua39
1 files changed, 28 insertions, 11 deletions
diff --git a/stand/lua/core.lua b/stand/lua/core.lua
index 3c4fece1e226..ca7cd5f253dd 100644
--- a/stand/lua/core.lua
+++ b/stand/lua/core.lua
@@ -34,6 +34,10 @@ local hook = require("hook")
local core = {}
+local default_safe_mode = false
+local default_single_user = false
+local default_verbose = false
+
local function composeLoaderCmd(cmd_name, argstr)
if argstr ~= nil then
cmd_name = cmd_name .. " " .. argstr
@@ -41,6 +45,26 @@ local function composeLoaderCmd(cmd_name, argstr)
return cmd_name
end
+local function recordDefaults()
+ -- On i386, hint.acpi.0.rsdp will be set before we're loaded. On !i386,
+ -- it will generally be set upon execution of the kernel. Because of
+ -- this, we can't (or don't really want to) detect/disable ACPI on !i386
+ -- reliably. Just set it enabled if we detect it and leave well enough
+ -- alone if we don't.
+ local boot_acpi = core.isSystem386() and core.getACPIPresent(false)
+ local boot_single = loader.getenv("boot_single") or "no"
+ local boot_verbose = loader.getenv("boot_verbose") or "no"
+ default_single_user = boot_single:lower() ~= "no"
+ default_verbose = boot_verbose:lower() ~= "no"
+
+ if boot_acpi then
+ core.setACPI(true)
+ end
+ core.setSingleUser(default_single_user)
+ core.setVerbose(default_verbose)
+end
+
+
-- Globals
-- try_include will return the loaded module on success, or nil on failure.
-- A message will also be printed on failure, with one exception: non-verbose
@@ -268,9 +292,9 @@ end
function core.setDefaults()
core.setACPI(core.getACPIPresent(true))
- core.setSafeMode(false)
- core.setSingleUser(false)
- core.setVerbose(false)
+ core.setSafeMode(default_safe_mode)
+ core.setSingleUser(default_single_user)
+ core.setVerbose(default_verbose)
end
function core.autoboot(argstr)
@@ -367,13 +391,6 @@ function core.popFrontTable(tbl)
return first_value, new_tbl
end
--- On i386, hint.acpi.0.rsdp will be set before we're loaded. On !i386, it will
--- generally be set upon execution of the kernel. Because of this, we can't (or
--- don't really want to) detect/disable ACPI on !i386 reliably. Just set it
--- enabled if we detect it and leave well enough alone if we don't.
-if core.isSystem386() and core.getACPIPresent(false) then
- core.setACPI(true)
-end
-
+recordDefaults()
hook.register("config.reloaded", core.clearCachedKernels)
return core