Ciclos requeridos para cada instrucción

Iniciado por 0xFer, 27 Julio 2015, 23:11 PM

0 Miembros y 1 Visitante están viendo este tema.

0xFer

Quisiera saber si hay alguna manera de saber cuántos ciclos de cpu requieren todas y cada una de las instrucciones de intel ASM.
Es más que nada para saber cuál instrucción usar, porque casi siempre hay varias formas de hacer lo mismo.

Gracias.
Código (java) [Seleccionar]
int getRandomNumber(){
    return 4; //chosen by fair dice roll
              //guaranteed to be random
}

cpu2

Hay una aplicacion creada por un admin de Masm32, si me acuerdo como se llama te la paso, de mientras puedes mirar un paper de Agner Fog.

Lo encuentras facil, hay bastantes Arch.

Un saludo.

0xFer

Código (java) [Seleccionar]
int getRandomNumber(){
    return 4; //chosen by fair dice roll
              //guaranteed to be random
}

x64core

Diria que la mejor informacion podes encontrarle en los volumenes de Intel o AMD:
http://www.intel.com/content/www/us/en/architecture-and-technology/64-ia-32-architectures-optimization-manual.html
Alfinal en los apendices.

cpu2, Yo no recuerdo/ví que Hutch haya escrito tal código o aplicación porque no creo que se pueda escribir tal cosa, a menos que estemos hablando de calcular el tiempo requerido por unas instrucciones.

cpu2

Cita de: x64core en 31 Julio 2015, 18:48 PM
Diria que la mejor informacion podes encontrarle en los volumenes de Intel o AMD:
http://www.intel.com/content/www/us/en/architecture-and-technology/64-ia-32-architectures-optimization-manual.html
Alfinal en los apendices.

cpu2, Yo no recuerdo/ví que Hutch haya escrito tal código o aplicación porque no creo que se pueda escribir tal cosa, a menos que estemos hablando de calcular el tiempo requerido por unas instrucciones.


Si me acuerdo de ese tema, tu me diste el enlace de mas32 era de un admin del foro que tenia el soft para calcular los tiempos, supongo que le ayudara en algo, pero perdí el link...

Un saludo.

P.D: @0xFer supongo que en contraste el pdf de Agner no ? Esta muy bien bastante trabajado.

x64core

#5
Sí, el código de MichaelW era para calcular el tiempo requerido para una especifica pieza de código, ya que el problema es especifico de architectura lo único que se me ocurre que podria contener la informacion de cada instruccion es alguna manera indocumentada usando CPUID aunque lo dudo, ya se ha hecho ingenieria inversa en el Microcode del 386 y hasta donde sé no hay tal informacion.

0xFer

¡Yep!, los contré y son 5, gracias por la info :)
Código (java) [Seleccionar]
int getRandomNumber(){
    return 4; //chosen by fair dice roll
              //guaranteed to be random
}

_Enko

Hasta donde tengo entendido Intel y AMD tambien cuando mejoran los procesadores no solo les agregan mas núcleos o mas Ghz.  Tambien optimizan la cantidad de ciclos reloj que necesitan algunas instrucciones.
De manera que un ADD en un pentium core 2 duo  va tomar mas ciclos de reloj que digamos un i3 moderno.

Asi que  si bien se puede hacer una tabla relativa de que instruccion toma mas ciclos que otra, es dificil contarlos ya que dependera de la arquitectura del procesador.

Saludos.