[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 DEBUG = (arg[1] == '-d')
|
||||
local LOGMASK = 'debug'
|
||||
nixio.setlogmask(LOGMASK)
|
||||
|
||||
local DAEMON = os.getenv('DAEMON') or 'fluksod'
|
||||
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) }
|
||||
|
||||
if delta.fdin == nil or delta.fdout == nil then
|
||||
-- TODO output to syslog
|
||||
print('Error. Unable to open the delta fifos.')
|
||||
print('Exiting...')
|
||||
nixio.syslog('alert', 'cannot open the delta fifos')
|
||||
os.exit(1)
|
||||
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)
|
||||
return num + 1
|
||||
|
|
|
@ -49,11 +49,16 @@ if ctrl.fdin == nil or ctrl.fdout == nil then
|
|||
os.exit(1)
|
||||
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.line = ctrl.fdout:linesource()
|
||||
|
||||
-- TODO acquire an exclusive lock on the ctrl fifos or exit
|
||||
|
||||
|
||||
local function send(ctrl, cmd)
|
||||
while ctrl.line() do end -- flush the out fifo
|
||||
|
|
Loading…
Reference in a new issue