Estoy usando los ganchos de Linux Security Module para agregar alguna funcionalidad personalizada a la llamada al sistema recv(). Quiero medir la sobrecarga de esta funcionalidad en comparación con la prvine recv(). Escribí un servidor tcp simple con el que corro y sin mi módulo. Este servidor tcp llama a una función recv() 'N' número de veces. Se mide el tiempo necesario para cada recv con algo como:Medición del tiempo de ejecución de una función dentro del kernel de Linux
clock_gettime(before);
recv()
clock_gettime(after);
global_time += after - before.
Al final, imprimo el tiempo promedio para un solo recv() con "global_time/N". Llamemos a esta vez como hora "user_space_avg_recv".
Dentro de mi módulo, quiero colocar funciones de medición de tiempo para calcular el tiempo exacto de ejecución de mi gancho. Intenté 3 métodos.
que utilizan unidades de tiempo de la siguiente manera:
sj = jiffies; my_hook(); ej = jiffies; current->total_oh = ej - sj;
pero veo que no hay diferencia entre SJ y EJ valores. Por lo tanto, total_oh no se modifica.
He usado current_kernel_time() ya que pensé que devuelve el tiempo en nanosegundos. Sin embargo, una vez más, no hubo diferencia en antes y después del tiempo.
Utilicé get_cycles. Imprimo el total de ciclos cuando el proceso finaliza. Sin embargo, cuando convierto los valores de ciclos totales en milisegundos, sale mucho más que el valor "user_space_avg_recv". Esto no tiene sentido ya que el valor medido dentro del núcleo siempre es menor que el valor del tiempo medido desde el espacio del usuario. Esto podría significar que no estoy midiendo con la API correcta o estoy cometiendo un error al convertir el valor de ciclos a milisegundos.
estoy usando básicamente siguiente fórmula para convertir los ciclos de milisegundos:
avg overhead of my hook in milliseconds =
(((cycles/2.99)/10^6)/N)
2,99 porque mi frecuencia de reloj es 2.99Ghz
Algunos puntos:
Mi usuario el programa espacial está vinculado a un único núcleo que usa la afinidad establecida.
estoy usando kernel 2.6.22.14
Para detener núcleo de conmutación de contextos, mientras que dentro de mi gancho, yo uso preempt_disable() y preempt_enable(). Por lo tanto, no contará los tiempos de ejecución de otros hilos del kernel. Incluso entonces, dado que mi gancho usa algo de E/S, mi hilo podría liberar el control voluntariamente o podría ocurrir alguna interrupción que podría aumentar el recuento total de ciclos.
Pregunta: ¿Cómo puedo medir tiempos de ejecución de la función precisa en el interior del núcleo?
Intentar desactivar el cambio de frecuencia en el BIOS y volver a medir con ciclos – osgx