TMS9918

Controlador de pantalla de video
Dispositivo de visualización de datos TMS9918A
Dispositivo de visualización de datos TMS9918A

El TMS9918 es un controlador de pantalla de vídeo (VDC) fabricado por Texas Instruments , en los manuales se hace referencia como "Procesador de pantalla de vídeo" (VDP) e introducido en 1979. [1] El TMS9918 y sus variantes se utilizaron en ColecoVision , CreatiVision , Memotech MTX , MSX , NABU Personal Computer , SG-1000 / SC-3000 , Spectravideo SV-318 , SV-328 , Sord M5 , Tatung Einstein , TI-99/4 , Casio PV-2000 , Coleco Adam , Hanimex Pencil II , PECOS y Tomy Tutor .

El TMS9918 genera gráficos de caracteres basados ​​en cuadrícula (utilizados para mostrar texto o imágenes de fondo) y sprites utilizados para mover objetos en primer plano.

Las características principales de este chip son, como se destacó en una presentación de 1980 de Karl Guttag (uno de los diseñadores): [1]

  • 256 x 192 píxeles a todo color por pantalla
  • 15 colores y/o tonos diferentes
  • Salida de vídeo compuesto en color no entrelazado
  • Cableado directo a RAM dinámicas de tipo RAS/CAS
  • Actualización automática de RAM dinámicas
  • Interfaz de CPU de tipo mapeado de memoria general de 8 bits
  • La CPU accede a la RAM a través de VDP (sin necesidad de DMA )
  • 32 personajes dinámicos por pantalla
  • Treinta y dos patrones de 8×8 por fila, 24 filas por pantalla
  • Modo de texto con cuarenta patrones de 6×8 por fila
  • Modo multicolor con 64 x 48 cuadrados de color asignables a la memoria
  • Entrada y control de vídeo externo
  • Funcionamiento con una sola fuente de alimentación de +5 voltios
  • Tecnología de compuerta de silicio de canal N estándar

Familia de productos

Todos los circuitos integrados de esta familia suelen denominarse con el nombre TMS9918, a veces con el sufijo "A". La "A" indica una segunda versión del chip que incorporaba nuevas funciones, la más destacada de las cuales era la incorporación de un modo de mapa de bits (Graphic II).

Resumen de la familia de productos TMS9918 de Texas Instruments
Variante de chipSalida de videoVídeo enFrecuencia de videoSoporte de modo 2
9918CompuestoCompuesto60 HzNo
9918A / 9118CompuestoCompuesto60 Hz
9928A / 9128YPbPr(Ninguno)60 Hz
9929A ​​/ 9129YPbPr(Ninguno)50 Hz

TMS9918

El TMS9918 sólo se utilizó en la TI-99/4; la TI-99/4A y las otras computadoras tenían la versión A VDC.

TMS9918A, TMS9928A y TMS9929A

Dispositivo de visualización de datos TMS9928A

El TMS9918A y el TMS9928A emiten una señal de vídeo de 60 Hz , mientras que el TMS9929A ​​emite 50 Hz. La diferencia entre '1' y '2' en 'TMS9918A' y 'TMS9928A' es que la versión '1' emite vídeo NTSC compuesto , mientras que las versiones '2' (incluido el TMS9929A) emiten YPbPr [2] analógico ( luminancia Y y señales de diferencia de color Pr (RY) y Pb (BY) ). La necesidad de este último era predominante en el mundo de 50 Hz , incluida Europa, debido a los diferentes estándares de señal de vídeo PAL y SECAM . Era más rentable emitir Y, Pr y Pb y codificarlos en PAL o SECAM en el modulador de RF , que intentar tener una consola diferente para cada estándar de color diferente. La versión '1' también cuenta con una entrada de video compuesto externa, lo que lo convierte en un chip útil para usar en "tituladores" de video que pueden superponer texto o gráficos en el video, mientras que la versión '2' no lo hace.

