Convertir el nivel de voltaje de salida del oscilador

0

Tengo un circuito de un chip USB (concentrador USB) con un oscilador externo personalizado de 24MHz. Este oscilador tiene un máximo de 3Vpp y el voltaje máximo del chip para XI es de 2.45 con un voltaje recomendado de 1.8.

¿Cuáles son las opciones para traducir el voltaje del oscilador de salida? La forma más simple es un divisor de resistencia, pero una resistencia tiene una capacitancia intrínseca y una inductancia asociadas y XI también puede no tener una impedancia infinita. También se encuentran chips de conversión de voltaje, pero esto significa que también tengo que implementar otro riel de voltaje de 1.8V y esta no es una opción.

Entonces, mi pregunta es ¿cuál es la mejor solución?

    
pregunta Luis Carlos

1 respuesta

1

Nadie tiene "impedancia de entrada infinita", y todo tiene "capacitancia intrínseca e inductancia asociadas". La pregunta es cuánto afectarán estos parámetros parásitos a la señal. Todo lo que necesita es tener una señal lo suficientemente fuerte como para alternar el búfer de entrada del circuito XTAL cerca del umbral de entrada de 1.8V / 2, o 900 mV + - 200 mV, eso es todo.

Si desea reducir una señal de 3.3 V proveniente del exterior de un oscilador sobre una línea de transmisión (traza de PCB), simplemente terminando la señal con una impedancia característica (por ejemplo, una traza típica de 60 a 65 ohmios) en el punto XI se reducirá la mitad al instante. Tensión, sin ningún divisor. La línea de transmisión será ese divisor, especialmente si iguala la impedancia de la línea de transmisión en el lado de entrada utilizando una resistencia de serie razonable (22 a 33 ohmios, en el extremo del oscilador). No habrá reflexiones ni ninguna otra fealdad de qué preocuparse.

Entonces, la respuesta corta es que todos estos "intrínsecos" son totalmente insignificantes a 24 MHz o incluso a frecuencias mucho más altas. Sus preocupaciones son absolutamente infundadas.

    
respondido por el Ale..chenski

Lea otras preguntas en las etiquetas

___ método qstnhdr ___ para manejar fuentes de interrupción GPIO concurrentes? ______ qstntxt ___

Tengo dos fuentes de interrupción GPIO que se ejecutan en dos subprocesos separados:

  1. Pulsos GPIO siguiendo la línea de frecuencia (60 Hz)
  2. botón
  3. presionar

¿Cómo puedo usar estas dos interrupciones simultáneamente, considerando que mi controlador (ESP32) multiplexa todas las interrupciones del periférico GPI0 en una interrupción de la CPU?

Actualmente, el programa permite que solo uno de ellos funcione a la vez.

Gracias

    
______ answer370267 ___

Estoy escribiendo esto sin utilizar nunca un ESP32 (o cualquier otro núcleo dual) o FreeRTOS. Desde mi conocimiento de FreeRTOS (búsqueda muy rápida), implementas los controladores de interrupción por tu cuenta, pero tienes que llamar a algunas funciones del sistema operativo desde dentro.

Por lo tanto, independientemente de la GPIO en la que ocurra la interrupción, terminará en la misma función de interrupción, porque solo hay un vector de interrupción para GPIO.

Pero el ESP32 tiene algunos registros para decirle qué interrupciones están pendientes. Y tienes registros que te dicen qué interrupción está habilitada. La combinación de esos registros le permite decidir qué pines están causando una interrupción.

Por lo tanto, en función de esto, puede hacer diferentes cosas según el GPIO que haya provocado la interrupción.

Te voy a dar una idea, no una implementación, así que lo siguiente es pseudocódigo:

%pre%

De esta manera puede dividir la interrupción en múltiples funciones de ejecución. Prefiero la manera de usar las funciones, pero estoy programando en C ++ e intento evitar las variables globales.

    
______ answer370257 ___

Primero verifique si el firmware / SDK le permite dividir las interrupciones. Es posible que tengas que saltar algunos aros adicionales para poder hacerlo. Muchas veces, el SDK basado en arduino silenciará las opciones disponibles para que sea más fácil para los principiantes y unificar la experiencia en diferentes tableros. Y revise la especificación del microcontrolador para ver exactamente qué sucederá cuando entren las interrupciones mientras ya está manejando otra.

De lo contrario, puede comprobar qué provocó la interrupción dentro de la rutina de interrupción y luego establecer un indicador volátil para manejarlo en su bucle principal.

    
______ answer370293 ___

A menos que un dispositivo tenga un enganche por pin de eventos de interrupción, su mejor opción es probablemente rastrear el último estado reconocido de cada registro de puertos de E / S [en %code% , abajo], y luego hacer algo como:

%pre%

Si cualquier bit de interés se establece en %code% o %code% , el código debe borrar atómicamente el bit (tal vez al deshabilitar las interrupciones, usar la carga vinculada / almacenamiento condicional u otros medios) y manejar la condición apropiada. Tenga en cuenta que si el estado de un pin cambia y luego vuelve a cambiar antes de ser observado por el código anterior, la transición debería perderse.

Cada vez que el sistema vaya a estar inactivo en función de una interrupción de cambio de pin, debería borrar el indicador de interrupción de cambio de pin, luego verificar si el estado del puerto coincide con %code% , y solo irse a dormir si lo hace partido. De esa manera, si el pin del puerto cambia antes de leerlo, el código lo notará y, si cambia después de leerlo, el hardware lo notará. Algunas plataformas hacen que sea imposible evitar por completo las condiciones de carrera, pero las buenas plataformas garantizarán que los eventos que se producen entre el borrado de la bandera y la lectura del estado del puerto se activen por el hardware además de que se informen en el software. En consecuencia, incluso si un evento que ocurre precisamente cuando el puerto se está leyendo no aparece en la lectura, aún se registrará como una activación de hardware.

    
___
¿Cómo puedo encontrar un OPamp, o cualquier otro componente, que tenga las propiedades requeridas al usar software de simulación como multisim?