Difference between revisions of "CanServo/Protocol/V1.1"
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| Line 5: | Line 5: | ||
* This protocol needs FW Ver 1.12+  | * This protocol needs FW Ver 1.12+  | ||
*   | * The purpose of this message is to set the servo's ID based on the servo's UID.  | ||
* CAN ID  | * CAN ID  | ||
Revision as of 06:36, 11 June 2024
Under construction
CAN Protocol Ver 1.1
- This protocol needs FW Ver 1.12+
 
- The purpose of this message is to set the servo's ID based on the servo's UID.
 
- CAN ID
- 0x7FF : Servo -> Host
 - 0x7FE : Host -> Servo
 
 
- Message : Servo -> Host
- ZUID, <UID : 16 byte>, <ID2 : 4 byte>, <ID1 : 1 byte>, <CAN Mode : 1 byte>
 
 
- Message: Host -> Servo
- ZIDS, <UID : 16 byte>, <ID2 : 4 byte>
 - ZIDS, <UID : 16 byte>, <ID2 : 4 byte>, <ID1 : 1 byte>
 - ZIDS, <UID : 16 byte>, <ID2 : 4 byte>, <ID1 : 1 byte>, <CAN Mode : 1 byte>
 
 
- This message is delivered using the MultiPacket method below.
 
MultiPacket for Long Message
- The first step is to calculate the CRC16 of the message and add it to the end to create the content to be sent.
 - Send (maximum) 7 bytes extracted from the content to be sent and a Check Byte.
 
- Multi Packet's Data Format
- < Data : max 7 byte, cut from 'Message + CRC16' >, <Check Byte>
 - Check Byte
- bit 7 = 1, if first packet
 - bit 6 = 1, if last packet
 - bit 5 = Toggle, first packet = 1, toggle bit on each packet
 - bit 4:0 = Seq, 0 ~ 31, inc 1 on each message
 
 
 
- Note:
- ID2, CRC16 : byte order : low byte first, little endian
 
 
- Reference:
 
FD-CAN
- FD-CAN allows up to 64 bytes to be transmitted, so up to 63 bytes can be extracted at a time.
 
- This approach has not yet been implemented.