Las variantes originales del TMS9918 eran NMOS de carga de agotamiento y se fabricaban con un proceso de 4,5 μm; fue uno de los primeros chips NMOS de carga de agotamiento que fabricó Texas Instruments, en contraste con el microprocesador TMS9900 que utilizaba el antiguo proceso NMOS de carga de mejora que requería tres voltajes de suministro. Debido al gran tamaño de la matriz y a la velocidad interna relativamente alta, el TMS9918 se calentaba lo suficiente como para necesitar un disipador de calor; algunos dispositivos, como la consola taiwanesa DINA (un híbrido Colecovision/SG-1000) no instalaron disipadores y sufrieron fallas en el chip. En 1983, Texas Instruments había reducido el tamaño del chip a 3 μm, lo que hacía que funcionara a menor temperatura y ya no requiriera un disipador: las máquinas MSX y la Sega SG-1000 usaban el nuevo TMS9918 de 3 μm, mientras que la mayoría de las Colecovisions tenían la variante original de 4,5 μm (la última serie de consolas producidas en 1985 tenía el modelo más nuevo TMS9918).

TMS9118, TMS9128 y TMS9129

Prototipo VDP TMP9118NL

A mediados de los años 1980 se lanzaron al mercado variantes posteriores de los chips de la serie TMS9918, los TMS9118 , TMS9128 y TMS9129 , pero nunca fueron muy populares. Se cambió la función de un pin y la asignación de la memoria de video permite utilizar dos chips de 16K×4 bits en lugar de los ocho chips de 16K×1 bit que necesita el TMS99xx. Por lo demás, los chips son completamente idénticos a los TMS9918A, TMS9928A y TMS9929A ​​respectivamente.

Interfaces externas

RAM de vídeo

El VDP tiene 16K × 8 bits de memoria de video externa. Esta memoria está fuera del espacio de direcciones de la CPU . Tener un espacio de direcciones separado significa que la CPU tiene que hacer más trabajo para escribir o leer esta memoria, pero también significa que el VDC no ralentiza la CPU cuando lee periódicamente esta memoria para generar la pantalla. Además, deja más espacio de direcciones disponible para la CPU para otra memoria y hardware mapeado en memoria.

Dependiendo del modo de pantalla que se utilice, es posible que no se necesite toda la memoria de vídeo para generar la imagen. En estos casos, la CPU puede utilizar la memoria de vídeo adicional para otros fines. Por ejemplo, un uso es como un bloc de notas para descomprimir los datos gráficos o de sonido almacenados en la ROM del cartucho. Otro uso popular es crear una segunda copia de algunos o todos los datos de la pantalla para eliminar el parpadeo y el corte, una técnica conocida como doble búfer .

UPC

La CPU se comunica con el VDP a través de un bus de 8 bits . Un pin controlado por la CPU separa este bus en dos "puertos", un puerto de control y un puerto de datos. Para escribir o leer un byte de memoria de vídeo, la CPU primero tiene que escribir dos bytes en el puerto de control del VDP en el registro de dirección interna del VDC. A continuación, la CPU realiza la escritura o lectura real en el puerto de datos del VDP. A medida que se escribe o lee un byte de datos, el TMS9918 incrementa automáticamente el registro de dirección interna. Esta función de incremento automático acelera las escrituras y lecturas de bloques de datos. El puerto de control también se utiliza para acceder a varios registros internos.

Gráficos

El TMS9918 tiene dos tipos de gráficos separados y distintos: personajes y sprites .

Personajes

Los caracteres se utilizan normalmente para crear texto o imágenes de fondo. Aparecen detrás de los sprites.

Modos de pantalla

El TMS9918 tiene varios modos de pantalla que controlan las características de los personajes.

Documentado

