Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-10-2011, 23:50   #1
Emalele1688
Member
 
Iscritto dal: Oct 2009
Messaggi: 157
[C Linux] Implementazione delle chiamate di sistema. Dove sono?

Salve!
Posto un quesito che da quando ho incominciato il corso di Sistemi Operativi all'università mi sta affliggendo.
Spero innanzitutto di essere nella sezione giusta, poichè ero indeciso se postare qui o nella sezione Linux; Arrivo al dunque.
Per farla breve, le chiamate di sistema implementate nelle librerie stdio.h, stdlib.h unistd.h e cosi via, (per esempio malloc, execl, free, exit, printf, scanf ecc...) sono implementate nella source del kernel, o sono implementate nelle librerie standard del C (le glibc per intenderci) utilizzando varie funzioni a livello kernel ?
Lo chiedo perchè mi sto leggendo un po di sorgenti del kernel Linux (nulla di complicato insomma hahahahaha). Fino ad oggi io lo solo patchato, configurato e compilato, mai sceso così nel dettaglio ma lo trovo molto interessante.
Grazie a chi avrà la pazienza di rispondermi e schiarirmi le idee...
Emalele1688 è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2011, 01:09   #2
LMCH
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 6286
Quote:
Originariamente inviato da Emalele1688 Guarda i messaggi
Per farla breve, le chiamate di sistema implementate nelle librerie stdio.h, stdlib.h unistd.h e cosi via, (per esempio malloc, execl, free, exit, printf, scanf ecc...) sono implementate nella source del kernel, o sono implementate nelle librerie standard del C (le glibc per intenderci) utilizzando varie funzioni a livello kernel ?
Queste sono le funzioni implementate come system call:
http://www.kernel.org/doc/man-pages/...yscalls.2.html
(guarda un giu nella pagina per vedere la lista delle funzioni)

Nota che persino le "vere" system call non vengono chiamate direttamente ma tramite dei wrapper definiti in glibc (o libreria equivalente nel caso di certi sistemi embedded).

Uno dei motivi principali per cui si usano i wrapper è perché per fare una syscall non si esegue un istruzione "call" ma una "int 80h" (interrupt software 80 esadecimale) con parametri passati direttamente sui registri interni e quindi il wrapper "converte il formato" rispetto a quello usato dal compilatore C/C++, l'aggravio del passaggio attraverso il wrapper è comunque trascurabile perchè la int 80h esegue la transizione i modalità kernel (che già di suo è bella pesante).
LMCH è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2011, 08:50   #3
DeltaDirac
Senior Member
 
L'Avatar di DeltaDirac
 
Iscritto dal: Jan 2007
Città: Firenze
Messaggi: 2906
Quote:
Originariamente inviato da Emalele1688 Guarda i messaggi
Salve!
Posto un quesito che da quando ho incominciato il corso di Sistemi Operativi all'università mi sta affliggendo...
Ciao,

ti consiglio, se ancora non l'hai fatto, di leggere il mitico Understanding the Linux Kernel di Cesati - Bovet. Ho dato Architetture di Calcolatori I proprio con il dr. Cesati e devo dire che il testo è stato un manna dal cielo
__________________

Alla povertà mancano molte cose, all'avarizia tutte.
DeltaDirac è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2011, 09:30   #4
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Quote:
Originariamente inviato da Emalele1688 Guarda i messaggi
Salve!
Posto un quesito che da quando ho incominciato il corso di Sistemi Operativi all'università mi sta affliggendo.
Spero innanzitutto di essere nella sezione giusta, poichè ero indeciso se postare qui o nella sezione Linux; Arrivo al dunque.
Per farla breve, le chiamate di sistema implementate nelle librerie stdio.h, stdlib.h unistd.h e cosi via, (per esempio malloc, execl, free, exit, printf, scanf ecc...) sono implementate nella source del kernel, o sono implementate nelle librerie standard del C (le glibc per intenderci) utilizzando varie funzioni a livello kernel ?
Lo chiedo perchè mi sto leggendo un po di sorgenti del kernel Linux (nulla di complicato insomma hahahahaha). Fino ad oggi io lo solo patchato, configurato e compilato, mai sceso così nel dettaglio ma lo trovo molto interessante.
Grazie a chi avrà la pazienza di rispondermi e schiarirmi le idee...
printf, malloc, free, scanf NON sono syscall. Sono funzioni della libreria standard del C e sono implementate nelle GLIBC.

execve (e solo execve) è implementata come syscall direttamente nel kernel. C'è un wrapper nelle glibc che non fa altro che ,quando chiamato, chiama la syscall del kernel. Le altre funzioni (execl, execv, execle ...etc) sono implementate attraverso execve.
exit anche è una syscall ...

Insomma, molte delle funzioni delle GLIBC non sono syscall ovviamente, ma alcune sono direttamente implementate come syscall (exit, execve, open, close ... ed altre)

In questo file c'è la lista di tutte le syscall:
linux/arch/x86/kernel/syscall_table.S ordinate numericamente.

Ciao
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2011, 11:02   #5
Emalele1688
Member
 
Iscritto dal: Oct 2009
Messaggi: 157
Quote:
ti consiglio, se ancora non l'hai fatto, di leggere il mitico Understanding the Linux Kernel di Cesati - Bovet. Ho dato Architetture di Calcolatori I proprio con il dr. Cesati e devo dire che il testo è stato un manna dal cielo
Si ci avevo già pensato, un bel mattone che comprerò presto

Dubbio eliminato.
Ultima cosa.
Ho letto nella lista la presenza di fork(). Quindi immagino che fork sia una SYSCALL, oppure mi sbaglio ed è sempre implementata nelle librerie standard?
Emalele1688 è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2011, 10:31   #6
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Sì, fork() è una system call, è inclusa nella tabella. Puoi trovare la lista completa delle system call nel file: syscall_table.S ("o simile") all'interno dei tuoi sorgenti del kernel.
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Un gruppo di ladri ha usato Google Maps ...
Apple non si fida di Samsung per la real...
Windows 11: un nuovo driver nativo mette...
Vi hanno regalato buoni Amazon? Intanto ...
Via acari, polvere e sporco da materassi...
Cuffie Beats in super offerta su Amazon,...
Xbox Cloud Gaming arriva su Amazon Fire ...
Un blackout a San Francisco manda in til...
Windows 11 è diventato più...
Apple cambia strategia a causa della cri...
007 First Light: uscita rimandata di due...
Samsung Galaxy A37 e A57: il comparto fo...
DAZN lancia la sua offerta di Natale: My...
Gigabyte fa marcia indietro? Sparito il ...
Alcuni rivenditori giapponesi bloccano l...
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: 02:52.


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