Doom.ttf: Executando Código na Máquina Virtual de Fontes TrueType

Doom.ttf: Executando Código na Máquina Virtual de Fontes TrueType

Descubra como a máquina virtual embutida em fontes TrueType, projetada para renderização de texto, pode ser explorada para executar código, permitindo a execução do clássico jogo Doom dentro de um arquivo de fonte.

MundiX News·18 de junho de 2026·7 min de leitura·👁 6 views

A execução do jogo Doom é lendária por sua capacidade de rodar em praticamente qualquer dispositivo, desde displays de cigarros eletrônicos e testes de gravidez até bactérias E. coli e tratores John Deere. Agora, o desafio é rodar Doom dentro de um arquivo de fonte TrueType (TTF). Como isso é possível? A resposta reside na complexa máquina virtual (VM) presente nas fontes.

VM em Fontes? Uma Superfície de Ataque Inesperada

Sim, fontes TrueType contêm uma máquina virtual funcional que pode ser explorada como um vetor de ataque incomum. Quando um navegador carrega uma página, ele precisa renderizar as letras. A abordagem mais direta seria rasterizar os contornos vetoriais dos glifos no tamanho desejado. No entanto, em tamanhos pequenos, isso pode resultar em uma "sopa" de pixels: serifs finos desaparecem, traços verticais oscilam entre os pixels e elementos que deveriam ter a mesma espessura aparecem com espessuras diferentes. Essa era uma catástrofe em telas de baixa resolução dos anos 90.

Em 1991, programadores da Apple introduziram uma solução: permitir que a própria fonte contivesse um programa que instruísse o rasterizador sobre como ajustar os contornos à grade de pixels. Essa técnica é chamada de hinting (do inglês "hint" - dica) e é executada em uma máquina de pilha com quase 200 instruções. A Microsoft adotou essa ideia, tornando o TrueType um padrão de fato. Atualmente, cada arquivo TTF contém hinting, e cada letra exibida na tela é o resultado da execução de centenas de instruções dessa VM. O interpretador reside no sistema FreeType em Linux e Android, no DirectWrite no Windows e no Core Text no macOS. Antes do Windows 10 Anniversary Update, a análise de fontes era realizada diretamente no kernel (win32k.sys), um ponto crucial para a segurança que exploraremos mais adiante.

A instrução set dessa VM é surpreendentemente robusta, indo muito além da simples tarefa de "mover um vértice de contorno em meio pixel". Ela inclui saltos condicionais (IF, ELSE, EIF), chamadas recursivas de funções (FDEF e CALL), uma área de armazenamento (Storage Area) com 65.535 células, e capacidades aritméticas e lógicas. Esses recursos combinados tornam a máquina Turing-completa. O site Gwern.net mantém um catálogo de sistemas "inesperadamente Turing-completos", e o TrueType figura nessa lista há muito tempo. Alguém, eventualmente, usaria essa capacidade para algo mais interessante do que simples contagem. A ideia de executar Doom dentro de uma fonte surgiu como um experimento.

Raycasting Simplificado

Antes de mergulhar no bytecode, é essencial entender como Doom e Wolfenstein 3D implementavam o 3D. A genialidade do raycasting reside em permitir a criação de pseudo-3D em hardware que não suportava gráficos 3D nativamente. O mapa do jogo é uma grade bidimensional de 16x16 células, onde cada célula pode conter um espaço vazio ou uma parede. O jogador está posicionado em algum lugar na grade, olhando em uma direção específica. O algoritmo funciona da seguinte forma: a tela é dividida em faixas verticais (por exemplo, uma para cada coluna de pixels). Para cada faixa, um raio é "lançado" da posição do jogador na direção correspondente a essa parte da tela. O raio viaja pela grade 2D até colidir com uma parede. A distância até a parede é medida e, quanto mais distante a parede, menor ela é desenhada na tela, criando a ilusão de 3D. A sutileza está na forma como o raio "viaja pela grade". Para evitar que ele "salte" sobre uma parede entre os passos, utiliza-se o algoritmo DDA (Digital Differential Analyzer). Este algoritmo garante que o raio avance sempre para a próxima fronteira de célula (horizontal ou vertical), a mais próxima, assegurando que nenhuma parede seja atravessada. John Carmack, em 1992, implementou isso em um processador 386 sem FPU, utilizando aritmética de ponto fixo e tabelas pré-calculadas para senos e cossenos. Essa abordagem se torna familiar quando consideramos a situação dentro do hinting TTF, onde nos encontramos exatamente no mesmo cenário.

Arquitetura TTF-DOOM

