Aquí está el problema en el que estoy trabajando:
El problema:" Una estación de trabajo de alta velocidad tiene palabras de 64 bits y direcciones de 64 bits con resolución de dirección a nivel de bytes. Suponiendo una caché asignada directamente con 8192 líneas de 64 bytes, ¿cuántos bits hay en cada uno de los siguientes campos de dirección para la caché? 1) byte 2) Índice 3) ¿Etiqueta?"
Primero definí los términos de este problema y utilicé la otra pregunta sobre caché asignada directa de Stack Overflow y mi otra pregunta sobreAlmacenamiento en cachécomo referencias (corríjame si alguna de mis definiciones es incorrecta)
- Palabras de 64 bits: el procesador puede procesar 64 bits a la vez
- Direcciones de 64 bits con direccionamiento a nivel de bytes: hay 2^64 ubicaciones de memoria en la RAM y cada ubicación de memoria almacena un byte.
- Cachees de alta velocidad y está dividido en líneas de caché
- Caché asignada directamentees donde un bloque de memoria RAM se asigna a una línea de caché (no estoy seguro del significado de esto
Ahora trabajandoCaché mapeado directocomo una referencia
- Byte: debido a que una línea de bytes se compone de 64 bytes, necesita 6 bits para identificar un solo byte dentro de esa línea de bytes.
- Índice: debido a que hay 8192 "filas" de líneas de bytes, necesita al menos 10 bits para identificar cada fila
Ahora aquí está la parte en la que estoy estancado. El otrocorreodijo "Todos los demás bits son bits TAG". mientras esta conferenciacorreodecía "Cada línea tiene una etiqueta que indica la dirección en M desde la cual se ha copiado la línea". Supongo que M significa RAM.
Entonces aquí, todos los demás bits serían 64 - 6 - 10 = 48 bits. ¿Pero no necesitarías los 64 bits del TAG para indicar de qué ubicación de memoria en la RAM provienen los datos del caché? ¿Alguien puede aclarar la confusión que tengo aquí?