Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-02-2010, 10:41   #1
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
[assembly] syscall

ciao, ho una domanda semplice...

in assembly quando utilizzo le syscall per sistemare gli argomenti in molti casi vedo che devo sistemare questi nei registri, altre volte nello stack.... con push

con che criterio alcune volte nei registri altre nello stack? dipende dalla syscall?
mi chiarite un attimo le idee?

grazie.
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2010, 12:53   #2
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
mi pare di aver capito che se sono in user mode è necessario che io li passi nei registri, invece in kernelmode vanno passati nello stack...

quindi... io posso scrivere un listato assembly dove gli argomenti li passo nello stack?
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2010, 14:39   #3
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Dipende esclusivamente dal sistema operativo e dall'architettura del processore.

Ad esempio, con AmigaOS alle chiamate di sistema si passavano tutti gli argomenti nei registri del 68000 (ne aveva 16).
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2010, 15:04   #4
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
a ecco grazie!

difatti...
sto programmando su un debian... e stavo scrivendo passando gli argomenti nello stack.... li ho sempre passati nei registri... quindi deduco che il codice non funzionerà..... nè?
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2010, 15:21   #5
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Chiaro. Se li aspetta nello stack, vedrai i fuochi d'artificio.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2010, 17:32   #6
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
... ... però trovo esempi dove vengono usati registri e argomenti nello stack, ad esempio questo dovrebbe utilizzare la syscall socketcall che è la numero 102.

Codice:
push	byte	0x0
push	byte	0x1
push	byte	0x2

mov	eax, 	0x66
mov	ebx, 	0x1
mov	ecx, 	esp
int 	0x80
percè ci sono quei push??

se volessi usare i registri la farei così: (perdona la sintassi )

Codice:
movl $0x6, %edx	         // 3° argomento
movl $0x1, %ecx	         // 2° argomento 
movl $0x2, %ebx	         // 1° argomento
mov $0x66, %al		// Sistemo 102 (_NR_socketcall) in AL
int $0x80		// socket()
difatti la mia per ora mi pare che non funziona....
che mi sfugge?
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2010, 18:01   #7
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
a ok, ho capito.... ........ leggersi la doc. serve a qualcosa...

socketcall ha la sintassi seguente:
int socketcall(int call, unsigned long *args);

quindi a seconda di call chiamo la funzione della famiglia che voglio (socket(), bind() ecc...) e gli argomenti me li metto da qualche parte e faccio riferimento ad essi con un puntatore che passo a socketcall().

... dovrebbe essere così... ora provo a riscrivermi il tutto ..... mi confermate?
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 13-02-2010, 00:29   #8
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
ok.... quindi dovrei aver risolto....

mi rimane un solo problema... la syscall dup2()... che non so perchè non ne vuole sapere di andare...

ma non vedo proprio che ci può essere di sbagliato...

questo è il pezzo di codice che mi da problemi:
Codice:
[ .............]
       int $0x80		// accept()

	xorl %ebx, %ebx		// effettuo un controllo sul risultato di accept()
	cmpl %eax, %ebx
	jb end
	movl %eax, %ebx         // Nuovo socket, sarà il 1° argomento di dup2

	xorl %eax, %eax
        movl %edx, %ebx    	// socket
        movb $6, %al	     	// Sistemo 6 (_NR_close) in AL
        int $0x80		// close()

	xorl %eax, %eax		// Azzero EAX
	xorl %ecx, %ecx		// Azzero ECX, il 2° argomento di dup2 (stdin)
	movb $0x3f, %al		// Sistemo 63 (_NR_dup2) in AL
	int $0x80		// dup2()

	xorl %eax, %eax		// Azzero EAX
	incl %ecx		// ora stdout
	movb $0x3f, %al		// Sistemo 63 (_NR_dup2) in AL
	int $0x80		// dup2()

	xorl %eax, %eax		// Azzero EAX
	incl %ecx		// ora stderr
	movb $0x3f, %al		// Sistemo 63 (_NR_dup2) in AL
	int $0x80		// dup2()

	xorl %eax, %eax		//Azzero eax
[......................]
se bypasso le chiamate a dup2 il programma funziona, altrimenti termina inspiegabilmente.... c'è qualcosa che mi impedisce di effettuare queste chiamate?

ci sto impazzendo grazie mille!
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 13-02-2010, 05:12   #9
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Da quel che leggo, dup2 vuole come primo parametro il vecchio fd e come secondo il nuovo fd da utilizzare.

