Quiero hacer un rastreador de bus CAN para 250 kbit/s usando mi computadora. Después de algunas investigaciones, descubrí que MCP2551 es una especie de regulador de nivel de voltaje para la capa física de CAN. Teniendo eso en cuenta, me pregunto si esta configuración podría funcionar. Solo quiero registrar los mensajes intercambiados con fines de prueba automatizados, no ser parte de la comunicación:
PC <-> USB-UART (quizás CP2102, porque ya tengo uno) <-> MCP2551 <-> bus CAN
Si no, ¿qué tipo de señales debo ingresar al MCP2551 para que sea parte del bus?
Puede hacer eso, pero lo que obtendrá en su bus CAN será UART usando niveles de voltaje CAN. Debe proporcionar al MCP2551 mensajes de protocolo CAN si desea comunicarse con dispositivos CAN en su bus. Lo mismo para escuchar: los mensajes CAN son tan diferentes del formato UART que UART no sabrá qué hacer con ellos. Tendrá al menos errores de marco todo el tiempo y no obtendrá el contenido del mensaje.
Esta imagen muestra la estructura de un mensaje CAN:
Hay muchos microcontroladores que tienen una interfaz CAN, sin el transceptor. Es para esto que se diseñó el MCP2551. En el pasado, usamos el NXP LPC2294, que tiene 4 interfaces CAN. Cada uno de ellos necesita un MCP2551 para conectarse a un bus CAN. Los controladores más recientes de NXP incluyen la familia LPC1800 , de la cual todos los miembros son compatibles con CAN.
Hice una interfaz USB/CAN usando FT2232H en modo MPSSE (olvídese de UART), MCP2515 y MCP2551. MCP2515 es la pieza clave que te falta aquí. Estudia bien lo que hace. Es el controlador CAN real el que realiza el encuadre, los ACK, la generación y verificación de la suma de comprobación, el filtrado de mensajes y otras cosas menos obvias que el estándar requiere que haga un nodo CAN. Si desea un rastreador, MCP2515 tiene un modo de solo escucha que garantiza que no haya transmisiones en el bus. MCP2551 es simplemente un adaptador de capa física tonto, similar a un MAX232 para RS-232 o ADM485 para RS-485.
Ahora, esta arquitectura está lejos de ser perfecta, ya que la tecnología FTDI MPSSE esencialmente no admite interrupciones (creo que solo usa transferencias USB masivas detrás de escena), por lo que tengo que sondear el controlador con frecuencia en busca de nuevos mensajes. Esto genera mucha carga en el controlador de host USB, pero aún no garantiza que no se pierdan mensajes (MCP2515 puede almacenar hasta 2 mensajes recibidos internamente si habilita el "modo de desbordamiento", solo uno si no lo hace). Una solución mucho mejor sería un microcontrolador adecuado con periféricos CAN y USB incorporados como STM32F105 (103 no puede usar USB y CAN al mismo tiempo). Vea este proyecto para una implementación funcional de exactamente esta idea. LPC18xx como lo sugirió stevenh también funcionará, pero LPC17xx probablemente sea más barato y más fácil de encontrar.
Dado que desea escuchar en un bus CAN existente según entiendo la pregunta, realmente no puede usar un UART en absoluto. CAN y UART siganlling son totalmente diferentes.
En teoría, podría mirar la línea de recepción CAN que sale del MCP2551 y decodificar el tráfico CAN. Eso no será fácil, pero es teóricamente posible. Sin hardware CAN especializado, tendrá que muestrear varias veces más rápido que la tasa de bits CAN y decodificar ese flujo de bits en el software más tarde. Probablemente necesitará grabar a aproximadamente 1 Mbit/s para decodificar CAN de 250 kbit/s.
Usar un microcontrolador será mucho más fácil. El PIC 18F2580 y otros procesadores similares tienen un periférico CAN incorporado. El hardware realiza toda la decodificación a nivel de bits y recibe tramas CAN completas. Luego, el procesador puede enviar tramas CAN recibidas a través de su UART a su PC.
runas
stevenvh
runas
runas
stevenvh
olin lathrop
runas
stevenvh
olin lathrop