Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Basato su piattaforma Qualcomm Snapdragon X Plus a 8 core, il nuovo Microsoft Surface Pro 12 è un notebook 2 in 1 molto compatto che punta sulla facilità di trasporto, sulla flessibilità d'uso nelle differenti configurazioni, sul funzionamento senza ventola e sull'ampia autonomia lontano dalla presa di corrente
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Il REDMAGIC Astra Gaming Tablet rappresenta una rivoluzione nel gaming portatile, combinando un display OLED da 9,06 pollici a 165Hz con il potente Snapdragon 8 Elite e un innovativo sistema di raffreddamento Liquid Metal 2.0 in un form factor compatto da 370 grammi. Si posiziona come il tablet gaming più completo della categoria, offrendo un'esperienza di gioco senza compromessi in mobilità.
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese di utilizzo intensivo e l'analisi di oltre 50 scatti, l'articolo offre una panoramica approfondita di Nintendo Switch 2. Vengono esaminate le caratteristiche che la definiscono, con un focus sulle nuove funzionalità e un riepilogo dettagliato delle specifiche tecniche che ne determinano le prestazioni
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-11-2020, 13:48   #1
zabnicola
Member
 
Iscritto dal: Nov 2020
Messaggi: 75
setup hardware di un calcolatore elettronico

sono un studente, sto studiando sistemi operativi.
Per capire di piu sui sistemi operativi cerco di realizzare un progetto.
Mi piacerebbe provare a scrivere un piccolo kernel fino al device manager.
Non ho mai lavorato nel settore elettronico, solo in ambito database e via dicendo.
Il mio obiettivo non è scrivere l'intero sistema operativo ma con la teoria studiata per l'esame saper leggere un codice sorgente nelle sue parti linux/openbsd e vederlo nella pratica funzionare.
Il progetto non parte perchè non trovo una libreria che mi simuli delle funzioni analoghe al BIOS implementate in C o Rust che mi visualizza i dati riguardo la scheda madre di cui è fatto il calcolatore: dimensione memoria centrale e dei dischi rigidi, schede video, processore e periferiche mouse e tastiera.

Non trovo nello specifico il codice sorgente di linux kernel oppure openbsd kernel di inizializzazione.
Qualcuno di voi lavorando nel settore firmware/sistemi ha avuto a che fare con inizializzazioni e setup? saprebbe indicarmi del materiale piu dettagliato su cui guardare?

Fino ad ora ho guardato
https://x0rg.github.io/CPU-X/
https://github.com/ThePhD/infoware

ma usano windows.h, utsnames.h and dmidecode.h.E' ok ma non mi è chiaro come i file .c corrispondenti mi restituiscono le informazioni sul processore e sul mouse.

Ultima modifica di zabnicola : 12-11-2020 alle 13:50. Motivo: grassetto alcune frasi per evidenziare la richiesta.
zabnicola è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2020, 21:10   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12814
Ciao e benvenuto!

Quote:
Originariamente inviato da zabnicola
Il mio obiettivo non è scrivere l'intero sistema operativo ma con la teoria studiata per l'esame saper leggere un codice sorgente nelle sue parti linux/openbsd e vederlo nella pratica funzionare.
Hai già finito il corso? Dove siete arrivati? State lavorando solo sulla teoria o fate anche programmazione? Da quello che dici immagino stiate lavorando su sistemi operativi POSIX.

Come stai messo a linguaggio C e ad assembly?

Senza rispondere a queste domande è difficile aiutarti in concreto.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 14-11-2020, 08:09   #3
zabnicola
Member
 
Iscritto dal: Nov 2020
Messaggi: 75
Il corso si l'ho completato. conosco alla base tutti gli argomenti trattati.
La teoria del corso copre i principali argomenti come
comunicazione, sincronizzazione,schedulazione tra/di processi,
tecniche di livello della memoria centrale,
memoria virtuale, gestione dell ingresso uscita.
Il linguaggio C lo conosco abbastanza. Nel corso l'argomento avvio e generazione di un sistema operativo non è spiegato in dettaglio ma è superficiale per via del tempo.
L'assembly non lo conosco bene, se non qualcosa per sapere di cosa si tratta.
Stavo guardando bsd e linux come sistemi operativi.
Nei sorgenti di linux ho trovato arch_setup e il richiamo a print_cpu_info che inizializza una struttura dati con le informazioni del processore e pensavo di provarle includendole da sole in un modulo del kernel fatto apposta per quelle.

