[Duda] Estructuras

Iniciado por cpu2, 6 Febrero 2013, 16:56 PM

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

cpu2

Hola

Cuando una función requiere una estructura cargo los valores al stack, y los paso como dirección, pero la pregunta es la siguiente.

Quiero rellenar la estructura tcphdr, el encabezado tcp, pero esta no requiere que la pase a ninguna función, como se hace?

Un saludo.

MCKSys Argentina

MCKSys Argentina

"Si piensas que algo está bien sólo porque todo el mundo lo cree, no estás pensando."


cpu2

¿Pero cómo implemento esa estructura a ASM?

Cómo sabe GAS o GCC que los valores son para esa estructura, porque no requiere pasarla a ninguna función.

Un saludo y gracias.

P.D: No dispongo de include, utilice la directiva pero así no compila.


MCKSys Argentina

En el ejemplo de la pagina, usa esto:


#include <netinet/ip.h> 
#include <netinet/tcp.h>
...
...
/* Cabecera IP */ 
struct iphdr *ip = (struct iphdr *)buffer; 
 
/* Cabecera TCP */ 
struct tcphdr *tcp = (struct tcphdr *)(buffer + sizeof(struct iphdr));
...
...


Ahora, usando Google, llegamos a un .h que contiene una de las structs:

http://freebsd.active-venture.com/FreeBSD-srctree/newsrc/netinet/tcp.h.html

Ahi está definida la estructura tcphdr en C:


struct tcphdr {
u_short th_sport; /* source port */
u_short th_dport; /* destination port */
tcp_seq th_seq; /* sequence number */
tcp_seq th_ack; /* acknowledgement number */
#if BYTE_ORDER == LITTLE_ENDIAN
u_int th_x2:4, /* (unused) */
th_off:4; /* data offset */
#endif
#if BYTE_ORDER == BIG_ENDIAN
u_int th_off:4, /* data offset */
th_x2:4; /* (unused) */
#endif
u_char th_flags;
#define TH_FIN 0x01
#define TH_SYN 0x02
#define TH_RST 0x04
#define TH_PUSH 0x08
#define TH_ACK 0x10
#define TH_URG 0x20
#define TH_ECE 0x40
#define TH_CWR 0x80
#define TH_FLAGS (TH_FIN|TH_SYN|TH_RST|TH_ACK|TH_URG|TH_ECE|TH_CWR)

u_short th_win; /* window */
u_short th_sum; /* checksum */
u_short th_urp; /* urgent pointer */
};


Inicializa todo con ceros y listo (ojo los tamaños).

Saludos!

PD: Otra fuente: http://ranger.uta.edu/~odell/TCP.H

Ten en cuenta que justo despues de la estructura IP viene la TCP (para eso usa el tamaño de la estructura ip con sizeof).
MCKSys Argentina

"Si piensas que algo está bien sólo porque todo el mundo lo cree, no estás pensando."


cpu2

Ya miré las estrucuras, lo que pasa es que no sabia que hacer.

Tengo que hacer todo eso en la sección .data, y luego ir rellenando la estructura no?

Es lo que he visto cuando ago un disassembler.

Se puede hacer todo esto en la pila?

Así fue como lo hice con la sockaddr_in.

Un saludo.

MCKSys Argentina

Claro, siempre y cuando reserves el espacio necesario...
MCKSys Argentina

"Si piensas que algo está bien sólo porque todo el mundo lo cree, no estás pensando."


cpu2

#6
Vale, yo no reserve espacio para la sockaddr_in, bueno tendria que asignar como mucho el tamaño del buffer, que es lo veo en el primer código que me pasaste.

Esto se podría hacer con esas dos?

Código (asm) [Seleccionar]
mov $0x0100007f4cdc0200, %rbx
push %rbx
mov %rsp, %rsi


Eso seria pasar la estructura sockaddr_in ala función bind, connect etc...

Pero hay estaba mi pregunta, tcphdr y iphdr no requieren ser pasadas a ninguna función, como se iba a saber que los datos del stack eran para esas dos estructuras.

Solamente cargo los valores en el stack y ya esta?

La función getsockopt le da la opción al descriptor para que los cabezales se tomen en cuenta.

#define IP_HDRINCL 2    /* int; header is included with data */


Pero eso lleva de nuevo amí pregunta, como sabén que los datos del stack son para esas estrcucturas.

Un saludo.

P.D: Perdona, soy un pesado, pero es que estas cosas no salen en los libros pffff...


fary

Vamos a ver... si una función no va a necesitar una estructura no se escribe esa estructura.. es así de facil, pero no en ensamblador, en cualquier lenguaje.

Cual es tu problema?

un saludo.
Un byte a la izquierda.

cpu2

Cita de: mDrinky en  9 Febrero 2013, 06:17 AM
Vamos a ver... si una función no va a necesitar una estructura no se escribe esa estructura.. es así de facil, pero no en ensamblador, en cualquier lenguaje.

Cual es tu problema?

un saludo.

Mi problema es que quiero cambiar la dirección de origen, y no se como implementarlo en ASM.

Al ser posible como el ejemplo de arriba, que ya veo que a causado más confusión.

Un saludo.

P.D: Un ejemplo me iría de perlas.

fary

A ver si me entero... quieres rellenar tu una estructura a mano envez de que te lo haga una API, no?

Eso se hace mov mov o con push y pop facilmente, ejemplo:

En la sección data:
Código (asm) [Seleccionar]
struct Numeros
    Numero1        dd ?
    Numero2        dd ?
ends

mNumeros        Numeros ?


En la code:

Código (asm) [Seleccionar]
mov eax,1
mov [mNumeros.Numero1],eax
mov eax,2
mov [mNumeros.Numero2],eax


y listo  :xD

Esa era tu duda?

un saludo!


Un byte a la izquierda.