1
0
Fork 0

Squashed 'tmk_core/' changes from caca2c0..dc0e46e

dc0e46e Rename LUFA to LUFA-git
3bfa7fa Remove LUFA-120730
215b764 Merge commit 'afa0f22a9299686fd88f58ce09c5b521ac917e8f' as 'protocol/lufa/LUFA'
afa0f22 Squashed 'protocol/lufa/LUFA/' content from commit def7fca
c0c42fa Remove submodule of LUFA
30f897d Merge commit '87ced33feb74e79c3281dda36eb6d6d153399b41' as 'protocol/usb_hid/USB_Host_Shield_2.0'
87ced33 Squashed 'protocol/usb_hid/USB_Host_Shield_2.0/' content from commit aab4a69
14f6d49 Remove submodule of USB_Host_Shield_2.0

git-subtree-dir: tmk_core
git-subtree-split: dc0e46eaa4367d4e218f8816e3c117895820f07c
This commit is contained in:
tmk 2015-05-13 11:13:10 +09:00
parent 4d116a04e9
commit f6d56675f9
1575 changed files with 421901 additions and 63190 deletions

View file

@ -0,0 +1,99 @@
"""
LUFA Library
Copyright (C) Dean Camera, 2014.
dean [at] fourwalledcubicle [dot] com
www.lufa-lib.org
"""
"""
Front-end configuration app for the TempDataLogger project. This script
configures the logger to the current system time and date, with a user
defined logging interval.
The logging interval should be specified in milliseconds and is rounded to
a multiple of 500ms.
Usage:
python temp_log_config.py <Log_Interval>
Example:
python temp_log_config.py 500
Requires the pywinusb library (https://pypi.python.org/pypi/pywinusb/).
"""
import sys
from datetime import datetime
import pywinusb.hid as hid
# Generic HID device VID, PID and report payload length (length is increased
# by one to account for the Report ID byte that must be pre-pended)
device_vid = 0x03EB
device_pid = 0x2063
report_length = 1 + 7
def get_hid_device_handle():
hid_device_filter = hid.HidDeviceFilter(vendor_id=device_vid,
product_id=device_pid)
valid_hid_devices = hid_device_filter.get_devices()
if len(valid_hid_devices) is 0:
return None
else:
return valid_hid_devices[0]
def configure_temp_log_device(device, time_date, log_interval_500ms):
# Report data for the demo is the report ID (always zero)
report_data = [0]
# Followed by the time/date data
report_data.extend([time_date.hour, time_date.minute,
time_date.second, time_date.day,
time_date.month, time_date.year - 2000])
# Lastly the log interval in 500ms units of time
report_data.extend([log_interval_500ms])
# Zero-extend the array to the length the report should be
report_data.extend([0] * (report_length - len(report_data)))
# Send the generated report to the device
device.send_output_report(report_data)
def main(time_date, log_interval_500ms):
hid_device = get_hid_device_handle()
if hid_device is None:
print("No valid HID device found.")
sys.exit(1)
try:
hid_device.open()
print("Connected to device 0x%04X/0x%04X - %s [%s]" %
(hid_device.vendor_id, hid_device.product_id,
hid_device.product_name, hid_device.vendor_name))
configure_temp_log_device(hid_device, time_date, log_interval_500ms)
print("Time/Date is now set to %s" % time_date)
print("Log interval is now set to every %0.1fs" % (log_interval_500ms * (500.0 / 1000.0)))
finally:
hid_device.close()
if __name__ == '__main__':
time_date = datetime.now()
log_interval_500ms = (int(sys.argv[1]) / 500) if len(sys.argv) > 1 else 2
# Clamp the log interval to the allowable range
log_interval_500ms = max(log_interval_500ms, 0x01)
log_interval_500ms = min(log_interval_500ms, 0xFF)
main(time_date, log_interval_500ms)