Hay cuatro modos de pantalla documentados disponibles en el TMS9918A (como se mencionó anteriormente, el TMS9918 carece del modo Gráfico 2):

  • Modo 0 (Texto): 240 × 192 píxeles en total, como 40 × 24 caracteres, extraídos de un conjunto de caracteres de 256 caracteres de 6 × 8 píxeles. Todo el conjunto de caracteres tiene una limitación de 2 colores. Este modo no admite sprites.
  • Modo 1 (Gráfico 1): 256 × 192 píxeles en total, como 32 × 24 caracteres, extraídos de un conjunto de caracteres de 256 caracteres de 8 × 8 píxeles. Cada grupo de 8 caracteres del conjunto de caracteres tiene una limitación de 2 colores. Por ejemplo, los caracteres del "0" al "7" tendrán todos los mismos atributos de color .
  • Modo 2 (Gráfico 2): 256 × 192 píxeles en total, como 32 × 24 caracteres, extraídos de 3 conjuntos de caracteres de 256 caracteres de 8 × 8 píxeles. Cada línea de 8 píxeles de ancho de un carácter en los conjuntos de caracteres tiene una limitación de 2 colores. Este modo proporciona un carácter único para cada ubicación de carácter en la pantalla, lo que permite la visualización de imágenes de mapa de bits.
  • Modo 3 (Multicolor): 256×192 píxeles en total, 64×48 píxeles virtuales modificables, como 32×24 caracteres " semigráficos ". Estos semigráficos se definen en un conjunto de caracteres especial de 256 caracteres definidos por 2×2 "píxeles gruesos". Hay 4×4 píxeles en cada píxel grueso, pero los píxeles dentro de un píxel grueso no se pueden definir individualmente, aunque cada píxel grueso puede tener su propio color, de ahí el nombre de este modo (Multicolor). Este modo es muy cuadrado y rara vez se utiliza.
Detalles del modo de pantalla 2

Técnicamente, el modo 2 es un modo de caracteres con un conjunto de caracteres coloridos. La pantalla está dividida horizontalmente en tres áreas de 256×64 píxeles, cada una de las cuales tiene su propio conjunto de caracteres. Al imprimir secuencialmente los caracteres del 0 al 255 en las tres áreas, el programa puede simular un modo gráfico en el que cada píxel se puede configurar individualmente. Sin embargo, el búfer de cuadros resultante no es lineal.

El programa también puede utilizar tres conjuntos de caracteres idénticos y luego tratar la pantalla como un modo de texto con un conjunto de caracteres coloridos. Los patrones de fondo y los sprites consisten entonces en caracteres coloridos. Esto se usaba comúnmente en los juegos, porque solo se debían mover 32×24 bytes para llenar y desplazarse por toda la pantalla.

El desafío de usar el modo 2 de TMS9918 era que cada área de 8x1 píxeles podía tener solo dos colores, primer plano y fondo. Se podían elegir libremente de la paleta de 16 colores, pero para cada área de 8x1, solo podían existir dos colores. Al manipular la pantalla en BASIC con el LINEcomando, uno podía fácilmente exceder el máximo de 2 colores por área de 8x1 y terminar con un " desbordamiento de color ".

Indocumentado

Originalmente, Texas Instruments sólo documentó los cuatro modos enumerados anteriormente. Sin embargo, el bit que habilita el modo 2 es más interesante de lo que se pensaba inicialmente. Se describe mejor como un bit modificador para los otros modos. Al habilitarlo se logran tres cosas: [3]

  1. Amplía el tamaño de la tabla de colores.
  2. Divide la pantalla horizontalmente en tercios.
  3. Cambia dos bits de dirección de las tablas de patrones y colores en bits de máscara, que controlan si cada tercio de la pantalla tiene su propia tabla de patrones y colores o no.

