Me pregunto si es posible modificar un sistema electrónico de consumo (TV, teléfono, dispositivo integrado, etc.) para que sea posible leer y posiblemente escribir el contenido de sus chips RAM mientras el sistema está funcionando, sin agregar ningún software al dispositivo objetivo.
No estoy muy familiarizado con el hardware, pero supongo que una solución podría implicar soldar algo en los pines del chip RAM, para que las señales sean interceptadas y luego "reproducir" las escrituras en una RAM interna, creando efectivamente una copia sincronizada de la RAM del dispositivo.
La RAM interna podría tener un segundo puerto que permitiría al usuario leerla, por ejemplo, a través de un controlador que expone una interfaz de almacenamiento masivo USB.
Alternativamente, sin el segundo puerto, el controlador quizás podría dar acceso al dispositivo original a la RAM interna cuando está escribiendo y, en su lugar, reemplazar las lecturas con las lecturas emitidas por el usuario para examinar la RAM cuando está leyendo.
O para los chips DRAM actualizados por el controlador, podría filtrar todos los accesos, excepto las escrituras utilizadas para la actualización de DRAM (al detectar una actualización y luego usar un temporizador), y luego aprobar las lecturas de examen en momentos en que no se está realizando la actualización de DRAM.
Un diseño alternativo podría ser reemplazar el chip de RAM con una RAM de doble puerto y luego conectar el puerto original al dispositivo de destino y el otro puerto al controlador que permite leerlo o escribirlo.
Este último diseño también permitiría escribir la RAM además de leer.
Alternativamente, uno podría intentar procesar el flujo de señales de RAM en el software en lugar de enviarlo a un chip de RAM, pero parece que esto sería mucho más complejo y costoso debido a la alta velocidad de datos (que podría requerir dividir el flujo y procesar con un grupo de máquinas).
Precisamente, las preguntas son:
¿Es posible en absoluto?
¿Es factible hacer esto en placas base producidas comercialmente con chips de RAM soldados que se encuentran en dispositivos electrónicos de consumo?
¿Hay algún dispositivo estándar que pueda hacer esto?
De no ser así, ¿cuál sería la forma más barata/sencilla de crear una copia única de un dispositivo de este tipo con solo soporte de lectura? ¿Qué pasa con el soporte de escritura? (asumiendo que todo más allá del dispositivo de destino y una PC normal tiene que ser comprado)
Esta es una pregunta general sobre chips SRAM, DDR, LPDDR, GDDR, Rambus, etc.
¿Es posible en absoluto?
Bueno, tal vez sí.
¿Es factible hacer esto en placas base producidas comercialmente con chips de RAM soldados que se encuentran en dispositivos electrónicos de consumo?
Definitivamente no. Conectar cables a las líneas entre la CPU y la RAM sin perturbar las comunicaciones es extremadamente difícil. Cuanto más rápido es el autobús, más difícil es esto. Reemplazar los chips de RAM con algo (una FPGA + RAM externa más grande probablemente sería suficiente) que "simule" un chip de RAM en el sistema modificado y haga lo que quiera con los datos es probablemente mucho más factible.
¿Hay algún dispositivo estándar que pueda hacer esto?
Lo más probable es que no.
Ignacio Vázquez-Abrams
fulana
mate b
chris stratton
chris stratton