Crear código nativo con Mono

Iniciado por Casidiablo, 26 Julio 2006, 19:36 PM

0 Miembros y 3 Visitantes están viendo este tema.

Casidiablo


Si, ya sé que para crear codigo nativo se utiliza la bandera --aot. Al utilizar esto en linux en un archivo llamado programa.exe (por ejemplo), se crea un archivo llamado programa.exe.so. Pero vaya sorpresa me llevo, al darme cuenta que al intentar ejecutarlo me sale el siguiente error:


Violación de segmento

Pero, ¿què coñ0s es eso? Analicé el archivo con el comando file, y todo normal, el archivo programa.exe.so es un ELF de 32 bits. Inclusive, miré su código en assembler con el comando objdump, y parece estar bien.

Intenté probarlo en windows, y nisiquiera  puedo crear el archivo que estaría supuestamente en código nativo.

Espero vuestra ayuda....

JuanK_Solocodigo

#1
Aunque este en codigo nativo debes ejecutarlo usando
mono miprograma.

Por otro lado en windows la opcion no esta incuida en el compilador  sino que es una utilidad aparte que se usa por la consola de comandos llamada ngen.

ngen nombreensamblado
Juan Carlos Ruiz
Ingeniero de Sistemas
Mi Blog Técnico

JuanK_Solocodigo

hasta donde entiendo la opcion de codigo nativo no implica que el programa cambie la manera en que se ejecuta, es decir tambien requiere que se use como intermediario el framework puesto que aun depende de sus servicios como por ejemplo el GC.

Lo que realmente hace esta utilidad es llevar a cabo el proceso que hace el JIT  por anticipado, lo cual acelera el tiempo de carga de la aplicacion ya que esta previamente convertida en codigo nativo.

Recordemos que en .NET el codigo se encuentra en estado de compilacion intermedia y una vez se ejecuta se termina la compilacion del codigo, sin embargo esta compilacion no es total y se va pasando por el JIT solo lo que se va necesitando, por ello la primera vez que ase accede a una funcion o modulo se demora un poco más mientras se realiza el proceso de compilacion final, pero ya una vez sucede esto la función se ejecuta en codigo nativo y es identica en rendimiento que un programa hecho en lenguaje nativo directamente; asi que la utilidad de convertir a codigo nativo lo que hace es terminar el proceso de compilacion del ensamblado de tal froma que cuando se use el programa no existan tiempos de carga porque ya esta todo convertido a codigo nativo. ;D

La desventaja de esto es que el proceso que convierte todo a codigo nativo no es tan eficiente como el JIT, ya que el JIT genera codigo nativo de acuerdo a una situacion particular de la maquina incluso dependiendo de en un momento determinado en el consumo de recursos.

La opcion de generar el ensamblado en codigo nativo tambien tiene el problema que al llevar tu ejecutab le o tus librerias .net a otra plataforma no van a funcionar por lo cual se recomienda hacer algo como lo que hace el instalador de Sharp develop, es decir una vez copiados o instalados los ensamblados en codigo CIL se ejecuta un batch que inicia el proceso de generacion de codigo nativo utilizando ngen.
Juan Carlos Ruiz
Ingeniero de Sistemas
Mi Blog Técnico

Casidiablo

Ok, gracias. Ahora lo entiendo.... gracias por la aclaración; desafortunadamente, para mi, en la documentación de mono no me decían eso... talvez no supe leer (todo en inglés).

Gracias, y saludos!!!

JuanK_Solocodigo

#4
en la documentacion de microsoft si esta, mono no ha hecho documentacion al respecto pero en el estandart del CIL debe de estar.
Juan Carlos Ruiz
Ingeniero de Sistemas
Mi Blog Técnico

Casidiablo

El problema es que solo he trasteado con la de Mono. ¿olvidé decir gracias?

JuanK_Solocodigo

Cita de: Casidiablo en 27 Julio 2006, 23:26 PM
Ok, gracias. Ahora lo entiendo.... gracias por la aclaración; desafortunadamente, para mi, en la documentación de mono no me decían eso... talvez no supe leer (todo en inglés).

Gracias, y saludos!!!


No, ahí estaba.  :D ;D ;)
Juan Carlos Ruiz
Ingeniero de Sistemas
Mi Blog Técnico

Casidiablo

Nada, después de intentar lo leído anteriormente me sigue pasando lo mismo... explico mis pasos detalladamente:

Haber, tengo el archivo en C# (*.cs):


casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ ls
Ejemplo.cs
casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ cat Ejemplo.cs
using System;
public class Ejemplo
{
        static int a, b, c;
        public static void Main(string[] args)
        {
                a = 25;
                b = a * 2;
                c = b * b + a;
                Console.WriteLine ("Hello parce!!!");
                Console.WriteLine ("El valor de A, B y C es: "+a+" "+b+" "+c);
                Console.WriteLine ("A + B + C es "+(a+b+c));
                Console.WriteLine ("Fin de la putada");
        }
}


Despues de ello compilo el archivo con el comando mcs...

casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ mcs Ejemplo.cs
casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ ls
Ejemplo.cs  Ejemplo.exe


Lo ejecuto con el comando mono:

casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ mono Ejemplo.exe
Hello parce!!!
El valor de A, B y C es: 25 50 2525
A + B + C es 2600
Fin de la putada


Lo "traduzco al codigo nativo" utilizando el falg --aot.

casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ mono --aot Ejemplo.exe
Mono Ahead of Time compiler - compiling assembly /home/casidiablo/fuentes/csharp/Ejemplo1/Ejemplo.exe
Code: 419 Info: 148 Ex Info: 9 Class Info: 30 GOT: 156
Executing the native assembler: as /tmp/mono_aot_zZxuHc -o /tmp/mono_aot_zZxuHc.o
Executing the native linker: ld -shared -o /home/casidiablo/fuentes/csharp/Ejemplo1/Ejemplo.exe.so /tmp/mono_aot_zZxuHc.o
Compiled 2 out of 2 methods (100%)
0 methods contain absolute addresses (0%)
0 methods contain wrapper references (0%)
0 methods contain lmf pointers (0%)
0 methods have other problems (0%)
AOT RESULT 0
casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ ls
Ejemplo.cs  Ejemplo.exe  Ejemplo.exe.so


Pero al intentar correr el programa con mono, o con el comando ./ me sale:

casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ mono Ejemplo.exe.so
cannot open assembly Ejemplo.exe.so
casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$./Ejemplo.exe.so
Violación de Segmento


Analizo el archivo que es, supuestamente, código nativo, con el comando file y aparentemente es un ejecutable común y corriente:

casidiablo@casidiablo:~/fuentes/csharp/Ejemplo1$ file Ejemplo.exe.so
Ejemplo.exe.so: ELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), not stripped


Y vuelvo a la pregunta inicial... ¿como le hago?

Casidiablo


JuanK_Solocodigo

ya le diste el atributo de ejecucion al ejecutable creado?

en todo caso? par
Juan Carlos Ruiz
Ingeniero de Sistemas
Mi Blog Técnico