Teniendo esto en cuenta, son posibles tres modos adicionales. Tenga en cuenta que, si bien los chips TMS9918A originales admiten estos modos, es posible que los clones y emuladores no los admitan.

  • Modo 0 (Texto) + Modo 2 (Gráfico 2) : conocido como Modo de texto de mapa de bits . Este modo permite imágenes de mapa de bits de dos colores, sin tabla de colores. Esto ahorra memoria, a expensas de una resolución horizontal ligeramente reducida (el modo de texto tiene una resolución horizontal de 240 píxeles en lugar de 256 píxeles como los modos gráficos).
  • Modo 1 (Gráfico 1) + Modo 2 (Gráfico 2): conocido como modo Half-Bitmap . Texas Instruments documentó este modo de pantalla "no documentado" en su manual titulado "Video Display Processors Programmers Guide SPPU004" [4] . En la sección 8.4.2, " Playing Games with VRAM Addressing" [ 4], analizan cómo este modo combina el ahorro de memoria del modo 1 con el detalle de color del modo 2. Sin embargo, como continúan diciendo, este modo limita la cantidad de sprites que se pueden mostrar a 8 en lugar de 32. Por lo tanto, el término "no documentado" utilizado para describir este modo es un nombre inapropiado. Sin embargo, debido a que este manual no era ampliamente conocido, este modo generalmente se considera uno de los modos no documentados. Generalmente, la única razón para usar este modo en lugar del Modo 2 es reducir el consumo de memoria.
  • Modo 3 (Multicolor) + Modo 2 (Gráfico 2) : conocido como modo multicolor de mapa de bits. Este modo es más bien una novedad, ya que no ofrece nada más allá de lo que el modo multicolor estándar ya puede hacer.

Desplazamiento

El TMS9918 no tiene registros de desplazamiento , por lo que el desplazamiento debe realizarse mediante software. Además, el desplazamiento solo puede realizarse en los límites de los caracteres, no píxel por píxel. [ cita requerida ]

Sprites

Los sprites se utilizan normalmente para crear objetos móviles en primer plano. Aparecen delante de los personajes (mosaicos).

Los modos 1, 2 y 3 permiten renderizar sprites. Puede haber hasta 32 sprites monocromáticos de 8×8 o 16×16 píxeles en pantalla, cada uno con su propio color único. La ilusión de sprites multicolores se puede crear apilando varios sprites uno sobre otro.

No puede haber más de 4 sprites en una sola línea de escaneo; los píxeles horizontales de los sprites adicionales se descartan. Los sprites con una prioridad más alta se dibujan primero. El VDP informa en un registro de estado el número del primer sprite descartado. La CPU puede evitar esta limitación rotando las prioridades de los sprites de modo que se dibuje un conjunto diferente de sprites en cada cuadro; en lugar de desaparecer por completo, los sprites parpadearán. Esta técnica se conoce como multiplexación de sprites.