Ultima modifica di zabnicola : 14-11-2020 alle 09:22.
zabnicola è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2020, 10:26   #4
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12814
Quote:
Originariamente inviato da zabnicola Guarda i messaggi
Il corso si l'ho completato. conosco alla base tutti gli argomenti trattati.
La teoria del corso copre i principali argomenti come
comunicazione, sincronizzazione,schedulazione tra/di processi,
tecniche di livello della memoria centrale,
memoria virtuale, gestione dell ingresso uscita.
Il linguaggio C lo conosco abbastanza. Nel corso l'argomento avvio e generazione di un sistema operativo non è spiegato in dettaglio ma è superficiale per via del tempo.
L'assembly non lo conosco bene, se non qualcosa per sapere di cosa si tratta.
Stavo guardando bsd e linux come sistemi operativi.
Nei sorgenti di linux ho trovato arch_setup e il richiamo a print_cpu_info che inizializza una struttura dati con le informazioni del processore e pensavo di provarle includendole da sole in un modulo del kernel fatto apposta per quelle.
Se riesci a leggere (e scrivere) il codice del kernel già è ottima cosa .

Tieni presente comunque che ci sono molti dettagli di basso livello che dipendono dal tipo di processore utilizzato e dal bios e questi sono tipicamente punti in cui è necessario conoscere l'assembly del processore utilizzato.

In Linux le funzioni di alto livello si poggiano su funzioni specifiche scritte per l'architettura del processore utilizzato (tutti i file dipendenti dall'architettura sono nella cartella "arch").

Ad esempio l'inizializzazione del processore e il setup dello stack per poi saltare a procedure di più alto livello come C.

In generale sarebbe buono conoscere anche tutta la parte relativa a come è strutturato un file eseguibile, le varie sezioni ad esempio: testo, dati, dati read-only, bss e via discorrendo.

Non avete fatto un corso di architetture dei calcolatori?

Per quanto riguarda gli OS ti segnalo questa wiki che è fatta mediamente bene:

https://wiki.osdev.org

Tieni comunque presente che in un modulo Linux si assume che molti dei passi iniziali del boot siano stati completati, per cui invocare alcune routine non è facilmente possibile senza combinare danni*

* a meno di non spegnere un core e fare il boot di un tuo kernel "bare-metal" su quello

Ultima modifica di WarDuck : 16-11-2020 alle 10:32.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2020, 19:17   #5
zabnicola
Member
 
Iscritto dal: Nov 2020
Messaggi: 75
Rimango del parere che il nome del modello della cpu è scritta nel Bios del notebook. Il bios rimane caricato nella ram fino a che il bootloader grub passi il tutto alla funzione di inizio del sistema operativo. Probabilmente il bootloader fa una copia del bios che era caricato in memoria ram sui primi settori del disco perche poi non viene più usato. Quindi se provassi a interrogare grub o leggere il blocco di memoria dove era salvato il bios momentaneamente dovrei riuscire a ottenere il nome del modello.

Non pensavo tanti problemi per sapere rilevare la cpu corrente e invece.

Ho letto su osdev la guida, funziona: il codice C di inizio viene caricato subito dopo che viene letto dal MBR che riporta la firma su come caricarlo.

Non ho sufficiente studio dell'assembly ma mi metteró ad impararlo gia nei prossimi giorni appena mi arriva il libro "Assembly impararlo con un simulatore"

Aggiorno tutti se ho qualcosa di concreto in piu
zabnicola è offline   Rispondi citando il messaggio o parte di esso
Old 17-11-2020, 15:10   #6
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12814
Quote:
Originariamente inviato da zabnicola Guarda i messaggi
Rimango del parere che il nome del modello della cpu è scritta nel Bios del notebook.
Sicuro? E che succede se cambi CPU?

Comunque ammesso e non concesso che vi sia una copia di questa informazione nel BIOS, è evidente che in qualche misura il BIOS dovrà leggere qualche informazione dalla CPU

Nota per altro che è comunque la CPU che esegue il codice del BIOS.

