Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-07-2008, 15:09   #1
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6868
[C] output system function

Ciao,
come posso fare per redirigere ad esempio in una stringa un comando eseguito con system() ?
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2008, 15:14   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
s/o?
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2008, 15:16   #3
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6868
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
s/o?
Linux
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2008, 15:19   #4
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Con system non è semplice (anche se c'è un modo contorto). Meglio usare la popen.
Usare direttamente fork+dup(stdin/out/err su un tuo pipe)+exec ti da la maggiore flessibilità, se popen non ti basta.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2008, 15:28   #5
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6868
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Con system non è semplice (anche se c'è un modo contorto). Meglio usare la popen.
Usare direttamente fork+dup(stdin/out/err su un tuo pipe)+exec ti da la maggiore flessibilità, se popen non ti basta.
Perfetto, grazie
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2008, 15:40   #6
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Per curiosità, questo è il crapposauro necessario per la system
Codice:
#define _GNU_SOURCE
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/mman.h>

int main(void)
{
	char buf[64];
	int fd;
	char *my_str;
	off_t sz;

	sprintf(buf, "/tmp/__tmpXXXXXX");
	fd = mkstemp(buf);
	unlink(buf);

	sprintf(buf, "ls >&%d", fd); // !!!
	system(buf);

	sz = lseek(fd, 0, SEEK_CUR);
	my_str = mmap(NULL, sz, PROT_READ, MAP_SHARED, fd, 0);

	close(fd);

	dprintf(fileno(stdout), "Output del comando: ");
	write(fileno(stdout), my_str, sz);
	dprintf(fileno(stdout), "\n");

	munmap(my_str, sz);

	return 0;
}
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2008, 08:59   #7
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6868
Grazie! Senti, ma per caso sto sbagliando l'uso della popen? Mi va in SIGFAULT

Codice:
   char comm[256];
   int dim_input_file
   strcpy(comm, "ls -lrt /home/ | grep file.trc | awk '{print $5}'");
   char out[256];  
   
  FILE* file_info = popen(comm , "r");

  while (fgets( out, sizeof(out), file_info));
   {
   dim_input_file = atoi(out); 
                

    }
il puntatore restituito dalla popen non è nullo, quindi ritorna bene(penso). Il comando che gli passo è corretto, quindi boh.

In alcuni sistemi va in altri no. Ovviamente lo stesso file è presente in tutti i sistemi.

Ultima modifica di Unrue : 18-07-2008 alle 09:10.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2008, 13:42   #8
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6868
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Per curiosità, questo è il crapposauro necessario per la system
Codice:
#define _GNU_SOURCE
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/mman.h>

int main(void)
{
	char buf[64];
	int fd;
	char *my_str;
	off_t sz;

	sprintf(buf, "/tmp/__tmpXXXXXX");
	fd = mkstemp(buf);
	unlink(buf);

	sprintf(buf, "ls >&%d", fd); // !!!
	system(buf);

	sz = lseek(fd, 0, SEEK_CUR);
	my_str = mmap(NULL, sz, PROT_READ, MAP_SHARED, fd, 0);

	close(fd);

	dprintf(fileno(stdout), "Output del comando: ");
	write(fileno(stdout), my_str, sz);
	dprintf(fileno(stdout), "\n");

	munmap(my_str, sz);

	return 0;
}
Ciao, mi potresti spiegare questa riga:
Codice:
write(fileno(stdout), my_str, sz);
Non capisco, nel file aperto e mappato in memoria non c'è nulla ed il contenuto lo scrivi sullo standard output Pensavo fosse il contrario. Poi, se tento di accedere al primo byte di mystr prima di unmap mi va in sigfault.

Ultima modifica di Unrue : 18-07-2008 alle 14:23.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2008, 15:28   #9
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Ciao, mi potresti spiegare questa riga:
Non mi dire che hai VERAMENTE utilizzato quella roba
Quote:
Codice:
write(fileno(stdout), my_str, sz);
Non capisco, nel file aperto e mappato in memoria non c'è nulla ed il contenuto lo scrivi sullo standard output
Il file viene riempito dal comando eseguito tramite system, la cui stdout viene reinviata sul file descriptor del file che ho aperto.
I file descriptor aperti vengono preservati tali dopo fork+exec (a meno che non imposti il flag "close on exec"). Questo è il trucco che ho usato.

Quote:
Poi, se tento di accedere al primo byte di mystr prima di unmap mi va in sigfault.
Controlla i valori di ritorno delle funzioni, non ho messo alcun controllo.
Controlla inoltre che sz>0, altrimenti vai di sicuro in segvault in quanto la mappa è di dimensione 0 (come ci vai di sicuro se tenti di scrivere sulla regione, visto che è senza PROT_WRITE).
Occhio inoltre che la stringa non termina con '\0' (per questo ho usato la write e non la dprintf o printf!)
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12

Ultima modifica di ilsensine : 18-07-2008 alle 15:37.
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2008, 15:35   #10
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Senti, ma per caso sto sbagliando l'uso della popen? Mi va in SIGFAULT
Togli il ";" alla fine della riga con il while, animale
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2008, 16:28   #11
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6868
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Togli il ";" alla fine della riga con il while, animale
Beh, ma non dovrebbe comunque generare un SIGFAULT.

Comunque il problema non è lì. Era prima nel codice, ma per qualche strano motivo schiantava solo là. Mah.
Unrue è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
CAS Space ha lanciato per la prima volta...
Qualcomm boccia Samsung: i futuri chip S...
Il razzo spaziale cinese Tianlong-3 di S...
Samsung cambia i piani: aumenta la produ...
TSMC non si ferma più: fatturato ...
Xiaomi porta in Italia il nuovo Redmi A7...
Mercato smartphone: Q1 2026 positivo (+1...
YouTube punta sull'AI: gli utenti potran...
Il prossimo chip a 2 nm di Samsung punte...
Due smartphone REDMAGIC sono stati rimos...
La beta della One UI 8.5 è ora di...
Addio al Pannello di Controllo di Window...
Il chip N1 di NVIDIA per i laptop del fu...
YouTube Premium costerà di pi&ugr...
I nuovi Samsung Galaxy A57 5G e A37 5G a...
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: 00:13.


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