A abordagem TTF-DOOM divide o processamento em duas partes. O JavaScript na página web lida com a entrada do teclado (WASD e setas), rastreia a posição e a rotação do jogador, e renderiza na tela Canvas todos os elementos que necessitam de sprites, como inimigos, armas e o HUD. A fonte, por outro lado, assume a pesada carga geométrica: recebe as coordenadas do jogador, lança raios, calcula as distâncias até as paredes e retorna um array de alturas. Essencialmente, atua como uma GPU, embora extremamente peculiar e lenta. A questão crucial é como transferir dados para a fonte, que é um arquivo estático. Surpreendentemente, isso é feito através de CSS. Fontes OpenType suportam "variable fonts" (fontes variáveis) com "eixos de variação". É possível definir uma string CSS como font-variation-settings: 'MOVX' 123, 'MOVY' 456, 'TURN' 789. O navegador, então, reinicia o hinting a cada alteração. Dentro do processo de hinting, existe uma instrução especial GETVARIATION (opcode 0x91) que coloca na pilha os valores atuais de todos os eixos. Isso estabelece a comunicação entre o mundo JavaScript e o mundo da máquina de pilha.

Segurança e Ataques via Fontes

A capacidade de execução de código dentro de fontes TrueType levanta sérias preocupações de segurança. Históricamente, vulnerabilidades em parsers de fontes foram exploradas para comprometer sistemas. O caso Duqu em 2011 demonstrou como um arquivo de fonte malicioso poderia explorar falhas no kernel do Windows para obter acesso. O Google Project Zero, após um ano de fuzzing em fontes, descobriu diversas vulnerabilidades. Mais recentemente, a "Operation Triangulation" revelou ataques sofisticados que utilizavam exploits em fontes para comprometer dispositivos. Ataques "scriptless", que exploram o hinting para executar código sem a necessidade de scripts maliciosos na página, são particularmente perigosos. A defesa contra essas ameaças envolve mecanismos como o fontdrvhost.exe no Windows, que isola o processamento de fontes, e o "Untrusted Font Blocking", que impede a instalação de fontes não confiáveis. A lição fundamental é que a complexidade inerente às fontes modernas, com suas VMs e capacidades de execução, pode se tornar uma superfície de ataque significativa se não for devidamente gerenciada e protegida.

🛡️⚡

Pare de pesquisar. Comece a hackear.

O MundiX é seu copiloto de pentest com IA: comandos exatos, análise de outputs e próximo passo na kill chain — em segundos.

Testar grátis por 7 dias →

Sem cartão para começar · Planos a partir de R$49/mês

📤 Compartilhar & Baixar

🧰 Ferramentas recomendadas

Divulgação: alguns links são patrocinados. Podemos receber comissão se você comprar — sem custo extra para você. Só indicamos o que faz sentido para a comunidade.

Aprendendo Kali Linux: Teste de segurança, pentest e hacking ético

Aprendendo Kali Linux: Teste de segurança, pentest e hacking ético

Com centenas de ferramentas pré-instaladas, a distribuição Kali Linux facilita o trabalho de os profissionais de segurança começarem a fazer testes de segurança rapidamente. No entanto, com mais de 600 ferramentas em seu arsenal, o Kali Linux também pode ser desafiador. A nova edição deste prático livro abrange as atualizações nas ferramentas e inclui uma melhor abordagem da análise forense e da engenharia reversa. Ric Messier, autor, não fica apenas no teste de segurança, mas também faz uma abordagem sobre a execução de análise forense, incluindo a análise em disco e na memória, assim como alguma análise básica de malware. • Explore as diversas ferramentas disponíveis no Kali Linux • Entenda o valor do teste de segurança e examine os tipos de teste disponíveis • Aprenda os aspectos básicos do pentest em todo o ciclo de vida do ataque • Instale o Kali Linux em vários sistemas, tanto físicos quanto virtuais • Descubra como usar diferentes ferramentas destinadas à segurança • Estruture um teste de segurança baseado nas ferramentas do Kali Linux • Estenda as ferramentas do Kali para criar técnicas de ataque avançadas • Use o Kali Linux para ajudar a criar relatórios quando o teste terminar “A abordagem concisa, clara e baseada na experiência adotada por Ric Messier para a introdução do Kali Linux e dos testes de cibersegurança é incomparável. Este livro é uma leitura excelente e acessível para iniciantes e um recurso valioso para qualquer pessoa.” —Alexander Arlt, Consultor sênior de segurança, Google

Ver na Amazon
Gshield 2 em 1 Hub Extensor Conector USB-C + USB-A e Adaptador de Rede Ethernet LAN RJ45 com 3 Entradas USB 3.0 até 5 Gbps em Liga de Alumínio para Computador e Notebook, Cinza

Gshield 2 em 1 Hub Extensor Conector USB-C + USB-A e Adaptador de Rede Ethernet LAN RJ45 com 3 Entradas USB 3.0 até 5 Gbps em Liga de Alumínio para Computador e Notebook, Cinza

