[fluksod + fsync] acquire a write lock on the delta and ctrl fifos when in use
This commit is contained in:
parent
350a373b72
commit
f6f6fd3d6e
2 changed files with 15 additions and 6 deletions
|
@ -32,6 +32,8 @@ local data = require 'flukso.data'
|
||||||
local arg = arg or {} -- needed when this code is not loaded via the interpreter
|
local arg = arg or {} -- needed when this code is not loaded via the interpreter
|
||||||
|
|
||||||
local DEBUG = (arg[1] == '-d')
|
local DEBUG = (arg[1] == '-d')
|
||||||
|
local LOGMASK = 'debug'
|
||||||
|
nixio.setlogmask(LOGMASK)
|
||||||
|
|
||||||
local DAEMON = os.getenv('DAEMON') or 'fluksod'
|
local DAEMON = os.getenv('DAEMON') or 'fluksod'
|
||||||
local DAEMON_PATH = os.getenv('DAEMON_PATH') or '/var/run/' .. DAEMON
|
local DAEMON_PATH = os.getenv('DAEMON_PATH') or '/var/run/' .. DAEMON
|
||||||
|
@ -83,13 +85,15 @@ function dispatch(wan_child, lan_child)
|
||||||
fdout = nixio.open(DELTA_PATH_OUT, O_RDWR) }
|
fdout = nixio.open(DELTA_PATH_OUT, O_RDWR) }
|
||||||
|
|
||||||
if delta.fdin == nil or delta.fdout == nil then
|
if delta.fdin == nil or delta.fdout == nil then
|
||||||
-- TODO output to syslog
|
nixio.syslog('alert', 'cannot open the delta fifos')
|
||||||
print('Error. Unable to open the delta fifos.')
|
|
||||||
print('Exiting...')
|
|
||||||
os.exit(1)
|
os.exit(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- TODO acquire an exclusive lock on the delta fifos or exit
|
-- acquire an exclusive lock on the delta fifos or exit
|
||||||
|
if not (delta.fdin:lock('tlock') and delta.fdout:lock('tlock')) then
|
||||||
|
nixio.syslog('alert', 'detected a lock on the delta fifos')
|
||||||
|
os.exit(2)
|
||||||
|
end
|
||||||
|
|
||||||
local function tolua(num)
|
local function tolua(num)
|
||||||
return num + 1
|
return num + 1
|
||||||
|
|
|
@ -49,11 +49,16 @@ if ctrl.fdin == nil or ctrl.fdout == nil then
|
||||||
os.exit(1)
|
os.exit(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- acquire an exclusive lock on the ctrl fifos or exit
|
||||||
|
if not (ctrl.fdin:lock('tlock') and ctrl.fdout:lock('tlock')) then
|
||||||
|
print('Error. Detected a lock on one of the ctrl fifos.')
|
||||||
|
print('Exiting...')
|
||||||
|
os.exit(1)
|
||||||
|
end
|
||||||
|
|
||||||
ctrl.fd = ctrl.fdout -- need this entry for nixio.poll
|
ctrl.fd = ctrl.fdout -- need this entry for nixio.poll
|
||||||
ctrl.line = ctrl.fdout:linesource()
|
ctrl.line = ctrl.fdout:linesource()
|
||||||
|
|
||||||
-- TODO acquire an exclusive lock on the ctrl fifos or exit
|
|
||||||
|
|
||||||
|
|
||||||
local function send(ctrl, cmd)
|
local function send(ctrl, cmd)
|
||||||
while ctrl.line() do end -- flush the out fifo
|
while ctrl.line() do end -- flush the out fifo
|
||||||
|
|
Loading…
Reference in a new issue