HOGESCHOOL ROTTERDAM / CMI Computersystemen 2 (TIRCCMS02 - Operating systems) L.V.de.Zeeuw@HRO.NL HOGESCHOOL ROTTERDAM / CMI 3 Input en Output Opgaven HOGESCHOOL ROTTERDAM / CMI Vraag 3.1 Stel dat de ontwikkelingen in de chiptechnologieën het mogelijk maken om een complete controller, met inbegrip van de Bus Access Logica, in één chip te bakken, wat voor een gevolg zou dat hebben voor het model van fig. 3-1? L.V. de Zeeuw Computersystemen 2 3 HOGESCHOOL ROTTERDAM / CMI Antwoord 3. 3.1.2 Dit zou voor het model in fig. 3-1 geen gevolgen hebben voor de architectuur hebben, omdat elk device toch toegang moet hebben tot de bus, en of dat nu door één chip of meerdere chips wordt bestuurd, maakt voor het schema niets uit. Wel heeft het gevolgen voor de snelheid van busoverdracht, toegangstijden tot de bus e.d., omdat elk device zelf kan zien of de bus voor hem vrij is of niet, deze taak wordt nu dus overgenomen van de processor door de devices. L.V. de Zeeuw Computersystemen 2 4 HOGESCHOOL ROTTERDAM / CMI Vraag 3.2 Veronderstel dat de disk controller de bytes even snel wegschrijft naar het geheugen, als de controller deze binnen krijgt vanaf disk, waarbij geen interne buffer wordt gebruikt. Is interleaving dan bruikbaar. Beargumenteer het antwoord. L.V. de Zeeuw Computersystemen 2 5 HOGESCHOOL ROTTERDAM / CMI Antwoord 3. 3.1.2 Nee, interleaving is dan niet nodig. De controller kan immers de aanvoer en verwerking van data bijhouden. L.V. de Zeeuw Computersystemen 2 6 HOGESCHOOL ROTTERDAM / CMI Vraag 3.3 Bij een disk wordt dubbele interleaving toegepast (zie figuur 3.4. (c)). De disk bestaat per spoor uit uit acht sectoren van 512 bytes. De omwenteling snelheid is 300 toeren per minuut. Hoelang duurt het om alle sectoren van een spoor in de juiste volgorde te lezen? Men mag ervan uitgaan, dat de arm al in de juiste positie staat en dat een halve omwenteling nodig is om sector 0 onder de lees/schrijf kop te krijgen. Al is de snelheid waarmee gegevens worden verstuurd? Beantwoord dezelfde vragen, nu met een DISC zonder interleaving, maar verder met dezelfde karakteristieken. Hoeveel valt datarate lager uit als gevolg van interleaving? L.V. de Zeeuw Computersystemen 2 7 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.3 3.1.2 Dubbel Interleaved: Voor het lezen van alle sectoren van een track in volgorde is bij een dubbel interleaved disk 3 1/2 omwentelingen nodig • ½ omwenteling voor het positioneren van de lees/schrijf kop. • 3 omwentelingen voor het lezen van 8 sectoren – – – eerste keer worden de sectors 0, 1, 2 gelezen tweede keer worden de sectors 3, 4, 5 gelezen derde keer worden de sectors 6 en 7 gelezen 300 omwentelingen/minuut = 300 omwentelingen / 60 s = 5 omwentelingen/s. 3 ½ omwenteling duurt 3 ½ / 5 = 0.7 s De datarate = 8 x 512 bytes / 0.7s = 5851 bytes/s Non Interleaved: Voor het lezen van alle sectoren van een track bij een non-interleaved disk zijn 1 ½ omwentelingen nodig: • 1/2 omwenteling voor het positioneren van de lees/schrijf kop. • 1 omwentelingen voor het lezen van 8 sectoren Dus totaal 1 1/2 omwentelingen 1 ½ x 1/5 = 0.3 s De datarate = 8 x 512 bytes / 0.3s = 13653 bytes/s L.V. de Zeeuw Computersystemen 2 8 HOGESCHOOL ROTTERDAM / CMI Vraag 3.4 De DM-11 terminal multiplexer, die werd gebruikt voor de PDP-11 nam van iedere (half duplex) terminal lijn zeven keer zoveel samples (monsters) als de baudrate. Zo kon men zien of het binnenkomende bit een 0 of een 1 was. Het samplen van de lijn duurde 5,7 μs. (10-6s). Hoeveel 1200 baud lijnen kon de DM-11 ondersteunen? L.V. de Zeeuw Computersystemen 2 9 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.4 3.x.y • 1200 baud gescand met 1200 x 7 = 8400 Hz. Dit is (1/8400) s per sample • Een scan op zich duurt 5.7 μs. • Door multiplexing kunnen er dus (1/8400) / (5.7 x10-6s) = 20 kanalen worden gescand. L.V. de Zeeuw Computersystemen 2 10 HOGESCHOOL ROTTERDAM / CMI Vraag 3.5 Een local network werkt als volgt. De user roept een system call aan om naar het netwerk te schrijven. Het operating system kopieert de data naar een kernel buffer. Hierna kopieert hij de data naar de network controller board. Wanneer alle bytes zijn opgeslagen in de controller worden ze verzonden over het netwerk met een snelheid van 10 megabits/s. De ontvangende network controller slaat elk bit een ms nadat het verzonden is op in zijn geheugen. Wanneer het laatste bit is ontvangen krijgt de destination CPU een interrupt zodat de kernel de nieuwe data kan kopiëren naar een kernel buffer. Vervolgens wordt uitgezocht voor welke user de data bestemd is en naar de betreffende user space gekopieerd. Als we aannemen dat elke interrupt en zijn afhandling 1 ms duurt, dat de data in blokken van 1024 bytes worden verstuurd en dat het kopiëren van een byte 1 ms duurt, wat is dan de maximale snelheid waarmee een proces data kan versturen naar een ander proces? L.V. de Zeeuw Computersystemen 2 11 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.5 3.x.y Systemcall van de gebruiker ( SWI ) Data naar kernel buffer Kernel buffer naar netwerk controller board 1000 μs 1024 μs 1024 μs 8 * 1024 = 8192 bits Verzenden van een datablock (10 megabits/s) Interrupt destination CPU Network controller board naar kernel buffer Kernel buffer naar data gebied L.V. de Zeeuw Computersystemen 2 8192 μs 1000 μs 1024 μs 1024 μs ----------- + 14288 μs 12 HOGESCHOOL ROTTERDAM / CMI Vraag 3.6 Wat wordt bedoeld met ‘apparaat onafhankelijk’? L.V. de Zeeuw Computersystemen 2 13 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.6 3.2.1 ‘Apparaat onafhankelijk’ wil zeggen, dat bepaalde commando's op een vaste manier moeten worden uitgevoerd, ongeacht op welk device de commando's betrekking hebben. Bijv. een write-commando moet altijd een schrijfaktie inhouden, of dit commando nu naar een scherm, printer of een file gestuurd wordt. L.V. de Zeeuw Computersystemen 2 14 HOGESCHOOL ROTTERDAM / CMI Vraag 3.7 In welke van de 4 software-lagen wordt het volgende afgehandeld? a) Bepalen van de track, sector en kopnummer bij het lezen van een disk. b) Bijhouden van een cache van recent gebruikte blokken. c) Schrijven van commando's naar device registers. d) Controleren of de gebruiker wel de permissie heeft om een bepaald device te gebruiken. e) Omzetten van binaire format naar ASCII om ze af te kunnen drukken. L.V. de Zeeuw Computersystemen 2 15 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.7 3.2.1 De 4 software-lagen zijn : (4) Utilities , gebruikerprogramma's. (3) Device onafhankelijke software. (2) Device drivers. (1) Interrupt handlers. a) b) c) d) e) Bepalen van de track, sector en kopnummer bij het lezen van een disk. (2) Bijhouden van een cache van recent gebruikte blokken. (3) Schrijven van commando's naar device registers (3) Controleren of de gebruiker wel de permissie heeft om een bepaald device te gebruiken. (4) Omzetten van binaire format naar ASCII om ze af te kunnen drukken. (1) L.V. de Zeeuw Computersystemen 2 16 HOGESCHOOL ROTTERDAM / CMI Vraag 3.8 Waarom worden output files voor de printer, normaliter, eerst op disk geschreven voordat ze worden afgedrukt? L.V. de Zeeuw Computersystemen 2 17 HOGESCHOOL ROTTERDAM / CMI Antwoord 3. 3.2.5 SPOOL = Simultanous Peripheral Operations On Line Omdat, indien ieder proces de mogelijkheid zou hebben om te printen en zo'n proces zou de character special file van de printer openen en daarna urenlang niets doen, dan kan geen enkel ander proces iets printen. Dit wordt ondervangen door een nieuw speciaal proces te creëren 'deamon' genaamd en ook een speciaal directory een spooling directory genaamd. Wanneer een proces een file wil printen moet het de gehele file genereren en dit in het spooling directory zetten. En dan is het aan het 'deamon' proces,wat het enige proces is met permissie om het special file van de printer te gebruiken,om de files in het directory uit te printen. Hierdoor wordt het probleem van het onnodig lang openhouden van de special file direct door de users volledig ondervangen. Bovendien kost dit weinig extra tijd, want dit deamon proces kan de files uitprinten als hiervoor tussendoor tijd over is. L.V. de Zeeuw Computersystemen 2 18 HOGESCHOOL ROTTERDAM / CMI Vraag 3.9 Beschouw figuur 3.8 Neem aan dat in stap (o) C om S vraagt in plaats van R. Zou dit leiden tot deadlock? En als C om S en R vraagt? L.V. de Zeeuw Computersystemen 2 19 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.9 3.3.2 Nee, in de graaf ontstaat voor beide scenario’s géén cirkel. Omdat er maar een taak tegelijk gebruik kan maken van een bepaalde device (bv een printer), moet ieder taak wachten totdat het device wordt vrijgegeven. Een device wordt dan pas vrijgegeven als de taak verder kan gaan op een ander device. Als er echter twee taken op elkaar zitten te wachten om verder te kunnen gaan, ontstaat er deadlock. Geen van beide taken geeft zijn device vrij. L.V. de Zeeuw Computersystemen 2 20 HOGESCHOOL ROTTERDAM / CMI Vraag 3.10 Al de trajecten in figuur 3.12 zijn horizontaal en verticaal. Kun je omstandigheden bedenken waarin ook diagonale trajecten mogelijk zijn ? L.V. de Zeeuw Computersystemen 2 21 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.10 3.3.6 Diagonale trajecten zijn alleen mogelijk als multiprocessor systemen gebruikt worden. L.V. de Zeeuw Computersystemen 2 22 HOGESCHOOL ROTTERDAM / CMI Vraag 3.11 Bekijk figuur. 3.11(b). Als Yvonne om nog een eenheid vraagt, leidt dit dan tot een veilige of onveilige toestand? Wat gebeurt er als de aanvraag van Micheal komt in plaats van Yvonne? L.V. de Zeeuw Computersystemen 2 23 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.11 3.3.6 • Als Yvonne om nog een eenheid vraagt, dan hou je nog 1 eenheid over, dit is niet genoeg om één van de aanvragers zijn volle credit te kunnen geven, een onveilige toestand dus. • Als de aanvraag van Michel komt, dan hou je er ook nog maar één over, maar dan bestaat de mogelijkheid om Michel zijn volle credit te geven, waarna er later 4 eenheden vrijkomen waarmee je weer de anderen hun volle credit kunt geven. Dit is dus een veilige toestand. L.V. de Zeeuw Computersystemen 2 24 HOGESCHOOL ROTTERDAM / CMI Vraag 3.12 Zie figuur 3.13. Stel dat process A de laatste tapedrive aanvraagt. Leidt dit tot een deadlock? L.V. de Zeeuw Computersystemen 2 25 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.12 3.3.6 • Dit kun je nagaan door het bankiers algoritme voor méér resources uit te voeren. – – – • E=totaal beschikbaar P=toegewezen. A=nog over. Indien A de laatste tapedrive aanvraagt kan dit tot een deadlock leiden omdat A ook nog een plotter nodig heeft die niet beschikbaar is en wordt vastgehouden door C die op een tapedrive staat te wachten. L.V. de Zeeuw Computersystemen 2 26 HOGESCHOOL ROTTERDAM / CMI Vraag 3.13 Een computer heeft 6 tape drives, met n processen die daar allen gebruik van willen maken. Elk proces kan twee drives nodig hebben. Voor welke waarden van n is het systeem vrij van deadlock? L.V. de Zeeuw Computersystemen 2 27 HOGESCHOOL ROTTERDAM / CMI Antwoord 3.13 3.3.6 Voor n<6 is het systeem deadlock vrij. Voor n≥6 is het mogelijk dat alle processen op elkaar staan te wachten, en dus geen van allen klaar komen met de uitvoering van hun taak. L.V. de Zeeuw Computersystemen 2 28