Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-11-2007, 12:52   #1
agus83
Member
 
Iscritto dal: Oct 2007
Messaggi: 48
questione di dati (in C)

Ciao a Tutti,
vi pongo un mio problema su un programma in linguaggio C.
Ecco la situazione:
una funzione riceve un pacchetto (nel caso SRTP) tramite * void
-> void funzione(void *pkt)

Questo pacchetto è stato creato facendo memcpy di diversi campi (stringhe,interi). Non è dunque una struttura vera e propria,ma una serie di byte. Io dovrei prendere il valore di un determinato campo, che nello specifico è un unsigned int quando è stato copiato. So le posizioni di inizio dei singolo campi (#byte),ma nn so come ricavare il numero e porlo nella mia variabile. Grazie Mille
agus83 è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 14:25   #2
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
se ho capito bene:
Codice:
memcpy( &Variabile, buffer, sizeof(Variabile) );
dove buffer è ovviamente la posizione del singolo campo
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 14:41   #3
agus83
Member
 
Iscritto dal: Oct 2007
Messaggi: 48
esatto,cosi avevo fatto io (sommando a buffer l'offest necessario). Purtroppo pero' sembra non funzionare...
Ho fatto delle prove,ma inconcludenti->

memcpy(pkt,stringa,sizeof(stringa));
printf("%s ",pkt,sizeof(stringa)); -> LO VISUALIZZA PERFETTO
memcpy(pkt+sizeof(stringa),&(codice),sizeof(codice)); -> 'CODICE' è UN INT

memcpy(&index,pkt+sizeof(stringa),sizeof(index));
printf(" ->%d\n",index); -> NULLA PURTROPPO.


Help Me!!!
agus83 è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 14:49   #4
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
c'è un vero casino nel tuo codice ...

Codice:
memcpy(pkt,stringa,sizeof(stringa));
la destinazione è a sinistra (come in tutte le funzioni standard del C)
quindi copi da stringa a pkt per lunghezza stringa ?

Codice:
printf("%s ",pkt,sizeof(stringa)); -> LO VISUALIZZA PERFETTO
passi 2 parametri alla printf ma ne visualizzi solo uno

Codice:
memcpy(pkt+sizeof(stringa),&(codice),sizeof(codice)); -> 'CODICE' è UN INT
quà si capisce che hai invertito dest e source. Codice va a sinistra perchè è la destinazione
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 15:23   #5
agus83
Member
 
Iscritto dal: Oct 2007
Messaggi: 48
Allora,
con -> memcpy(pkt,stringa,sizeof(stringa)); voglio appunto avere come destinazione pkt.
Nella printf avevo dimenticato di calcellare un pezzetto :P
printf("%s ",pkt); -> LO VISUALIZZA PERFETTO
Al pkt aggiungo anche un'intero oltre che alla stringa gia presente
memcpy(pkt+sizeof(stringa),&(codice),sizeof(codice));
Adesso provo a mettere l'intero che ho copiato su un'altra variabile per vedere se riesco a riprendere il valore
memcpy(&index,pkt+sizeof(stringa),sizeof(index));
Verifico.....
printf(" ->%d\n",index); -> NULLA PURTROPPO.
agus83 è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 15:27   #6
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Sembra giusto quindi metti tutto il codice altrimenti non si riesce a capire bene

che tipo di dato è pkt ?
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 15:41   #7
agus83
Member
 
Iscritto dal: Oct 2007
Messaggi: 48
Hai ragione,avrei dovuto farlo prima...sorry
ecco il file mini di prova che ho fatto

main()
{
unsigned char stringa[] = "stringa di prova";
unsigned char pkt[64];
unsigned char *confronto = NULL;
int index;
int i;
int codice;

codice=547;

memcpy(pkt,stringa,sizeof(stringa));
printf("%s \n",pkt);
memcpy(pkt+sizeof(stringa),&(codice),sizeof(codice));
printf("%s \n",pkt);
memcpy(pkt+sizeof(codice),stringa,sizeof(stringa));
memcpy(&index,pkt+sizeof(stringa),sizeof(index));
printf(" -> %d \n",index);

return 0;
}

Purtoppo 'index' alla fine non contiene il valore di 'codice'
agus83 è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 15:46   #8
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
c'è una linea di troppo, adesso funzica

Codice:
main()
{
	unsigned char stringa[] = "stringa di prova";
	unsigned char pkt[64];
	unsigned char *confronto = NULL;	
	int index;
	int i;
	int codice;

	codice=547;

	memcpy(pkt,stringa,sizeof(stringa));
	printf("%s \n",pkt);
	memcpy(pkt+sizeof(stringa),&(codice),sizeof(codice));
	printf("%s \n",pkt);
	//memcpy(pkt+sizeof(codice),stringa,sizeof(stringa));
	memcpy(&index,pkt+sizeof(stringa),sizeof(index));
	printf(" -> %d \n",index);

	return 0;
}
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 15:53   #9
agus83
Member
 
Iscritto dal: Oct 2007
Messaggi: 48
Grande,è vero!!!!!!!!!!!!!!!!!!!!!!!!!!!
Ma perchè se aggiungo altra roba al pacchetto non riesco a estrapolare lo stesso il valore con la memcpy e la dimensione del valore??? mmmhhh...in teoria non dovrebbe cambiare....nn so'...
agus83 è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 16:04   #10
agus83
Member
 
Iscritto dal: Oct 2007
Messaggi: 48
risolto,sono uno scemo avevo sbagliato l'offset :P
Grazie Mille per l'aiuto!!!!!!!
agus83 è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2007, 16:07   #11
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Quote:
Originariamente inviato da agus83 Guarda i messaggi
risolto,sono uno scemo avevo sbagliato l'offset :P
Grazie Mille per l'aiuto!!!!!!!
vedo che hai capito da solo.

Prego.

Se posso consigliarti: soprattutto in C (ma vale sempre) devi avere sotto controllo qualsiasi istruzione
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
Una denuncia getta ombre sulle batterie ...
DJI Avata 2 Fly Smart Combo a 526€: il d...
Alla guida della nuova auto elettrica ci...
GeForce RTX 3060 12 GB a giugno di nuovo...
Apple Music sarà sponsor ufficiale di Po...
The Mandalorian & Grogu: trailer fin...
Fedeltà record: Apple blinda gli utenti,...
Volkswagen ID.3 Neo: fino a 630 km di au...
GPU-Z mette i dati personali a rischio? ...
La PS6 potrebbe essere retrocompatibile ...
Amazfit Cheetah 2 Pro arriva in Italia: ...
Duolingo ammette l'errore dopo un anno: ...
Samsung Galaxy Tab S10 Lite a 249€: il t...
Samsung Micro RGB: la rivoluzione del co...
Sempre più autonomia per gli smar...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 16:40.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v