Nel tuo codice vedo che il primo argomento (il vecchio fd) è sempre 63, mentre il secondo (il nuovo fd) è 0, 1 e 1 rispettivamente (quest'ultimo dovrebbe essere 2 per stderr, quindi già qui ci sarebbe un errore).

Non mi suona bene. Esattamente cosa vorresti ottenere con quel pezzo di codice?

Inoltre potresti provare intanto con una sola dup2, e vedere cosa ti restituisce in uscita.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 13-02-2010, 10:43   #10
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
praticamente dovrei redirigere i canali standard di comunicazione sul socket,

dup2 è la syscall numero 63, che infatti metto in AL, non centra nulla con gli argomenti.

Poi il primo argomento è in EBX, che sarebbe il socket ritornato da accept.
E il secondo argomento sono gli fd 0, 1 ,2 stdin, stdout e stderr.

l'equivalente in C:
Codice:
cli=accept(soc,0,0);		//#define __NR_socketcall	102
dup2(cli,0);			//#define __NR_dup2	63
dup2(cli,1);
dup2(cli,2);
ho tolto la close() per ora perchè ho visto che vi era un errore.

ho provato anche ad eliminare le ultime due dup2 ma anche la prima sembra provocare l'errore.

...... ma aspetta! ti sembra corretto il controllo del valore di ritorno di accept?

Ultima modifica di Teo@Unix : 13-02-2010 alle 10:48.
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 13-02-2010, 10:52   #11
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
sembrerebbe sia la accept ora a darmi problemi...

ti posto il codice con la accept:

Codice:
	xorl %eax, %eax		// Azzero EAX
	incl %eax
	pushl %eax		// 1 nello stack
	pushl %edx		// socket
	movl %esp, %ecx
	movb $0x4, %bl		// n° socketcall listen
        movb $0x66, %al         // Sistemo 102 (_NR_socketcall) in AL	
	int $0x80		// listen()

	xorl %eax, %eax		// Azzero...
        xorl %ebx, %ebx
        pushl %eax		// 0 nello stack, 2° arg. di accept()
        pushl %eax		// 0 nello stack, 3° arg. di accept()
	pushl %edx        	// socket, 1° arg.
        movl  %esp, %ecx	// *args
        movb $0x5, %bl     	// n° socketcall accept
        movb $0x66, %al    	// Sistemo 102 (_NR_socketcall) in AL	
        int $0x80		// accept()

	xorl %ebx, %ebx		// effettuo un controllo sul risultato di accept()
	cmpl %eax, %ebx
	jb end
	movl %eax, %ebx         // Nuovo socket, sarà il 1° argomento di dup2

	xorl %eax, %eax		// Azzero EAX
	xorl %ecx, %ecx		// Azzero ECX, il 2° argomento di dup2 (stdin)
	push $0x3f
	pop %eax		// Sistemo 63 (_NR_dup2) in AL
	int $0x80		// dup2()

	xorl %eax, %eax		// Azzero EAX
	incl %ecx		// ora stdout
	push $0x3f
	pop %eax		// Sistemo 63 (_NR_dup2) in AL
	int $0x80		// dup2()

	xorl %eax, %eax		// Azzero EAX
	incl %ecx		// ora stderr
	push $0x3f
	pop %eax		// Sistemo 63 (_NR_dup2) in AL
	int $0x80		// dup2()
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2010, 14:12   #12
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Francamente non riesco a vedere dove potrebbe essere il problema.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2010, 19:48   #13
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
alla fine sono risalito al problema...

era il controllo del valore di ritorno di accept. Non ho capito però esattamente. Come se il salto non fosse corretto, ma non credo sia nemmeno questo perché anche se inteso come salto corto doveva funzionare... fatto sta che ora funziona con questa versione:
Codice:
..............
        xorl %eax, %eax		// Azzero...
        xorl %ebx, %ebx
        pushl %eax		// 0 nello stack, 2° arg. di accept()
        pushl %eax		// 0 nello stack, 3° arg. di accept()
	pushl %edx        	// socket, 1° arg.
        movl  %esp, %ecx	// Posiziono puntatore arg.
        movb $0x5, %bl     	// n° socketcall accept
        movb $0x66, %al    	// Sistemo 102 (_NR_socketcall) in AL	
        int $0x80		// interrupt accept()

	movl %eax, %ebx		// New socket
	
	// int dup2(int oldfd, int newfd);

	xorl %eax, %eax		// Azzero EAX
	xorl %ecx, %ecx		// Azzero ECX, il 2° argomento di dup2 (stdin)
	push $0x3f		//
	pop %eax		// Sistemo 63 (_NR_dup2) in AL
	int $0x80		// interrupt dup2()
.............
grazie. Ciao.
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
Prime Video sotto accusa: doppiaggi anim...
Rivoluzione Linux fra i gamer: nuovo rec...
OnePlus 15R: in attesa dell'arrivo in It...
BIOS schede madri AMD: AGESA 1.2.8.0 in ...
Questa Smart TV LG 65'' QNED 2025 è un b...
PC Desktop con RTX 4060 a un prezzo supe...
Il nuovo iPhone 17e arriverà a in...
POCO anticipa l'arrivo di un nuovo smart...
Ecco la lista delle migliori 32 offerte ...
Intel cambia strategia: cancellato lo sp...
Uno dei più venduti: Lefant M330 ...
Superluna Fredda 2025: oggi l'ultima Lun...
4 idee regalo in sconto su Amazon da pre...
Netflix vuole Warner Bros Discovery: in ...
Meta 'ruba' un altro big ad Apple: arruo...
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: 10:03.


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