Compatível com portas USB-C e USB-A, ideal para ampliar a conectividade de dispositivos como MacBook Pro e outros com portas USB-C. Inclui um adaptador USB-A extra, proporcionando uma conexão Ethernet estável e veloz de até 1 Gbps, perfeita para filmes, jogos online e videoconferências. Oferece três portas USB 3.0 com velocidades de transferência de até 5 Gbps, permitindo conectar mouse, teclado, discos rígidos e outros periféricos. Fabricado em alumínio durável, garantindo longa vida útil e resistência ao uso diário. Design compacto e leve, ideal para viagens de negócios e uso diário, facilitando o transporte e armazenamento. Funciona com Windows 10/8.1/8, Mac OS e Chrome OS, oferecendo versatilidade incomparável para diversas necessidades de conectividade. Assegura uma conectividade estável e rápida, perfeita para tarefas exigentes como transferência de dados, streaming e mais.

Ver na Amazon
Hacking APIs: Breaking Web Application Programming Interfaces

Hacking APIs: Breaking Web Application Programming Interfaces

Hacking APIs is a crash course on web API security testing that will prepare you to penetration-test APIs, reap high rewards on bug bounty programs, and make your own APIs more secure. You'll learn how REST and GraphQL APIs work in the wild and set up a streamlined API testing lab with Burp Suite and Postman. Then you'll master tools useful for reconnaissance, endpoint analysis, and fuzzing, such as Kiterunner and OWASP Amass. Next, you'll learn to perform common attacks, like those targeting an API's authentication mechanisms and the injection vulnerabilities commonly found in web applications. You'll also learn techniques for bypassing protections against these attacks. In the book's nine guided labs, which target intentionally vulnerable APIs, you'll practice: Enumerating APIs users and endpoints using fuzzing techniques Using Postman to discover an excessive data exposure vulnerability Performing a JSON Web Token attack against an API authentication process Combining multiple API attack techniques to perform a NoSQL injection Attacking a GraphQL API to uncover a broken object level authorization vulnerability

Ver oferta
Gray Hat Hacking: The Ethical Hacker's Handbook, Sixth Edition

Gray Hat Hacking: The Ethical Hacker's Handbook, Sixth Edition

Up-to-date strategies for thwarting the latest, most insidious network attacks This fully updated, industry-standard security resource shows, step by step, how to fortify computer networks by learning and applying effective ethical hacking techniques. Based on curricula developed by the authors at major security conferences and colleges, the book features actionable planning and analysis methods as well as practical steps for identifying and combating both targeted and opportunistic attacks. Gray Hat Hacking: The Ethical Hacker's Handbook, Sixth Edition clearly explains the enemy's devious weapons, skills, and tactics and offers field-tested remedies, case studies, and testing labs. You will get complete coverage of Internet of Things, mobile, and Cloud security along with penetration testing, malware analysis, and reverse engineering techniques. State-of-the-art malware, ransomware, and system exploits are thoroughly explained. Fully revised content includes 7 new chapters covering the latest threats Includes proof-of-concept code stored on the GitHub repository Authors train attendees at major security conferences, including RSA, Black Hat, Defcon, and B-Sides

Ver na Amazon
Bloqueador USB de privacidade de porta USB para PC, notebook, bloco de laptop,

Bloqueador USB de privacidade de porta USB para PC, notebook, bloco de laptop,

Proteção de privacidade aprimorada: protege o link de transmissão de dados para evitar roubo de informações, fornecendo proteção de segurança robusta que protege a privacidade do usuário durante transferências de arquivos e garante uma conexão segura para interações de dispositivos sem preocupações em vários ambientes Uso a longo prazo: a camada protetora resistente ao desgaste, combinada com um corpo de metal resistente, oferece gerenciamento de calor confiável e qualidade duradoura durante o uso diário Entrega eficiente de energia: a tecnologia de chip inteligente garante a identificação automática dos requisitos de energia, fornecendo carregamento eficiente alinhando-se com vários protocolos de carregamento rápido para maior conveniência Proteção contra sobrecarga: evitando riscos de sobrecarga, este bloqueador de dados USB protege a vida útil da bateria e garante um desempenho estável, mantendo um fluxo estável de energia para melhorar a longevidade do dispositivo de forma eficaz Prático de transportar: com atenção à portabilidade, este bloqueador de dados USB oferece um design compacto que é leve e fácil de transportar, melhorando a conveniência do usuário e operação eficiente

Ver na Amazon

📩 Newsletter MundiX

Receba novidades de cibersegurança + um checklist de pentest grátis. Sem spam.

Ao assinar você concorda em receber e-mails. Cancele quando quiser.