Quote:
Originariamente inviato da zabnicola Guarda i messaggi
Il bios rimane caricato nella ram fino a che il bootloader grub passi il tutto alla funzione di inizio del sistema operativo. Probabilmente il bootloader fa una copia del bios che era caricato in memoria ram sui primi settori del disco perche poi non viene più usato.

Quindi se provassi a interrogare grub o leggere il blocco di memoria dove era salvato il bios momentaneamente dovrei riuscire a ottenere il nome del modello.
Il BIOS è memorizzato nella EEPROM della scheda madre ed è mappato su indirizzi accessibili dalla CPU. Probabile che venga fatta una copia in RAM per motivi di efficienza. All'accensione il processore comincia ad eseguire da un indirizzo specifico, che punta alla prima istruzione del BIOS, il quale comincia la sua esecuzione.

Ad un certo punto il BIOS legge il primo settore del primo disco (512 bytes) e lo carica in RAM ad un indirizzo prestabilito, da lì in poi parte il boot loader di secondo livello che fa tutto quello che deve fare per consentire l'avvio (eventuale) dell'OS.

Quote:
Originariamente inviato da zabnicola Guarda i messaggi
Non pensavo tanti problemi per sapere rilevare la cpu corrente e invece.

Ho letto su osdev la guida, funziona: il codice C di inizio viene caricato subito dopo che viene letto dal MBR che riporta la firma su come caricarlo.

Non ho sufficiente studio dell'assembly ma mi metteró ad impararlo gia nei prossimi giorni appena mi arriva il libro "Assembly impararlo con un simulatore"

Aggiorno tutti se ho qualcosa di concreto in piu
In realtà si può fare facilmente anche da user-space, ma conoscere qualcosina di assembly e dell'architettura della CPU sicuramente oltre ad essere necessario, aiuta .

Ultima modifica di WarDuck : 17-11-2020 alle 15:13.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 17-11-2020, 17:44   #7
zabnicola
Member
 
Iscritto dal: Nov 2020
Messaggi: 75
Quote:
Originariamente inviato da zabnicola
Il bios rimane caricato nella ram fino a che il bootloader grub passi il tutto alla funzione di inizio del sistema operativo. Probabilmente il bootloader fa una copia del bios che era caricato in memoria ram sui primi settori del disco perche poi non viene più usato.
dalla eeprom su cui è memorizzato, il bios va in esecuzione
E' cosi in memoria centrale per essere eseguito dal processore, questo a patto che la eeprom non faccia anche da memoria centrale.

[#1 Problema] Sto lavorando sul modulo semplice in debian 9. Pultroppo non capisco dove sbaglio.
[#2 Soluzione] Ho installato gli header che occorrono per includere le funzioni di sistema operativo.

[#3 Modello applicazione]
apt-get install build-essential linux-headers-4.9.0-14-amd64
vim m_example.c
Codice:
#include <linux/init.h>
#include <linux/module.h>
#include <linux/kernel.h>
static int __init m_example_init(void) {
printk(KERN_INFO “Load module 1 \n”);
        return 0;
}

module_init(m_example_init);
EOF
#cartelle in cui guarda
/usr/include
locate init.h

[#1] non lo riporto tutto, sono comunque qualche righe di codice per iniziare. Mi restituisce questo errore
mod_zab/m_example.c|1|fatal error: linux/init.h: No such file or directory|
Eppure ho installato gli header.So che va a guardare in /usr/include ed in effetti cercando il file non è presente.
-- --
E' possibile scrivere moduli kernel anche per piattaforma Windows e FreeBsd, ma per quanto riguarda Windows esula dall'obbiettivo che mi sono prefissato: di recuperare le informazioni sulle specifche hardware sull'architettura x86 x64.
Invece Bsd ho trovato poca documentazione su come creare un modulo.


Come dicevi resta da vedere se quelle funzioni sono usabili anche in userspace.
[#4 Soluzione] La funzione che cerco di aggiungere è la print_cpu_info che si trova nei sorgenti common.c della architettura.
https://elixir.bootlin.com/linux/v2..../common.c#L937

Ultima modifica di zabnicola : 19-11-2020 alle 18:26.
zabnicola è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2020, 12:01   #8
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12814
Come stai compilando il modulo?

Ti serve uno specifico Makefile per compilare i moduli del kernel Linux:

https://www.cyberciti.biz/tips/compi...el-module.html

Gli include files dovrebbero trovarsi nella cartella "/usr/src/linux-headers-$(uname -r)"



PS: occhio che devi registrare anche la funzione per rimuovere il modulo (con module_exit) altrimenti poi non lo puoi rimuovere.

Ultima modifica di WarDuck : 20-11-2020 alle 12:09.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2020, 16:33   #9
zabnicola
Member
 
Iscritto dal: Nov 2020
Messaggi: 75
[#6 soluzione, problema]
Ho installato #7 il pacchetto kernel-devel in opensuse Lead 15. Ora con il comando make ho il modulo compilato e pronto per essere caricato nel kernel.

Codice:
[#7 applicazione]
zypper in kernel-devel
cd /home/zabnicola/hello_mod_zab/hello/
ls
m_example.c
Makefile
EOF
vim Makefile
obj-m += m_example.o

all:
        make -C /lib/modules/5.3.18-lp152.50-default/build
 M=/home/zabnicola/hello_mod_zab/hello/ modules

clean:
        make -C /lib/modules/5.3.18-lp152.50-default/build M=/home/zabnicola/hello_mod_zab/hello/  clean
EOF
make
make: Entering directory '/usr/src/linux-5.3.18-lp152.50-obj/x86_64/default'
  CC [M]  /home/zabnicola/hello_mod_zab/hello/m_example.o
  Building modules, stage 2.
  MODPOST 1 modules
  CC      /home/zabnicola/hello_mod_zab/hello/m_example.mod.o
  LD [M]  /home/zabnicola/hello_mod_zab/hello/m_example.ko
make: Leaving directory '/usr/src/linux-5.3.18-lp152.50-obj/x86_64/default'

insmod m_example.ko
dmesg | tail -1
[ 8929.885648] Load module 1
rmmod m_example.ko
dmesg | tail -1
[ 9103.987749] Cleaning up module 1
--
Aggiungo la funzione di rimozione del modulo dal kernel.
Codice:
[#8 Linguaggio]
#include <linux/module.h>    // included for all kernel modules
#include <linux/kernel.h>    // included for KERN_INFO
#include <linux/init.h>      // included for __init and __exit macros

MODULE_LICENSE("GPL");
MODULE_AUTHOR("zabnicola");
MODULE_DESCRIPTION("A Simple Hello World module");

static int __init hello_init(void){
    printk(KERN_INFO "Load module 1\n");
    return 0;    // Non-zero return means that the module couldn't be loaded.
}

static void __exit hello_cleanup(void){
    printk(KERN_INFO "Cleaning up module 1\n");
}

module_init(hello_init);
module_exit(hello_cleanup);
EOF

Ultima modifica di zabnicola : 20-11-2020 alle 17:08.
zabnicola è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso Microsoft Surface Pro 12 è il 2 in 1 pi&u...
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet! Recensione REDMAGIC Astra Gaming Tablet: che spe...
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2 Dopo un mese, e 50 foto, cosa abbiamo capito del...
Gigabyte Aero X16 Copilot+ PC: tanta potenza non solo per l'IA Gigabyte Aero X16 Copilot+ PC: tanta potenza non...
vivo X200 FE: il top di gamma si è fatto tascabile? vivo X200 FE: il top di gamma si è fatto ...
2 minuti: il tempo per scorrere le 25 of...
Mini LED TCL: confronto tra le migliori ...
Robot aspirapolvere: questi sono i più a...
Portatile tuttofare Lenovo Core i5/16GB ...
Scende a 99€ il tablet 11" 2,4K con...
Amiga: quali erano i 10 giochi più belli
Driver più sicuri: Microsoft alza...
Ego Power+ ha la giusta accoppiata per l...
Scompiglio nei listini Amazon: prezzi im...
Sotto i 105€ il robot Lefant che lava, a...
Mini proiettori smart in offerta: uno co...
Smartwatch Amazfit in offerta: Balance o...
Windows XP ritorna: ecco come usarlo sub...
Arrow Lake in saldo: Intel taglia i prez...
LG C4 da 55'' a 899€ è il top per...
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: 19:38.


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