tmc2208: Separate low-level bit-banging code from MCU_TMC_uart class
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
47901e57c9
commit
88fe2787a9
|
@ -182,16 +182,10 @@ FieldFormatters.update({
|
||||||
# TMC2208 uart communication
|
# TMC2208 uart communication
|
||||||
######################################################################
|
######################################################################
|
||||||
|
|
||||||
# Helper code for communicating via TMC uart
|
# Code for sending messages on a TMC uart
|
||||||
class MCU_TMC_uart:
|
class MCU_TMC_uart_bitbang:
|
||||||
def __init__(self, config, name_to_reg, fields):
|
def __init__(self, config):
|
||||||
self.printer = config.get_printer()
|
ppins = config.get_printer().lookup_object("pins")
|
||||||
self.name = config.get_name().split()[-1]
|
|
||||||
self.name_to_reg = name_to_reg
|
|
||||||
self.fields = fields
|
|
||||||
self.ifcnt = None
|
|
||||||
# pin setup
|
|
||||||
ppins = self.printer.lookup_object("pins")
|
|
||||||
rx_pin_params = ppins.lookup_pin(
|
rx_pin_params = ppins.lookup_pin(
|
||||||
config.get('uart_pin'), can_pullup=True)
|
config.get('uart_pin'), can_pullup=True)
|
||||||
tx_pin_desc = config.get('tx_pin', None)
|
tx_pin_desc = config.get('tx_pin', None)
|
||||||
|
@ -200,7 +194,7 @@ class MCU_TMC_uart:
|
||||||
else:
|
else:
|
||||||
tx_pin_params = ppins.lookup_pin(tx_pin_desc)
|
tx_pin_params = ppins.lookup_pin(tx_pin_desc)
|
||||||
if rx_pin_params['chip'] is not tx_pin_params['chip']:
|
if rx_pin_params['chip'] is not tx_pin_params['chip']:
|
||||||
raise ppins.error("TMC2208 rx and tx pins must be on the same mcu")
|
raise ppins.error("TMC uart rx and tx pins must be on the same mcu")
|
||||||
self.mcu = rx_pin_params['chip']
|
self.mcu = rx_pin_params['chip']
|
||||||
self.pullup = rx_pin_params['pullup']
|
self.pullup = rx_pin_params['pullup']
|
||||||
self.rx_pin = rx_pin_params['pin']
|
self.rx_pin = rx_pin_params['pin']
|
||||||
|
@ -216,8 +210,6 @@ class MCU_TMC_uart:
|
||||||
cmd_queue = self.mcu.alloc_command_queue()
|
cmd_queue = self.mcu.alloc_command_queue()
|
||||||
self.tmcuart_send_cmd = self.mcu.lookup_command(
|
self.tmcuart_send_cmd = self.mcu.lookup_command(
|
||||||
"tmcuart_send oid=%c write=%*s read=%c", cq=cmd_queue)
|
"tmcuart_send oid=%c write=%*s read=%c", cq=cmd_queue)
|
||||||
def get_fields(self):
|
|
||||||
return self.fields
|
|
||||||
def _calc_crc8(self, data):
|
def _calc_crc8(self, data):
|
||||||
# Generate a CRC8-ATM value for a bytearray
|
# Generate a CRC8-ATM value for a bytearray
|
||||||
crc = 0
|
crc = 0
|
||||||
|
@ -270,30 +262,46 @@ class MCU_TMC_uart:
|
||||||
if data != encoded_data:
|
if data != encoded_data:
|
||||||
return None
|
return None
|
||||||
return val
|
return val
|
||||||
|
def reg_read(self, addr, reg):
|
||||||
|
msg = self._encode_read(0xf5, addr, reg)
|
||||||
|
params = self.tmcuart_send_cmd.send_with_response(
|
||||||
|
[self.oid, msg, 10], 'tmcuart_response', self.oid)
|
||||||
|
return self._decode_read(reg, params['read'])
|
||||||
|
def reg_write(self, addr, reg, val):
|
||||||
|
msg = self._encode_write(0xf5, 0x00, reg | 0x80, val)
|
||||||
|
self.tmcuart_send_cmd.send_with_response(
|
||||||
|
[self.oid, msg, 0], 'tmcuart_response', self.oid)
|
||||||
|
|
||||||
|
# Helper code for communicating via TMC uart
|
||||||
|
class MCU_TMC_uart:
|
||||||
|
def __init__(self, config, name_to_reg, fields):
|
||||||
|
self.printer = config.get_printer()
|
||||||
|
self.name = config.get_name().split()[-1]
|
||||||
|
self.name_to_reg = name_to_reg
|
||||||
|
self.fields = fields
|
||||||
|
self.ifcnt = None
|
||||||
|
self.mcu_uart = MCU_TMC_uart_bitbang(config)
|
||||||
|
def get_fields(self):
|
||||||
|
return self.fields
|
||||||
def get_register(self, reg_name):
|
def get_register(self, reg_name):
|
||||||
reg = self.name_to_reg[reg_name]
|
reg = self.name_to_reg[reg_name]
|
||||||
msg = self._encode_read(0xf5, 0x00, reg)
|
|
||||||
if self.printer.get_start_args().get('debugoutput') is not None:
|
if self.printer.get_start_args().get('debugoutput') is not None:
|
||||||
return 0
|
return 0
|
||||||
for retry in range(5):
|
for retry in range(5):
|
||||||
params = self.tmcuart_send_cmd.send_with_response(
|
val = self.mcu_uart.reg_read(0x00, reg)
|
||||||
[self.oid, msg, 10], 'tmcuart_response', self.oid)
|
|
||||||
val = self._decode_read(reg, params['read'])
|
|
||||||
if val is not None:
|
if val is not None:
|
||||||
return val
|
return val
|
||||||
raise self.printer.command_error(
|
raise self.printer.command_error(
|
||||||
"Unable to read tmc2208 '%s' register %s" % (self.name, reg_name))
|
"Unable to read tmc2208 '%s' register %s" % (self.name, reg_name))
|
||||||
def set_register(self, reg_name, val, print_time=0.):
|
def set_register(self, reg_name, val, print_time=0.):
|
||||||
msg = self._encode_write(0xf5, 0x00,
|
reg = self.name_to_reg[reg_name]
|
||||||
self.name_to_reg[reg_name] | 0x80, val)
|
|
||||||
if self.printer.get_start_args().get('debugoutput') is not None:
|
if self.printer.get_start_args().get('debugoutput') is not None:
|
||||||
return
|
return
|
||||||
for retry in range(5):
|
for retry in range(5):
|
||||||
ifcnt = self.ifcnt
|
ifcnt = self.ifcnt
|
||||||
if ifcnt is None:
|
if ifcnt is None:
|
||||||
self.ifcnt = ifcnt = self.get_register("IFCNT")
|
self.ifcnt = ifcnt = self.get_register("IFCNT")
|
||||||
params = self.tmcuart_send_cmd.send_with_response(
|
self.mcu_uart.reg_write(0x00, reg, val)
|
||||||
[self.oid, msg, 0], 'tmcuart_response', self.oid)
|
|
||||||
self.ifcnt = self.get_register("IFCNT")
|
self.ifcnt = self.get_register("IFCNT")
|
||||||
if self.ifcnt == (ifcnt + 1) & 0xff:
|
if self.ifcnt == (ifcnt + 1) & 0xff:
|
||||||
return
|
return
|
||||||
|
|
Loading…
Reference in New Issue