2014-10-05 16:25:31 +08:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import asyncio
|
2014-10-25 11:34:52 +08:00
|
|
|
import argparse
|
2014-12-31 17:41:22 +08:00
|
|
|
import atexit
|
2015-02-03 22:06:45 +08:00
|
|
|
import os
|
2014-10-05 16:25:31 +08:00
|
|
|
|
2015-01-17 19:38:20 +08:00
|
|
|
from artiq.protocols.pc_rpc import Server
|
2015-07-14 04:08:20 +08:00
|
|
|
from artiq.protocols.sync_struct import Notifier, Publisher, process_mod
|
2015-07-09 19:54:38 +08:00
|
|
|
from artiq.protocols.file_db import FlatFileDB
|
2015-01-14 12:16:49 +08:00
|
|
|
from artiq.master.scheduler import Scheduler
|
2015-07-14 04:08:20 +08:00
|
|
|
from artiq.master.worker_db import get_last_rid
|
2015-01-26 23:37:33 +08:00
|
|
|
from artiq.master.repository import Repository
|
2015-01-28 21:44:15 +08:00
|
|
|
from artiq.tools import verbosity_args, init_logger
|
2014-10-05 16:25:31 +08:00
|
|
|
|
|
|
|
|
2015-01-23 00:52:13 +08:00
|
|
|
def get_argparser():
|
2014-12-08 19:22:02 +08:00
|
|
|
parser = argparse.ArgumentParser(description="ARTIQ master")
|
2015-02-16 05:55:43 +08:00
|
|
|
group = parser.add_argument_group("network")
|
|
|
|
group.add_argument(
|
2014-10-25 11:34:52 +08:00
|
|
|
"--bind", default="::1",
|
|
|
|
help="hostname or IP address to bind to")
|
2015-02-16 05:55:43 +08:00
|
|
|
group.add_argument(
|
2015-01-13 03:55:50 +08:00
|
|
|
"--port-notify", default=3250, type=int,
|
2015-03-24 03:02:14 +08:00
|
|
|
help="TCP port to listen to for notifications (default: %(default)d)")
|
2015-02-16 05:55:43 +08:00
|
|
|
group.add_argument(
|
2015-01-13 03:55:50 +08:00
|
|
|
"--port-control", default=3251, type=int,
|
2015-03-24 03:02:14 +08:00
|
|
|
help="TCP port to listen to for control (default: %(default)d)")
|
2015-01-28 21:44:15 +08:00
|
|
|
verbosity_args(parser)
|
2015-01-23 00:52:13 +08:00
|
|
|
return parser
|
2014-10-25 11:34:52 +08:00
|
|
|
|
|
|
|
|
2015-07-22 05:13:50 +08:00
|
|
|
class Log:
|
|
|
|
def __init__(self, depth):
|
|
|
|
self.depth = depth
|
|
|
|
self.data = Notifier([])
|
|
|
|
|
|
|
|
def log(self, rid, message):
|
|
|
|
if len(self.data.read) >= self.depth:
|
|
|
|
del self.data[0]
|
|
|
|
self.data.append((rid, message))
|
|
|
|
log.worker_pass_rid = True
|
|
|
|
|
|
|
|
|
2014-10-05 16:25:31 +08:00
|
|
|
def main():
|
2015-01-23 00:52:13 +08:00
|
|
|
args = get_argparser().parse_args()
|
2015-01-28 21:44:15 +08:00
|
|
|
init_logger(args)
|
2015-02-04 14:44:39 +08:00
|
|
|
if os.name == "nt":
|
2015-02-03 22:06:45 +08:00
|
|
|
loop = asyncio.ProactorEventLoop()
|
|
|
|
asyncio.set_event_loop(loop)
|
|
|
|
else:
|
|
|
|
loop = asyncio.get_event_loop()
|
2014-12-31 17:41:22 +08:00
|
|
|
atexit.register(lambda: loop.close())
|
|
|
|
|
2015-07-22 05:13:50 +08:00
|
|
|
ddb = FlatFileDB("ddb.pyon")
|
|
|
|
pdb = FlatFileDB("pdb.pyon")
|
|
|
|
rtr = Notifier(dict())
|
|
|
|
log = Log(1000)
|
|
|
|
|
2015-05-17 16:11:00 +08:00
|
|
|
worker_handlers = {
|
2015-07-14 04:08:20 +08:00
|
|
|
"get_device": ddb.get,
|
|
|
|
"get_parameter": pdb.get,
|
2015-01-13 19:12:19 +08:00
|
|
|
"set_parameter": pdb.set,
|
2015-07-14 04:08:20 +08:00
|
|
|
"update_rt_results": lambda mod: process_mod(rtr, mod),
|
2015-07-22 05:13:50 +08:00
|
|
|
"log": log.log
|
2015-02-20 03:09:11 +08:00
|
|
|
}
|
2015-05-17 16:11:00 +08:00
|
|
|
scheduler = Scheduler(get_last_rid() + 1, worker_handlers)
|
|
|
|
worker_handlers["scheduler_submit"] = scheduler.submit
|
2015-03-09 23:22:41 +08:00
|
|
|
scheduler.start()
|
2014-12-31 17:41:22 +08:00
|
|
|
atexit.register(lambda: loop.run_until_complete(scheduler.stop()))
|
|
|
|
|
2015-07-23 23:06:15 +08:00
|
|
|
repository = Repository(log.log)
|
2015-07-18 00:55:48 +08:00
|
|
|
repository.scan_async()
|
|
|
|
|
2014-12-31 20:13:10 +08:00
|
|
|
server_control = Server({
|
2015-01-12 18:51:23 +08:00
|
|
|
"master_ddb": ddb,
|
2015-01-26 23:37:33 +08:00
|
|
|
"master_pdb": pdb,
|
|
|
|
"master_schedule": scheduler,
|
2015-07-18 00:55:48 +08:00
|
|
|
"master_repository": repository
|
2014-12-31 20:13:10 +08:00
|
|
|
})
|
|
|
|
loop.run_until_complete(server_control.start(
|
|
|
|
args.bind, args.port_control))
|
|
|
|
atexit.register(lambda: loop.run_until_complete(server_control.stop()))
|
2014-12-31 17:41:22 +08:00
|
|
|
|
2014-12-31 20:13:10 +08:00
|
|
|
server_notify = Publisher({
|
2015-05-17 16:11:00 +08:00
|
|
|
"schedule": scheduler.notifier,
|
2015-01-12 18:51:23 +08:00
|
|
|
"devices": ddb.data,
|
|
|
|
"parameters": pdb.data,
|
2015-07-14 04:08:20 +08:00
|
|
|
"rt_results": rtr,
|
2015-07-22 05:13:50 +08:00
|
|
|
"explist": repository.explist,
|
|
|
|
"log": log.data
|
2014-12-31 17:41:22 +08:00
|
|
|
})
|
2014-12-31 20:13:10 +08:00
|
|
|
loop.run_until_complete(server_notify.start(
|
|
|
|
args.bind, args.port_notify))
|
|
|
|
atexit.register(lambda: loop.run_until_complete(server_notify.stop()))
|
2014-12-31 17:41:22 +08:00
|
|
|
|
|
|
|
loop.run_forever()
|
2014-10-05 16:25:31 +08:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|