El movimiento automático de los sprites no lo gestiona el VDP. En la práctica, la CPU captará la interrupción vertical del VDP (una salida estándar del VDP que se activa automáticamente cada 50 o 60 segundos (según la variante del chip) al comienzo del VBI ( intervalo de borrado vertical ). La CPU pasa entonces a una rutina de manejo de sprites en el software, que a su vez le indica al VDP dónde debe reposicionar los sprites.

Cuando dos píxeles no transparentes de cualquier par de sprites colisionan, se activa el indicador de colisión de sprites. Esto resulta útil para activar rutinas de detección de colisiones más avanzadas dentro del software, que pueden determinar la ubicación exacta de la colisión y actuar en consecuencia, ya que el VDP por sí mismo no puede informar qué dos sprites han colisionado.

Bandera

Los chips de la familia TMS9918 utilizaban una paleta de video compuesta . Los colores se generaban en función de una combinación de valores de luminancia y crominancia para el TMS9918A y los valores Y , RY y BY para el TMS9928A/9929A.

Valores de la hoja de datos

El TMS9918 tiene una paleta fija de 16 colores , compuesta por 15 colores mostrados y un color "transparente".

  • Cuando se usa "transparente" para los sprites, se mostrarán los caracteres de fondo.
  • Cuando se usa "transparente" para los caracteres, se mostrará la señal de vídeo externa.

De acuerdo con la “Tabla 2.3 – Asignaciones de color” de la hoja de datos [5] los niveles de salida son los siguientes:

Código de coloresColorLuminanciaCrominanciaYRY (Pr.)POR (Pb)
0transparente-----
1negro0%-0%47%47%
2verde medio53%53%53%7%20%
3verde claro67%40%67%17%27%
4azul oscuro40%60%40%40%100%
5azul claro53%53%53%43%93%
6rojo oscuro47%47%47%83%30%
7cian67%60%73%0%70%
8rojo medio53%60%53%93%27%
9rojo claro67%60%67%93%27%
10amarillo oscuro73%47%73%57%7%
11amarillo claro80%33%80%57%17%
12verde oscuro46%47%47%13%23%
13magenta53%40%53%73%67%
14gris80%-80%47%47%
15blanco100%-100%47%47%

Notas: Los colores son meramente ilustrativos y se convirtieron de los valores YPrPb (MS9928A/9929A) a sRGB teniendo en cuenta la corrección gamma . No se tuvo en cuenta la colorimetría SMPTE C ; consulte la siguiente sección para ver conversiones de colores alternativas.

Pantalla CRT

[ ¿Investigación original? ]

Para convertir Y, RY y BY a RGB, debes considerar cómo se originó Y, es decir:

Y = R * 0,30 + G * 0,59 + B * 0,11

Por lo tanto, es necesario utilizar las siguientes fórmulas:

R = RY + Y B = POR + Y G = (Y - 0,30 * R - 0,11 * B) / 0,59

Pero primero hay que prestar atención al hecho de que para todos los colores que no tienen crominancia (es decir, negro, gris y blanco), RY y BY no son 0 %, sino que todos tienen un desplazamiento del 47 %. Por lo tanto, primero hay que restar este desplazamiento de todos los valores de RY y BY. Debido a que en la práctica este paso nunca se realizará solo, no hay problema en que algunos resultados sean negativos:

Código de coloresColorYRÍOPOR
1negro0%0%0%
2verde medio53%-40%-27%
3verde claro67%-30%-20%
4azul oscuro40%-7%53%
5azul claro53%-4%46%
6rojo oscuro47%36%-17%
7cian73%-47%23%
8rojo medio53%46%-20%
9rojo claro67%46%-20%
10amarillo oscuro73%10%-40%
11amarillo claro80%10%-30%
12verde oscuro47%-34%-24%
13magenta53%26%20%
14gris80%0%0%
15blanco100%0%0%

Ahora puedes realizar la conversión a RGB. Todos los resultados deben estar en el rango de 0% a 100%:

Código de coloresColorRGRAMOB
1negro0%0,0000%0%
2verde medio13%78,3729%26%
3verde claro37%85,9831%47%
4azul oscuro33%33,6780%93%
5azul claro49%46,4576%99%
6rojo oscuro83%31,8644%30%
7cian26%92,6102%96%
8rojo medio99%33,3390%33%
9rojo claro113%53,9492%47%
10amarillo oscuro83%75,3729%33%
11amarillo claro90%80,5085%50%
12verde oscuro13%68,7627%23%
13magenta79%36.0508%73%
14gris80%80.0000%80%
15blanco100%100.0000%100%

Se podría llegar a la conclusión de que el valor erróneo de 113% para R del color "rojo claro" es el resultado de un error tipográfico en la hoja de datos y que RY no debe ser mayor que el 80%. Pero si se miden las señales de salida del chip con un osciloscopio , se encontrará que todos los valores de la tabla son correctos. Por lo tanto, el error está dentro del chip y hace que la señal roja se sature. Por este motivo, este valor debe corregirse al 100%.

Además, hay que tener en cuenta que hasta entonces sólo se disponía de tubos de rayos catódicos para monitores de ordenador, así como para televisores, y que estos CRT tenían una gamma . Los chips de la serie TMS9918 habían sido diseñados para funcionar con televisores y sus CRT tenían una gamma de 1,6 (observación: los CRT de los monitores Macintosh tenían 1,8 y los CRT de los monitores de PC tenían 2,2). Las pantallas planas no tienen gamma . Por este motivo, los colores del TMS9918 se ven algo pálidos aquí, como se puede ver en la primera tabla anterior. La siguiente tabla utiliza los valores con corrección de gamma, que son (escritos en hexadecimal porque así lo requiere la codificación de Wikipedia):

Código de coloresColorRGRAMOB
1negro000000
2verde medio0AANUNCIO1E
3verde claro34C84C
4azul oscuro2B2DE3
5azul claro514Bpensión completa
6rojo oscuroBD2925
7cian1EE2ES
8rojo mediopensión completa2C2B
9rojo claroFF5F4C
10amarillo oscuroBDA22B
11amarillo claroD7B454
12verde oscuro0A8C18
13magentaA.C.329A
14grisB2B2B2
15blancoFFFFFF

Nota: Los pasos utilizados son: redondear todos los valores a dos decimales, luego elevar a la potencia de 1,6 para la corrección gamma y finalmente transformar el rango de valores de 0...100 a 0...255.

Presupuesto

  • RAM de video: cableado directo a 4, 8 o 16 KB
  • Modos de texto: 40 × 24 y 32 × 24
  • Resolución: 256 × 192
  • Colores: 15 colores + transparente
  • Sprites: 32, 1 color, máximo 4 por línea horizontal

Legado

El TMS9918A de Texas Instruments fue reemplazado por el V9938 de Yamaha , que agregó modos de mapa de bits adicionales, sprites más coloridos , un registro de desplazamiento vertical de pantalla completa, registros de desplazamiento vertical y horizontal, un blitter de hardware y una paleta personalizable . El V9938 fue diseñado para el estándar de computadoras MSX2 y luego se usó en una actualización de terceros para el TI-99/4A : el "ordenador en una tarjeta" Geneve 9640 .

El V9938, a su vez, fue sucedido por el V9958 , que agregó algunos modos de color alto adicionales y un registro de desplazamiento horizontal de dos páginas; estos chips se usaron en los sistemas MSX2+/ turboR .

Toshiba fabricó un clon llamado T6950 y no admite la función de enmascaramiento de patrones/tablas de colores no documentada en el modo de gráficos 2. [6] [ se necesita una mejor fuente ] Más tarde, Toshiba lanzó el T7937A MSX-Engine con un VDP integrado y arregló las funciones de enmascaramiento. Ambos VDP de Toshiba presentan una paleta ligeramente diferente a la de los VDP de Texas, con colores más vivos.

El TMS9918 fue la base de los chips VDP de la Master System , Game Gear y Mega Drive de Sega . El PPU de Nintendo utilizado en la Famicom/NES también se basó vagamente en el TMS9918. Utilizaron modos de visualización y registros adicionales, y añadieron capacidades de desplazamiento por hardware y otras funciones avanzadas.

Véase también

Referencias

  1. ^ ab "Borrador del Simposio Técnico de Arizona TMS9918 - Desarrollo - SMS Power!". www.smspower.org .
  2. ^ "Espacios de color YUV, YCbCr, YPbPr | DiscoveryBiz.Net". discoverybiz.net .
  3. ^ Procesador de visualización de vídeo / Modos híbridos, que también se pone en uso.
  4. ^ ab Procesadores de pantalla de video - Guía del programador (PDF) . Texas Instruments.
  5. ^ Texas Instruments (1982), Procesadores de pantalla de video TMS9918A/TMS9928A/TMS9929A ​​(PDF) , consultado el 2 de noviembre de 2018
  6. ^ "Modo no documentado 1 + 2: encuesta/discusión | Centro de recursos MSX (página 2/4)".
  • Ficha de datos
  • Guía del programador
  • Reemplazo moderno del F18A
  • Reemplazo de SRAM para VRAM TMS9x18
Obtenido de "https://es.wikipedia.org/w/index.php?title=TMS9918&oldid=1251003140"