Quisiera saber si existe alguna forma de programar un PIC por primera vez (escribir en Flash) a través de una tarjeta FPGA.
El PIC ya está soldado a la FPGA y no puedo quitarlo. No existe ningún gestor de arranque en el PIC. Por lo tanto, necesito programarlo en modo USART / SPI / I2C con un gestor de arranque para que pueda recibir datos de la FPGA.
Sé que normalmente tengo que desoldarlo, conectarlo a un programador de hardware como PICKit y programarlo con un software en la computadora como MPLAB, pero no puedo pagar eso.
Puedo generar el gestor de arranque con MPLAB, que es un archivo .hex, pero ¿cómo puedo transferirlo a la FPGA y luego a la PIC a través de los pines de la FPGA?
El PIC utilizado es Microchip PIC12F1822.
No, no necesita, de hecho no puede, usar SPI, UART o I 2 C para programar el PIC. La única forma de introducir un nuevo programa en un PIC que no tenga un código especial cargado para ese fin (un gestor de arranque) es utilizar la interfaz de programación de hardware externa. Eléctricamente, esto significa conectarse a Vss, MCLR, PGC y PGD. Puede ser útil tener el programador también conectado a Vdd, pero no es necesario para este chip siempre que se conozca el nivel de Vdd y el programador se ajuste en consecuencia.
La interfaz de hardware de bajo nivel es bastante simple. PGD es la línea de datos, que es muestreada por el PIC en el flanco descendente de PGC (la línea de reloj). Para poner el PIC en el modo de programación en primer lugar, se registra una clave especial de 32 bits en relación con los bordes específicos en MCLR (aunque vea la nota a continuación con respecto a la programación de alto voltaje).
El protocolo de nivel superior se vuelve más complicado. La mayoría de las cosas se hacen con comandos de 6 bits, algunos de los cuales van seguidos de palabras de datos de 14 bits. Tienes que leer las especificaciones de programación cuidadosamente. Tenga en cuenta que la especificación de programación es un documento separado de la hoja de datos. Vaya a la página del producto para su PIC particular en el sitio web de Microchip y encontrará un enlace a la especificación de programación en la sección de documentos.
Estos tipos de PIC tienen dos formas de ingresar al modo de programación, alto voltaje (HVP) y bajo voltaje (LVP). El método de alto voltaje requiere elevar el MCLR entre 8 y 9 voltios y mantenerlo allí durante la programación. Este método siempre funciona, independientemente de cualquier dato posible programado en el PIC.
El método de bajo voltaje para ingresar al modo de programación comienza con la activación de MCLR alto, luego bajo, luego marcando una secuencia de teclas especial de 32 bits usando PGC y PGD normalmente. La pieza entrará en el modo de programación con la secuencia de teclas correcta y permanecerá en el modo de programación mientras el MCLR se mantenga bajo.
El método de bajo voltaje se puede desactivar mediante uno de los bits de configuración. Sin embargo, el estado borrado del bit de configuración permite la programación de bajo voltaje, se envía de fábrica de esa manera, y este bit de configuración solo se puede configurar para no permitir LVP si se ingresó a la programación con el método de alto voltaje. Por lo tanto, para que LVP no esté habilitado, todo lo siguiente debe ser cierto:
Dado que deshabilitar LVP requiere una acción deliberada y el programador adecuado, es probable que aún esté habilitado. Si se deshabilitó deliberadamente por alguna extraña razón, debe suministrar 8-9 V en MCLR para que el PIC entre en modo de programación al menos el tiempo suficiente para realizar un borrado masivo (que vuelve a habilitar LVP).
La programación de un PIC requiere un alto voltaje. Sí, es posible cambiar un PIC a "LVP", o modo de programación de bajo voltaje, pero necesita un programador de alto voltaje para hacerlo.
Si su PIC ya se ha puesto en modo LVP, entonces sí, puede programar fácilmente el PIC desde el FPGA. Todas las hojas de datos contienen las formas de onda de programación necesarias para programar el chip, por lo que sería un caso de construir su propio dispositivo de programador PIC en el FPGA.
Sin embargo, si el PIC no se ha puesto en modo LVP, deberá generar un alto voltaje (generalmente 10 V) y aplicarlo al pin MCLR en el momento adecuado para ingresar al modo de programación. Si aún no tiene este tipo de hardware en su placa, entonces requerirá hardware adicional que, en última instancia, es controlado por el FPGA en cuanto a cuándo se activa.
La mayoría de los programadores de PIC incluyen un pequeño regulador de impulso (doblador de voltaje) para llevar los 5 V provistos hasta 10 V usando un PIC integrado para administrar la regulación de voltaje. A menudo usan PWM del PIC y una entrada ADC en el PIC como un simple regulador de impulso.
Debería echar un vistazo a los esquemas PICkit2 disponibles públicamente.
pjc50
mate joven
mística
mística
mate joven
mística
Dzarda
horta