[fsync] write fsync exit code to syslog
This commit is contained in:
parent
ecf0912ff5
commit
e80c9d17c8
1 changed files with 22 additions and 6 deletions
|
@ -38,6 +38,21 @@ local POLLIN = nixio.poll_flags('in')
|
||||||
local POLL_TIMEOUT_MS = 1000
|
local POLL_TIMEOUT_MS = 1000
|
||||||
local MAX_TRIES = 5
|
local MAX_TRIES = 5
|
||||||
|
|
||||||
|
local function exit(code)
|
||||||
|
nixio.openlog('fsync', 'pid')
|
||||||
|
|
||||||
|
local level
|
||||||
|
|
||||||
|
if code == 0 then
|
||||||
|
level = 'info'
|
||||||
|
else
|
||||||
|
level = 'err'
|
||||||
|
end
|
||||||
|
|
||||||
|
nixio.syslog(level, string.format('fync exited with code: %d', code))
|
||||||
|
os.exit(code)
|
||||||
|
end
|
||||||
|
|
||||||
local ctrl = { fdin = nixio.open(CTRL_PATH_IN, O_RDWR_NONBLOCK),
|
local ctrl = { fdin = nixio.open(CTRL_PATH_IN, O_RDWR_NONBLOCK),
|
||||||
fdout = nixio.open(CTRL_PATH_OUT, O_RDWR_NONBLOCK),
|
fdout = nixio.open(CTRL_PATH_OUT, O_RDWR_NONBLOCK),
|
||||||
events = POLLIN,
|
events = POLLIN,
|
||||||
|
@ -46,14 +61,14 @@ local ctrl = { fdin = nixio.open(CTRL_PATH_IN, O_RDWR_NONBLOCK),
|
||||||
if ctrl.fdin == nil or ctrl.fdout == nil then
|
if ctrl.fdin == nil or ctrl.fdout == nil then
|
||||||
print('Error. Unable to open the ctrl fifos.')
|
print('Error. Unable to open the ctrl fifos.')
|
||||||
print('Exiting...')
|
print('Exiting...')
|
||||||
os.exit(1)
|
exit(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- acquire an exclusive lock on the ctrl fifos or exit
|
-- acquire an exclusive lock on the ctrl fifos or exit
|
||||||
if not (ctrl.fdin:lock('tlock') and ctrl.fdout:lock('tlock')) then
|
if not (ctrl.fdin:lock('tlock') and ctrl.fdout:lock('tlock')) then
|
||||||
print('Error. Detected a lock on one of the ctrl fifos.')
|
print('Error. Detected a lock on one of the ctrl fifos.')
|
||||||
print('Exiting...')
|
print('Exiting...')
|
||||||
os.exit(1)
|
exit(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
ctrl.fd = ctrl.fdout -- need this entry for nixio.poll
|
ctrl.fd = ctrl.fdout -- need this entry for nixio.poll
|
||||||
|
@ -94,7 +109,7 @@ local function send(ctrl, cmd)
|
||||||
end
|
end
|
||||||
|
|
||||||
print(MAX_TRIES .. ' write attempts failed. Exiting ...')
|
print(MAX_TRIES .. ' write attempts failed. Exiting ...')
|
||||||
os.exit(2)
|
exit(2)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function toc(num)
|
local function toc(num)
|
||||||
|
@ -140,7 +155,7 @@ if hw_major ~= flukso.main.hw_major or hw_minor > flukso.main.hw_minor then
|
||||||
print('Overridden. Good luck!')
|
print('Overridden. Good luck!')
|
||||||
else
|
else
|
||||||
print('Use -f to override this check at your own peril.')
|
print('Use -f to override this check at your own peril.')
|
||||||
os.exit(3)
|
exit(3)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
print(string.format('Hardware check (major: %s, minor: %s) .. ok', hw_major, hw_minor))
|
print(string.format('Hardware check (major: %s, minor: %s) .. ok', hw_major, hw_minor))
|
||||||
|
@ -159,7 +174,7 @@ for i = 1, MAX_SENSORS do
|
||||||
if flukso[tostring(i)] ~= nil then
|
if flukso[tostring(i)] ~= nil then
|
||||||
if flukso[tostring(i)]['class'] == 'analog' and i > MAX_ANALOG_SENSORS then
|
if flukso[tostring(i)]['class'] == 'analog' and i > MAX_ANALOG_SENSORS then
|
||||||
print(string.format('Error. Analog sensor %s should be less than or equal to max_analog_sensors (%s)', i, MAX_ANALOG_SENSORS))
|
print(string.format('Error. Analog sensor %s should be less than or equal to max_analog_sensors (%s)', i, MAX_ANALOG_SENSORS))
|
||||||
os.exit(4)
|
exit(4)
|
||||||
end
|
end
|
||||||
|
|
||||||
local ports = flukso[tostring(i)].port or {}
|
local ports = flukso[tostring(i)].port or {}
|
||||||
|
@ -167,7 +182,7 @@ for i = 1, MAX_SENSORS do
|
||||||
for j = 1, #ports do
|
for j = 1, #ports do
|
||||||
if tonumber(ports[j]) > MAX_SENSORS then
|
if tonumber(ports[j]) > MAX_SENSORS then
|
||||||
print(string.format('Error. Port numbering in sensor %s should be less than or equal to max_sensors (%s)', i, MAX_SENSORS))
|
print(string.format('Error. Port numbering in sensor %s should be less than or equal to max_sensors (%s)', i, MAX_SENSORS))
|
||||||
os.exit(5)
|
exit(5)
|
||||||
|
|
||||||
else
|
else
|
||||||
phy_to_log[toc(tonumber(ports[j]))] = toc(i)
|
phy_to_log[toc(tonumber(ports[j]))] = toc(i)
|
||||||
|
@ -297,3 +312,4 @@ for i = 1, #avahi.tail do
|
||||||
end
|
end
|
||||||
|
|
||||||
print(arg[0] .. ' completed successfully. Bye!')
|
print(arg[0] .. ' completed successfully. Bye!')
|
||||||
|
exit(0)
|
||||||
|
|
Loading…
Reference in a new issue