Laurent@2086: import subprocess,sys,ctypes Laurent@2086: from threading import Thread Edouard@2114: import ctypes,time,re Laurent@2086: Laurent@2086: SDOAnswered = PLCBinary.SDOAnswered Laurent@2086: SDOAnswered.restype = None Laurent@2086: SDOAnswered.argtypes = [] Laurent@2086: Laurent@2086: SDOThread = None Laurent@2086: Result = None Laurent@2086: Laurent@2086: def SDOThreadProc(*params): Laurent@2086: global Result Laurent@2086: if params[0] == "upload": Laurent@2086: command = "ethercat upload -p %d -t %s 0x%.4x 0x%.2x" Laurent@2086: else: Laurent@2086: command = "ethercat download -p %d -t %s 0x%.4x 0x%.2x %s" Laurent@2086: Laurent@2086: proc = subprocess.Popen(command % params[1:], stdout=subprocess.PIPE, shell=True) Laurent@2086: res = proc.wait() Laurent@2086: output = proc.communicate()[0] Laurent@2086: Laurent@2086: if params[0] == "upload": Laurent@2086: Result = None Laurent@2086: if res == 0: Laurent@2086: if params[2] in ["float", "double"]: Laurent@2086: Result = float(output) Laurent@2086: elif params[2] in ["string", "octet_string", "unicode_string"]: Laurent@2086: Result = output Laurent@2086: else: Laurent@2086: hex_value, dec_value = output.split() Laurent@2086: if int(hex_value, 16) == int(dec_value): Laurent@2086: Result = int(dec_value) Laurent@2086: else: Laurent@2086: Result = res == 0 Laurent@2086: Laurent@2086: SDOAnswered() Laurent@2086: Laurent@2086: def EthercatSDOUpload(pos, index, subindex, var_type): Laurent@2086: global SDOThread Laurent@2086: SDOThread = Thread(target=SDOThreadProc, args=["upload", pos, var_type, index, subindex]) Laurent@2086: SDOThread.start() Laurent@2086: Laurent@2086: def EthercatSDODownload(pos, index, subindex, var_type, value): Laurent@2086: global SDOThread Laurent@2086: SDOThread = Thread(target=SDOThreadProc, args=["download", pos, var_type, index, subindex, value]) Laurent@2086: SDOThread.start() Laurent@2086: Laurent@2086: def GetResult(): Laurent@2086: global Result Laurent@2086: return Result Edouard@2114: Edouard@2114: KMSGPollThread=None Edouard@2114: StopKMSGThread=False Edouard@2114: def KMSGPollThreadProc(): Edouard@2114: """ Edouard@2114: Logs Kernel messages starting with EtherCAT Edouard@2114: Uses GLibc wrapper to Linux syscall "klogctl" Edouard@2114: Last 4 KB are polled, and lines compared to last Edouard@2114: captured line to detect new lines Edouard@2114: """ Edouard@2114: global StopKMSGThread Edouard@2114: libc=ctypes.CDLL("libc.so.6") Edouard@2114: klog = libc.klogctl Edouard@2114: klog.argtypes = [ctypes.c_int, ctypes.c_char_p, ctypes.c_int] Edouard@2114: klog.restype = ctypes.c_int Edouard@2114: s=ctypes.create_string_buffer(4*1024) Edouard@2114: last = None Edouard@2114: while not StopKMSGThread: Edouard@2114: l = klog(3,s,len(s)-1) Edouard@2114: log = s.value[:l-1] Edouard@2114: if last : Edouard@2114: log = log.rpartition(last)[2] Edouard@2114: if log : Edouard@2114: last = log.rpartition('\n')[2] Edouard@2114: for msg in re.findall(r'<\d>\[\s*\d*\.\d*\]\s*(EtherCAT\s*.*)$', Edouard@2114: log, re.MULTILINE): Edouard@2114: PLCObject.LogMessage(msg) Edouard@2114: time.sleep(0.5) Edouard@2114: Edouard@2114: def _runtime_etherlab_init(): Edouard@2114: global KMSGPollThread, StopKMSGThread Edouard@2114: StopKMSGThread = False Edouard@2114: KMSGPollThread = Thread(target = KMSGPollThreadProc) Edouard@2114: KMSGPollThread.start() Edouard@2114: Edouard@2114: def _runtime_etherlab_cleanup(): Edouard@2114: global KMSGPollThread, StopKMSGThread Edouard@2114: StopKMSGThread = True Edouard@2114: KMSGPollThread = None Edouard@2114: Edouard@2114: