Demo board. Nagy András. Conet Kft november 29.

Hasonló dokumentumok
Threos: Mikrokernel operációs rendszer a gyakorlatban

Operációs rendszerek. Az Executive és a kernel Policy és mechanizmusok szeparálása Executive: policy - objektum kezelés Kernel: mechanizmusok:

Operációs rendszerek. Az NT folyamatok kezelése

Processzusok (Processes), Szálak (Threads), Kommunikáció (IPC, Inter-Process Communication)

Operációs rendszerek. Windows NT. A Windows NT

Norway Grants. Az akkumulátor mikromenedzsment szabályozás - BMMR - fejlesztés technológiai és műszaki újdonságai. Kakuk Zoltán, Vision 95 Kft.

2. Számítógépek működési elve. Bevezetés az informatikába. Vezérlés elve. Külső programvezérlés... Memória. Belső programvezérlés

386 processzor címzés

Flash és PHP kommunikáció. Web Konferencia 2007 Ferencz Tamás Jasmin Media Group Kft

(kernel3d vizualizáció: kernel245_graph.mpg)

Processzusok (Processes), Szálak (Threads), Kommunikáció (IPC, Inter-Process Communication)

A számítógép egységei

Adatbázis és alkalmazás konszolidáció Oracle SPARC T4/5 alapon

Informatikai Rendszerek Intézete Gábor Dénes Foiskola. Operációs rendszerek oldal LINUX

ARM Cortex magú mikrovezérlők. mbed

Programmable Chip. System on a Chip. Lazányi János. Tartalom. A hagyományos technológia SoC / PSoC SoPC Fejlesztés menete Mi van az FPGA-ban?

Léteznek nagyon jó integrált szoftver termékek a feladatra. Ezek többnyire drágák, és az üzemeltetésük sem túl egyszerű.

Dr. Schuster György október 30.

Operációs rendszerek. Bemutatkozás

Hálózati architektúrák és Protokollok GI 8. Kocsis Gergely

Mikrorendszerek tervezése

Everything Over Ethernet

Magic xpi 4.0 vadonatúj Architektúrája Gigaspaces alapokon

Kommunikáció. 3. előadás

Operációs rendszerek III.

Java I. A Java programozási nyelv

Könyvtári címkéző munkahely

Autóipari beágyazott rendszerek. Komponens és rendszer integráció

Tartalom. Történeti áttekintés. Történeti áttekintés Architektúra DCOM vs CORBA. Szoftvertechnológia

Az iskolai rendszerű képzésben az összefüggő szakmai gyakorlat időtartama. 10. évfolyam Adatbázis- és szoftverfejlesztés gyakorlat 50 óra

5. Hálózati címzés. CCNA Discovery 1 5. fejezet Hálózati címzés

Operációs rendszerek. A Windows NT felépítése

Párhuzamos programozási platformok

Digitális rendszerek. Digitális logika szintje

Számítógépes munkakörnyezet II. Szoftver

OPERÁCIÓS RENDSZEREK I. BEVEZETÉS Koczka Ferenc -

WAGO PLC-vel vezérelt hő- és füstelvezetés

Infokommunikációs alkalmazásfejlesztő. Informatikai alkalmazásfejlesztő

Számítógép felépítése

Image Processor BarCode Service. Felhasználói és üzemeltetői kézikönyv

IP alapú komunikáció. 2. Előadás - Switchek 2 Kovács Ákos

Szárazföldi autonóm mobil robotok vezérlőrendszerének kialakítási lehetőségei. Kucsera Péter ZMNE Doktorandusz

Kommunikáció. Folyamatok közötti kommunikáció. Minden elosztott rendszer alapja

Operációs rendszerek. Az X Window rendszer

1. Fejezet: Számítógép rendszerek. Tipikus számítógép hirdetés

Bevitel-Kivitel. Eddig a számítógép agyáról volt szó. Szükség van eszközökre. Processzusok, memória, stb

DWL-G520 AirPlus Xtreme G 2,4GHz Vezeték nélküli PCI Adapter

Hálózati architektúrák laborgyakorlat

Hálózati architektúrák és Protokollok GI 7. Kocsis Gergely

Párhuzamos programozási platformok

A Java EE 5 plattform

Szolgáltatás Orientált Architektúra és több felhasználós adatbázis használata OKF keretein belül. Beke Dániel

Vé V g é r g e r h e a h j a tá t s á i s s z s ál á ak a Runnable, Thread

Fábián Zoltán Hálózatok elmélet

Szoftvertechnológia alapjai Java előadások

Megnevezés Leírás Megjegyzés Irodai PC

E Y E Z O N E B1080PX-3 BEMUTATÁS

Első sor az érdekes, IBM PC ra alapul: 16 bites feldolgozás, 8 bites I/O (olcsóbb megoldás). 16 kbyte RAM. Nem volt háttértár, 5 db ISA foglalat

Szenzorhálózatok programfejlesztési kérdései. Orosz György

TANMENET 2018/2019. tanév

Számítógépek felépítése

Széchenyi István Egyetem. Programozás III. Varjasi Norbert

Számítógépes Hálózatok 2011

Egy egyszerű, gyors és szabad újratelepítő eszköz: upi

Operációs rendszerek

III. Felzárkóztató mérés SZÉCHENYI ISTVÁN EGYETEM GYŐR TÁVKÖZLÉSI TANSZÉK

Kommunikációs rendszerek programozása. Switch-ek

Általános rendszergazda Általános rendszergazda

5-6. ea Created by mrjrm & Pogácsa, frissítette: Félix

Tartalom DCOM. Történeti áttekintés. Történeti áttekintés. Történeti áttekintés. Történeti áttekintés

Uniprogramozás. várakozás. várakozás. Program A. Idő. A programnak várakoznia kell az I/Outasítások végrehajtására mielőtt továbbfuthatna

AWK programozás Bevezetés

Operációs rendszerek. UNIX/Linux fájlrendszerek

Szkriptnyelvek. 1. UNIX shell

Az alábbi állítások közül melyek a forgalomirányító feladatai és előnyei?

Operációs rendszerek

Hálózatok építése és üzemeltetése

Internet-hőmérő alapkészlet

BMD Rendszerkövetelmények

evosoft Hungary Kft.

AWK programozás, minták, vezérlési szerkezetek

webalkalmazások fejlesztése elosztott alapon

TestLine - GINOP teszt Minta feladatsor

Hardver összetevők ellenőrzése Linux alatt. Hardverguruk előnyben...

OpenBSD hálózat és NAT64. Répás Sándor

elektronikus adattárolást memóriacím

Hálózati architektúrák és Protokollok PTI 5. Kocsis Gergely

Alap protokollok. NetBT: NetBIOS over TCP/IP: Name, Datagram és Session szolgáltatás.

Hálózati architektúrák laborgyakorlat

Informatikai füzetek

Számítógépes alapismeretek

KÉPZETT VILLANYSZERELŐ SZAKEMBER

Arduino bevezető Szenzorhálózatok és alkalmazásaik

Memóriák - tárak. Memória. Kapacitás Ár. Sebesség. Háttértár. (felejtő) (nem felejtő)

Az adott eszköz IP címét viszont az adott hálózat üzemeltetői határozzákmeg.

Parciális rekonfiguráció Heterogán számítási rendszerek VIMIMA15

Virtualizációs technológiák Linux alatt (teljesítményteszt)

IPv6 Elmélet és gyakorlat

Számítógép hálózatok

COMET webalkalmazás fejlesztés. Tóth Ádám Jasmin Media Group

Átírás:

Nagy András Baráth Áron Kéri Kálmán Conet Kft. 2016. november 29.

Tartalom 1 Hardware Software 2 3

Hardware Software Tartalom 1 Hardware Software 2 3

Hardware Software Motiváció Elosztott épületvezérlés építéséhez kerestünk környezetet Skálázható legyen Szimulálható legyen Elosztott legyen Nem találtunk számunkra megfelelőt Komplex probléma

Hardware Software Komplex Rendszerek Rendszerelemek: megfelelő hardware és software összessége Hardware: kell vas, amin futnak a programok ki-/bemenetek kezelése (fogyasztók, érzékelők) Software: Több szintű programok összesége

Hardware Software Hardware környezet Utasítások beolvasása, értelmezése, végrehajtása, ki-/bemenetek Nagyon alacsony szint ( vas ) Végrehajtó egység (processzor) Memória (RAM, ROM, FLASH) Perifériák Beavatkozók, érzékelők Sokféle: komplex, nem nyitott, nem hibamentes Nehéz kezelni

Hardware Software Hardware alap Végrehajtó egység (processzor) Sokféle típus Általános célú (asztali gép, szerver, tablet) Speciális célú (grafika, hang) Mikrokontrollerek Elmosódtak a határvonalak Technológiai fejlődés hatása 1994: Intel Pentium P54C (75-120 MHz, 8-12W, $849) 2011: LPC1830 ARM Cortex M3 (180 MHz, 0,25W, $5)

Hardware Software Hardware tulajdonságok Több félét használunk Alacsonyabb szinten Microcontroller (ARM, Cortex M0, M3, M4, M7) Magasabb szinten Microprocessor (Intel x86 64, ARM Cortex A8)

Hardware Software Software rétegek Több szint, különböző szintek (bonyolultság változik) Egymásra épülnek Alacsonyabb Másként nehéz, pl. időkritikus Magasabb Összetett

Hardware Software Programok software környezete Elfedi a hardware környezetet Egységes software felületet biztosít Több szintű (pl. interpreter, web böngésző) Lehet meztelen vasra is programot írni Beágyazott rendszerekben nem ritka Operációs rendszer!

Hardware Software Operációs rendszer Alacsony szintű software réteg Szolgáltatások egységes felülete Széles spektrum Két nagy pólus: Microkernel és Monolitikus kernel Hol húzzuk meg az operációs rendszer határvonalát Operációs rendszer részei egyben vagy külön Szétosztott vagy központosított Sebesség, komplexitás, modularitás vonzata van Hibrid kernel (részben micro, részben monolitikus)

Hardware Software Tervezett operációs rendszer Microkernel Valós idejű ütemezés Multitasking, multithreading Virtuális memória kezelése, de egy címtér ASLR adja magát Task kontextusában futó megszakítások Nagyon kevés architektúra függő rész

Hardware Software Microkernel tulajdonságok Objektum orientált szemléletmód Alapvetően C-ben + C preprocesszált ASM Gyors, egyszerű rendszerhívások (timeout) Single stack kernel (stateless) Paraméter átadás csak regisztereken keresztül Üzenet alapú kommunikáció

Hardware Software Alacsony szintű szolgáltatások A kernel önmagában kevés Szükség van a kernel-re épülő szolgáltatásokra Programok betöltése Device driverek írása Task-ok felügyelete Programkönyvtárak Mindent külön programokban kell megoldani

Tartalom 1 Hardware Software 2 3

Registry Futási idejű információk szálbiztos megosztása task lista device lista Értesítési mechanizmus Típusok: dir, tmp, int, bin Szerializálhatóság Guarded key

Library Service Program méretét növeli a static library Érdemes a programkönyvtárat külön tenni Dinamikus hozzászerkesztés: dynamic library Shared Executable (sx) Stateless (gyorsabb, olcsóbb) Stateful (univerzálisabb)

bootfs és cpio Az adatok bootfs-en tárolódnak bootloader.ini Rendszer image-ek: *.cpio.xz Multi-config image Tartalma teljes egészében a /run alá kerül (tmpfs) Alapvető device-ok IDE, SATA vezérlő Network driver VFS, file rendszerek Config-ok, script-ek, devman ini-k

Config script Egyszerű szintaxis (értékadás, szekvencia és elágazás) Alapműveletek elvégzése egész számokon String konkatenáció Konverziók Programindítás Műveletek a registry-vel: kulcs létrehozás kulcsra várakozás kulcs törlés

Device manager Supervisor A detektorok információi ide futnak be Programok (újra)indítása Watch objektum szerepe Függőségek kezelése A futtatási környezet egyszer értékelődik ki Config script-ek futtatása File rendszer interface: /dev

/$ ls -l /dev dr-xr-xr-x 0 2016-11-29 7:05:20 detectors dr-xr-xr-x 0 2016-11-29 7:05:20 drvroot crw-rw-rw- 0 2016-11-29 7:05:20 null dr-xr-xr-x 0 2016-11-29 7:05:20 programs crw-rw-rw- 0 2016-11-29 7:05:20 random crw-rw-rw- 0 2016-11-29 7:05:20 zero

Detektorok Hardware konfiguráció detektálása (ACPI, PCI) Másra is használható Statikus (PCI) és dinamikus (USB) detektálások A device manager-nek küldi el A detektált hardware meghajtója kommunikálhat a detektorával Szabványos interface

I/O request Megnyitott Device példány szükséges hozzá Nagy mennyiségű adat is átküldhető Üzenet küldése a Device-nak A rendszer egyik alap építőeleme T D 0 V max IOreq Device T P 0 V max

Device class Azonos szerepkörű device-ok (service-ek) közös interfésze DCLS_BLOCK DCLS_FILESYSTEM DCLS_SERVICE... Egy device (service) több class-t is megvalósíthat pl. TCP/IP device: DCLS_TCPIP, DCLS_CHAR, DCLS_SERVICE Vannak opcionális parancsok pl. FS_CMD_MKDIR

File system service Class: DCLS_FILESYSTEM Különböző file system-ek közös interfésze tmpfs ffs bootfs FAT32 Nem feltétlenül valósít meg minden műveletet Összekötés blokk vagy flash device-szal Mindegyik a VFS-en keresztül érhető el

Network interface Ethernet és Wi-Fi Adatcsomagok küldése megadott MAC címre A hogyan nem érdekes Közös interfész: DCLS_NETIFACE Speciális műveletek (NIF_CMD_GETOPT, NIF_CMD_SETOPT)

TCP/IP stack Network interfészek felhasználása Absztrakciós réteg Robosztus, moduláris és testreszabható IPv4 üzenetek küldése ICMP UDP TCP Alkalmazás szintű protokollok DNS NetBIOS NS DHCP

pkman Package manager Teljesen C-ben íródott.pkg.cpio.xz formátum Integritás: SHA-256 Verifikálás: digitális aláírás (RSA-2048) Az alpm és a pacman ihlette Multi-arch by design

makepk pkman-kompatibilis package előálĺıtása Különböző sémák A package formátum is paraméter Feladata: Külső tool-ok meghívása (build) Package leíró (integritás, aláírás) cpio összeálĺıtása Tömörítés

httpd Hypertext Transfer Protocol FastCGI (és CGI) támogatás Többszálú request feldolgozás CGI programok automatikus betöltése és cache-elése CGI-k újra felhasználhatók

ftpd File Transfer Protocol Újra fordított binárisokat gyorsan kellett másolni TFTP kényelmetlen és nem megbízható httpd-hez hasonlóan többszálú

HTTP kérés kiszolgálása httpd TCP/IP VFS ffs Ethernet Device Flash Device hardware

barsh A bash egy egyszerűsített verziója Nincs központi szerepe Automatikus- és környezeti változók kezelése Shell script lehetőség Figyelembe veszi a shebang-et (interpreter választás) Minimális a beépített parancskészlet

utibox Linux-ból ismert parancsok gyűjteménye ls cp mv Egyetlen program, közös függvények miatt Symlink-ek választják ki az eszközt Program betöltése lustán!

sysbox Rendszer erőforrásait és kernel objektumait kezeli task threads treereg Egyetlen program, közös függvények miatt Symlink-ek választják ki az eszközt Program betöltése lustán!

Tartalom 1 Hardware Software 2 3

Demo bemutatása

Köszönjük a figyelmet! andy2@conet.hu baratharon@caesar.elte.hu keri.kalman@gmail.com