DNIX - DNIX

DNIX
ӘзірлеушіDataindustrier AB
ОЖ отбасыUnix тәрізді
Жұмыс жағдайыТарихи
Дереккөз моделіЖабық көзі
Соңғы шығарылым5.4
ЛицензияМеншіктік

DNIX (төл емле: D-Nix) болды Unix тәрізді нақты уақыттағы операциялық жүйе швед компаниясынан Dataindustrier AB (DIAB). Деп аталатын нұсқасы ABCenix үшін де жасалды ABC 1600 Луксордан шыққан компьютер. (Daisy Systems кейбіреулерінде Daisy DNIX деп аталатын нәрсе болды CAD жұмыс станциялары. Бұл DIAB өнімімен байланысты емес еді.)

Тарих

Швециядағы DIAB-тің басталуы

DIAB DS90 және D-NIX жүйелік байланыстырғыштар

Dataindustrier AB (сөзбе-сөз аудармасы: компьютерлік индустрияның акционерлік компаниясы) 1970 жылы Ларс Карлссон бір тақталы компьютер өндіріс Сундсвол, Швеция, өндіретін а Zilog Z80 -базалы компьютер деп аталады 4680.[түсіндіру қажет ] 1978 жылы DIAB Швед телекомпаниясымен жұмыс істей бастады Luxor AB үй мен кеңсенің компьютерлік серияларын шығару ABC 80 және ABC 800.

1983 жылы DIAB тәуелсіз біріншісін жасады UNIX - үйлесімді машина, DIAB DS90 негізінде Motorola 68000 ОРТАЛЫҚ ЕСЕПТЕУІШ БӨЛІМ. D-NIX осында өзінің пайда болуын негізге алды UNIX жүйесі V лицензия AT&T. DIAB дегеніміз - бұл өндірістік автоматика компаниясы, және қажет нақты уақыттағы операциялық жүйе, сондықтан компания AT & T жеткізетін UNIX-ті ауыстырды ядро өзіндік әзірленген, бірақ нақты уақыт режиміндегі үйлесімді нұсқасы бар. Бұл ядро ​​бастапқыда Z80 ядросы деп аталған OS8.[1]

Уақыт өте келе, компания UNIX-тен бірнеше стандартты пайдаланушылар кеңістігінің құралдарын өздерінің қосымшаларымен алмастырды, бұл жағдайда UNIX-тен код алынбаған және олардың машиналары кез-келген AT&T UNIX лицензиясына тәуелсіз орналастырылуы мүмкін болатын. Екі жылдан кейін және Luxor-мен ынтымақтастықта компьютер шақырылды ABC 1600 сонымен қатар DIAB Motorola процессорларының жаңа нұсқаларын қолдана отырып DS90 компьютерінің жетілдірілген нұсқаларын шығаруды жалғастыра отырып, кеңсе нарығы үшін жасалған. Motorola 68010, 68020, 68030 және ақыр соңында 68040. 1990 жылы DIAB сатып алды Бұқа тобы брендтік атауымен DS машиналарын өндіруді және қолдауды жалғастырды DIABсияқты аттармен DIAB 2320, DIAB 2340 және т.б., DNIX-тің DIAB нұсқасын әлі де іске қосады.[2]

ISC Systems корпорациясындағы туынды

ISC Systems корпорациясы (ISC) өзінің желісінде пайдалану үшін 1980 жылдардың соңында DNIX пайдалану құқығын сатып алды Motorola 68k -базалық компьютерлер. (ISC кейінірек сатып алды Оливетти, және өз кезегінде қайта сатылды Ванг, содан кейін оны сатып алды Гетроника. Көбінесе «ISC» деп аталатын бұл корпоративті ұйым бірнеше жыл бойына шатасқан атауларға жауап берді.) Бұл код филиалы SVR2 үйлесімді нұсқасы, және кең модификациялау және дамыту олардың қолында алды. Мұның маңызды ерекшеліктері операциялық жүйе оның қолдауы болды пейджингті талап ету, дискісіз жұмыс станциялары, көпөңдеу, асинхронды енгізу / шығару, процедураларды (өңдеушілерді) каталогтарға орнату мүмкіндігі файлдық жүйе, және хабарлама жіберу. Оның шынайы уақыт қолдау негізінен ішкі болды оқиғаға негізделген іздеу тетіктерін емес, кезектер[3]), екі сыныптағы процестің басымдылықтары (аяқталғанға дейін жүгіртіліп), іргелес файлдарды қолдау (болдырмау үшін бөлшектену жадты блоктау). Сапасы ортогоналды асинхронды оқиғаны іске асыру қазіргі коммерциялық операциялық жүйелерде әлі теңестірілмеген, дегенмен кейбіреулер оған жақындайды. (Әлі қабылданбаған тұжырымдама - барлық асинхронды белсенділіктің синхронды түйісу нүктесі өзі асинхронды, жарнамалық инфинит болуы мүмкін. DNIX мұны апломмен өңдеді.) Асинхронды енгізу-шығару қондырғысы қажеттілікті жойды Беркли розеткалары таңдаңыз немесе SVR4 Келіңіздер АҒЫМДАР сауалнама механизм, дегенмен, артқы үйлесімділік үшін ұяшық семантикасын сақтайтын ұяшықтарды эмуляциялау кітапханасы болды. DNIX-тің тағы бір ерекшелігі сол болды жоқ стандартты утилиталар (мысалы ps, жиі қылмыс жасаушы) өз жұмысын орындау үшін ядро ​​жадында қыбыр етті. Оның орнына жүйелік қоңыраулар қолданылды және бұл ядроның ішкі архитектурасы қажет болған жағдайда өзгерте алатындығын білдірді. Өңдеуші тұжырымдамасы желілік протокол стектерінің ядродан тыс болуына мүмкіндік берді, бұл дамуды айтарлықтай жеңілдетті және жалпы сенімділікті жақсартты, бірақ өнімділік құны бойынша. Сонымен қатар, шетелдік файлдық жүйелер сенімділікті жоғарылату үшін пайдаланушы деңгейіндегі процестерге мүмкіндік берді. Негізгі файлдық жүйе сыртқы процесс болуы мүмкін болғанымен (және бұрын болған да), оны орындау үшін ядроға тартылды. Егер бұл болмаса, DNIX а деп қарастырылуы мүмкін еді микро ядро дегенмен, ол ресми түрде осылай дамымаған. Өңдегіштер өңдеуге болмайтын «жергілікті» Unix файлының, каталог құрылымының немесе құрылғысының кез-келген типінде және файл енгізу-шығару сұраныстарында басқа өңдеушілерге берілуі мүмкін. . Өңдегіштің қосылыстары а-ға ұқсас файлдық жүйеден тәуелсіз де болуы және берілуі мүмкін құбыр. Мұның бір әсері сол TTY «құрылғыларға» ұқсас ядроға негізделген эмуляциялауға болады жалған терминал нысан.

Өңдеушінің күнді сақтаған мысалы ISC дискісіз жұмыс станциясының қолдауында болды, мұнда іске асырудағы қате құбырлар жұмыс станциясында файл серверінде қажетсіз қоршауды тудыруы мүмкін. Тиісті ядро ​​түзетулерін әзірлегенге дейін жұмыс стансасында зардап шеккен аталған құбырларға қол жетімділік үшін өңдеуші құрылды. Бұл өңдеушіге шамамен 5 қажет болды килобайт іске асырылатын код, бұл тривиальды өңдеушінің үлкен болуының қажеті жоқтығының көрсеткіші.

ISC сонымен қатар өндіріс құқығын алды DIAB DS90-10 және DS90-20 машиналары оның файл серверлері ретінде. DS90-20 мультипроцессоры мақсатты нарық үшін өте қымбат болды және ISC өзінің серверлерін жасап, оларға DNIX порталы болды. ISC өзінің жеке дизайнын жасады GUI - осы файл серверлерімен жұмыс істеуге арналған дискісіз жұмыс станциялары және қайтадан DNIX порталы. (ISC Daisy DNIX жұмыс істейтін Daisy жұмыс станцияларын DIAB-тің DNIX-ті басқаратын машиналарды жобалау үшін қолданғанымен, ішкі түсініксіз шатасулар болды, өйткені әзірлеушілер мен дизайнерлер бағдарламалық жасақтама қызметкерлерімен сирек сөйлесті. немесе жүйе! Жүгіртпе әзіл келесідей болды: «Біз ISC-де салу компьютерлер, бізде жоқ пайдалану «. DNIX асинхронды енгізу-шығару тірегі жеңілдетілді оқиғаларға негізделген бағдарламалау ресурстарында салыстырмалы түрде шектеулі болса да жақсы жұмыс істейтін жұмыс станцияларында. (GUI дискісіз жұмыс станциясында 7 МГц болған 68010 процессор және 512K жадында ғана қолдануға болатын, оның ядросы шамамен жартысын жұмсады. Көптеген жұмыс станцияларында 1 болды МБ жады, бірақ кейінірек 10 МГц процессорлармен бірге 2 МБ және 4 МБ нұсқалары болған.) Толық қондырғы бір серверден (16 МГц) тұруы мүмкін. 68020, 8 Мбайт жедел жады және 200 Мбайт қатты диск) және 64 жұмыс станциясына дейін. Жүктелу баяу болса да, мұндай массив а-да қолайлы болады банк кассирі қолдану. DNIX туа біткен тиімділігімен қатар, байланысты DIAB C компиляторы жоғары өнімділіктің кілті болды. Бұл үшін әсіресе жақсы код пайда болды 68010, әсіресе ISC оны аяқтағаннан кейін. (ISC оны қайта өзгертті Texas Instruments TMS34010 өзінің соңғы жұмыс станциясында қолданылатын графикалық копроцессор.) DIAB Әрине, C компиляторы DNIX-ті құру үшін пайдаланылды, бұл оның тиімділігіне ықпал ететін факторлардың бірі болды, және ол (кейбір түрде) арқылы қол жетімді Wind River Systems.

Бұл жүйелер бұрынғы жазу кезінде 2006 жылы қолданыла береді Сиэтл-Бірінші Ұлттық Банк қазір филиалдар Америка Банкі. Мүмкін, DNIX-ті белгілі бір деңгейде қолданатын басқа ISC клиенттері болуы мүмкін, мүмкін. ISC арқылы айтарлықтай DNIX қатысуы болды Орталық және Оңтүстік Америка.

Асинхронды оқиғалар

DNIX-тің жергілікті жүйелік қоңырауы болды днекс (2) кітапхана функциясы, Unix стандартына ұқсас unix (2) немесе сискал (2) функциясы. Бұған бірнеше аргументтер қажет болды, олардың біріншісі функциялардың коды болды. Бұл жалғыз қоңырау Unix-тен барлық функционалдылықты қамтамасыз етті, бірақ синтаксистік жағынан Unix-тен өзгеше болды және DNIX-ке ғана арналған көптеген кеңейтімдерге ие болды.

DNIX функциялық кодтары екі классқа бөлінді: 1 тип және 2 тип. 1 тип командалар дегеніміз - енгізу-шығару қызметімен байланысты немесе эмиссия процесінің бұғатталуына себеп болатын кез келген нәрсе. Негізгі мысалдар болды F_OPEN, F_CLOSE, F_READ, F_WRITE, F_IOCR, F_IOCW, F_WAIT, және F_NAP. 2 типі қалғаны болды, мысалы F_GETPID, F_GETTIMEОларды ядроның өзі бірден қанағаттандыра алады.

Асинхронды шақыру үшін арнайы файл дескрипторы 2 типті опкод арқылы тұзақ кезегі жасалуы керек еді F_OTQ. 1 типті қоңырау келесідей болады F_NOWAIT функционалды мәнімен бірге OR-ed биті, және қосымша параметрлердің бірі днекс (2) кезек файлының дескрипторы болды. Асинхронды шақырудан қайтарылатын мән қалыпты мән емес, ядро ​​тағайындалған идентификатор болды. Асинхронды сұраныс аяқталған уақытта, а оқу (2) (немесе F_READ) тұзақтың кезегінің файлының дескрипторының идентификаторы мен нәтижесінің күйін қамтитын ядросы анықталған құрылымды қайтарады. The F_CANCEL әлі аяқталмаған асинхронды әрекетті тоқтату үшін операция қол жетімді болды, оның аргументтерінің бірі ядро ​​тағайындалған идентификатор болды. (Процесс тек қазіргі уақытта өзіне тиесілі болған сұраныстардың күшін жоя алады. Жоюдың нақты семантикасы әр сұраныстың өңдеушісіне байланысты болатын, негізінен бұл кез келген күтуді тоқтату керек дегенді білдіреді. Жартылай аяқталған операцияны қайтаруға болады.) ядро тағайындалған идентификатор, кез-келген асинхронды әрекетке берілген аргументтердің бірі 32 биттік пайдаланушы тағайындаған идентификатор болды. Көбінесе бұл функционалды нұсқағышты енгізу-шығару аяқталу әдісімен жұмыс жасайтын тиісті ішкі бағдарламаға сілтеме жасайды, бірақ бұл жай конвенция. Бұл мәнді түсіндіру үшін тұзақ кезегінің элементтерін оқыған ұйым болды.

құрылым itrq {                   / * Тұзақ кезегінен оқылатын мәліметтер құрылымы. * /        қысқа   it_stat;        / * Күйі * /        қысқа   it_rn;          / * Сұраныс нөмірі * /        ұзақ    ол_жоқ;         / * Иесінің идентификаторы сұрау бойынша беріледі * /        ұзақ    it_rpar;        / * Қайтарылған параметр * /};

Ескеретін жайт, асинхронды оқиғалар файлдардың дескрипторын оқу операциялары арқылы жиналды және мұндай оқудың өзі асинхронды бола алды. Бұл бір процестің ішінде болуы мүмкін оқиғаларды жартылай автономды асинхронды өңдеу пакеттеріне әсер етті. (DNIX 5.2-де болмады жеңіл процестер немесе жіптер.) Сонымен қатар ескеретін жайт кез келген ықтимал бұғаттау операциясы синхронды түрде шығарыла алды, сондықтан DNIX көптеген клиенттерді бір серверлік процесспен басқаруға жақсы жабдықталған. Процесс тек бір қақпан кезегінде тұрумен шектелмеген, сондықтан енгізу-шығару сұраныстарына осылайша басымдық берілуі мүмкін.

Үйлесімділік

Туғаннан басқа днекс (2) қоңырау, 'стандартты' толық жиынтығы libc интерфейс қоңырауы қол жетімді болды.ашық (2), жабу (2), оқу (2), жазу (2)Артқы үйлесімділікке пайдалы болумен қатар, олар екілік үйлесімді түрде орындалды NCR Tower компьютерді, DNIX-ке сәйкес екілік файлдар өзгеріссіз жұмыс істеуі үшін. DNIX ядросында екі тұзақ диспетчері болды, біреуі DNIX әдісі үшін, ал біреуі Unix әдісі үшін. Диспетчерді таңдау бағдарламашыға байланысты болды, ал екеуін бір-бірімен алмастыру әдісі қолданылды. Функционалдылық қай жерде қайталанса, олар бірдей болды. (Бұл машиналарда 68000 № 0 тұзақ үшін нұсқаулық қолданылды unix (2) қоңыраулар және №4 тұзақ нұсқаулық днекс (2). Екі тұзақ өңдеуші шынымен өте ұқсас болды, бірақ [әдетте жасырын] unix (2) қоңырау процессордың D0 регистрінде функция кодын ұстады, ал днекс (2) оны қалған параметрлермен бірге стекте ұстады.)

DNIX 5.2-де желілік протоколдар стегі болмады (жіңішке қоспағанда) X.25 - негізделген Ethernet хаттама стегі дискі жоқ жұмыс станциясының қолдау пакетін пайдалану үшін ISC қосқан), барлық желілерді өңдеу және өңдеуіштерге жазу арқылы жүргізілді. Осылайша, болмады розетка механизм, бірақ а ішкі ұяшық (3) TCP / IP өңдегішімен сөйлесу үшін асинхронды енгізу-шығару әдісін қолданған. Берклиден алынған әдеттегі желілік бағдарлама құрастырылып, өзгеріссіз жұмыс істей алады (әдеттегі Unix модулі бойынша) портинг проблемалар), дегенмен ол жергілікті асинхронды енгізу-шығаруды қолданған баламалы бағдарлама сияқты тиімді болмауы мүмкін.

Өңдеушілер

DNIX шеңберінде процесс енгізу-шығару сұраныстарын өңдеу және файлдық жүйені кеңейту үшін қолданыла алады. Мұндай процесс а деп аталды Өңдеуші, және операциялық жүйенің басты ерекшелігі болды. Өңдегіш дегенде кем дегенде біреуіне иелік ететін процесс ретінде анықталды сұраныс кезегі, екі жолдың бірімен сатып алынған арнайы файл дескрипторы: а F_ORQ немесе а F_MOUNT қоңырау. Біріншісі оқшауланған сұраныстың кезегін ойлап тапты, оның соңы әдетте баланың процесіне беріледі. (Желілік қашықтықтан орындау бағдарламалары, олардың көпшілігі осы әдісті балаларына енгізу-шығару стандартты жолдарын ұсыну үшін қолданды.) Соңғысы файлдық жүйеге қосылды, сондықтан файл енгізу-шығару сұраныстары өңдеушілер қабылдауы мүмкін еді. (Желіге кіру бағдарламалары, одан да көп, осы әдісті балаларына стандартты енгізу-шығару жолдарын ұсынды, өйткені Unix-ке кірудің семантикасы бірнеше байланысты емес процестердің стандартқа қосылуын талап етеді Операторға енгізу-шығару жолы.) Файлдық жүйеде каталогқа қондырылғаннан кейін өңдеуші сол кезде барлық енгізу-шығару қоңырауларын қабылдады.

Содан кейін өңдеуші сұраныстың кезегінен кіші ядроларға берілген сұраныс деректерінің құрылымын оқиды. (Мұндай оқуды өңдеуші автордың қалауы бойынша синхронды немесе асинхронды түрде жасауға болады.) Содан кейін өңдеуші әр сұранысты қанағаттандыру үшін, көбінесе DNIX қолданып, орындайтын. F_UREAD және F_UWRITE сұраныстың мәліметтер кеңістігіне оқуға және жазуға шақырады, содан кейін сұранысты тиісті түрде тоқтатады F_TERMIN. Артықшылығы бар өңдеуші өзінің клиентінің бағынышты өңдеушілерге (мысалы, файлдық жүйеге) жеке сұраныстары үшін рұқсаттарын қабылдай алады F_T1REQ қоңырау шалыңыз, сондықтан оған бағынушының рұқсат схемасын көбейтудің қажеті жоқ. Егер өңдеуші сұранысты өзі орындай алмаса, F_PASSRQ функциясы енгізу-шығару сұраныстарын бір өңдеушіден екіншісіне беру үшін қолданыла алады. Өңдеуші сұралған жұмыстың бір бөлігін басқа өңдеушіге бермей тұрып орындай алады. Өңдегіштің жай-күйіне бағдарлануы өте кең таралған, сондықтан клиенттің сұраныстары синхронды түрде орындалды. Бұл бір өңдеушіге бірнеше клиенттердің сұраныстарын бір-біріне орынсыз бұғаттамай бір уақытта жіберуге мүмкіндік берді. Сұраныс құрылымының бір бөлігі процесс идентификаторы және оның басымдығы болды, сондықтан өңдеуші осы ақпарат негізінде алдымен немен жұмыс істейтінін таңдай алады, жұмыс сұралатын тәртіппен орындалуы қажет емес. Бұған көмектесу үшін сұранысты және тұзақты кезектерді сұрастырып, оны орындау үшін төменге созылғанға дейін көбірек жұмыс бар-жоғын білу мүмкін болды.

құрылым ireq {                   / * Кіріс сұранысының құрылымы * /        қысқа   ir_fc;          / * Функция коды * /        қысқа   ir_rn;          / * Сұраныс нөмірі * /        ұзақ    ir_opid;        / * Сіз ашық немесе монтажда берген иесінің идентификаторы * /        ұзақ    ir_bc;          / * Байт саны * /        ұзақ    ir_upar;        / * Пайдаланушы параметрі * /        ұзақ    ir_rad;         / * Кездейсоқ мекен-жай * /        қысқаша  ir_uid;         /* Қолданушының ID */        қысқаша  ir_gid;         / * Пайдаланушылар тобы * /        уақыт_т  ir_time;        / * Сұраныс уақыты * /        улонг   ir_nph;        улонг   ir_npl;         / * Түйін және процесс идентификаторы * /};

Сұраныс кезектері процесінде болуы мүмкін шектеулер жоқ. Бұл желілік құралдармен қамтамасыз ету үшін пайдаланылды хроот мысалы, түрмелер.

Мысалдар

ISC өңдеушілерінің жұмысының тиімділігін бағалау үшін мыналар болған:

  • шетелдік файлдық жүйелер
    • FAT
    • CD-ROM /ISO9660
    • дискінің кескін файлдары
    • ЖЖҚ дискісі (жазудан қорғалған жүктеу дискілерінде қолдану үшін)
  • желілік хаттамалар
  • қашықтағы файлдық жүйелер
    • DNET оның / net / machine / path / from / its / root ...
    • NFS
  • қашықтан кіру
  • қашықтан орындау
    • rx (DNET )
    • ремш
    • rexec
  • жүйені кеңейту
    • терезеші (GUI)
    • vterm (xterm тәрізді)
    • құжат (кітапша) принтер
    • dmap (ruptime аналогы)
    • windowmac ​​(Macintosh-қа GUI шлюзі)
  • жүйелік патчтар
    • атты құбыр өңдеуші

ISC кеңейтімдері

ISC 5.2 екеуін де сатып алды (SVR2 үйлесімді) және 5.3 (SVR3 үйлесімді) DNIX нұсқалары. Сатып алу кезінде DNIX 5.3 әзірлеуден өтті DIAB сондықтан DNIX 5.2 қолданылды. Уақыт өте келе, ISC инженерлері өздерінің 5.3 ядросының көптеген ерекшеліктерін, ең алдымен, 5.2-ге енгізді ортақ жады және IPC, сондықтан кейбір ерекшеліктер арасында алшақтық болды DIAB және ISC-тің DNIX нұсқалары. DIAB 5.3 ISC 5.2 аяқталғаннан гөрі көп SVR3 мүмкіндіктерін қамтуы мүмкін. Сонымен қатар, DIAB DNIX 5.4, a SVR4 үйлесімді ОЖ.

ISC-де әзірлеушілер өздерінің DNIX 5.2 нұсқасын едәуір кеңейтті (тек тізімге енетін ерекшеліктер берілген ядро өзі) олардың қажеттіліктеріне және Unix индустриясының жалпы тенденцияларына негізделген:

  • Дисксіз жұмыс станциясын қолдау. Жұмыс станциясының ядро ​​файлдық жүйесі жойылды және оның орнына X.25 негізіндегі Ethernet байланыс стубы алынды. Файл серверінің ядросы қашықтағы сұраныстарды қабылдайтын және оларды ядро ​​процестерінің пулына қызмет көрсету үшін ұсынатын жұптастырушы компонентпен кеңейтілді, бірақ бұл үшін стандартты өңдеуші жазылуы мүмкін еді. (Кейінірек өнімнің өмірлік циклінде ISC стандартты қолданды SVR4 DNIX серверлерінің орнына негізделген Unix серверлері. Бұлар қолданылған X.25 АҒЫМДАР және арнайы дайындалған файл-сервер бағдарламасы. Тиімділігі аз құрылымға қарамастан, пайдаланылатын платформалардың шикі ат күші әлдеқайда жылдам серверге қол жеткізді. Өкінішке орай, бұл файл сервері бағдарламасы жергілікті DNIX серверінің барлық функционалдығын қолдамады. Ұқсас нәрселер құбырлар, ешқашан мүлдем жұмыс істемеген. Бұл аталған құбыр өңдеуші процесінің тағы бір негіздемесі болды.)
  • gdb ISC функцияларын қолдана отырып, бақылау нүктесін қолдау ММУ.
  • Асинхронды енгізу / шығару файлдық жүйеге нақты айналды. (Бастапқыда ол бәрібір бұғатталды.) Мұны істеу үшін ядро ​​процестері (kprocs немесе ағындар) пайдаланылды.
  • Фермаға қолдау стресс - ұқсас бағдарлама. Стандартты Unix-тегі қателерді жөндеуден басқа із бір сатылы механизм, бұл трассер қолданыстағы процестерде стандартты бір сатылы механизмді қолдана алатындай етіп уақытша қабылдау қондырғысын қосуды қажет етті.
  • SVR4 сигнал механизмді кеңейту. Ең алдымен, жаңа үшін ТОҚТА және ЖАЛҒАСЫ сигналдар, бірақ жаңа сигналды басқару қоңырауларын да қамтиды. ISC-тің бастапқы кодының болмауына байланысты адб және sdb дебагерлерінде u-парақ өзгертілмеді, сондықтан жаңа сигналдарды тек бұғаттауға немесе әдепкі өңдеуді қабылдауға болатын, сондықтан оларды ұстап алу мүмкін болмады.
  • Желіні қолдау иіскеу. Бұл кеңейтуді қажет етті Ethernet драйвер, сондықтан бір оқиға бірнеше енгізу-шығару сұранысын қанағаттандыра алады және қолдау үшін бағдарламалық жасақтамада аппараттық сүзуді шартты түрде жүзеге асырады азғындық режимі.
  • Дискіні шағылыстыру. Бұл құрылғының драйверінде емес, файлдық жүйеде жасалды, сондықтан әр түрлі құрылғылар бір-бірімен аздап (немесе тіпті толықтай) көрсетілуі мүмкін еді. Кішкентай қатты дискіні иілгішке шағылыстыру әйнекті тексерудің кең тараған әдісі болды, өйткені оны шығару дискінің қателіктерін тудыратын оңай әдіс болды.
  • 32 бит inode, 30 таңбадан тұратын файл атауы, символдық сілтеме, және жабысқақ файлдық жүйеге арналған кеңейтімдер. / Dev / нөл, / dev / шу, / dev / stdXXX және / dev / fd / X құрылғылары қосылды.
  • Процесс тобының идентификатор тізімдері (бастап SVR4 ).
  • #! сценарийдің тікелей орындалуы.
  • ISC көмегімен сериялық портты көбейту Z-80 негізделген VMEbus байланыс тақталары.
  • Жылжымалы своп бөлімі.
  • Орындалған процестердің негізгі 'демп' суреттері. Қолдау термобекіткіш команда.
  • Қайта өңдеу функциясы. Қозғалмалы басымдықтарды іске асыруға арналған уақытты бөлу репритизаторының байланыстырылған бағдарламасы.
  • Процесті оны бірден алып тастап, оны «кружка» жасау тәсілі барлық жады ресурстары. Ағымның қандай екенін анықтау үшін өте пайдалы жұмыс жиынтығы болып табылады, бірақ оған қол жетімді, бірақ оны пайдалану міндетті емес. Бұл процестің жад картасының барлық 1024 парағының күйін көрсететін GUI утилитасымен байланысты болды. (Бұл ISC MMU қолдайтын жад парақтарының саны.) Қолдану кезінде сіз мақсатты процесті оның өмірі бойымен мезгіл-мезгіл «кружкадан өткізіп», содан кейін қанша жадты ауыстырғанын көресіз. Бұл ISC өндірістік ортасы пайдаланылған кезде пайдалы болды. жадының қолданылуын және өсуін басқаратын ұзақ өмір сүретін бірнеше процестер өнімділікті сақтаудың кілті болды.

Ешқашан қосылмаған ерекшеліктер

1997 жылы ISC-де DNIX әзірлемесі тиімді түрде тоқтаған кезде, жоспарланған ОЖ-нің бірқатар ерекшеліктері кестеде қалды:

  • Ортақ нысандар - DNET үшін шифрлаушы және GUI бейнелеу кітапханасы бар динамикалық жүктелген екі кітапхана болған, бірақ бұл мекеме ешқашан жалпыланбаған. ISC машиналары жалпы жетіспеушілігімен сипатталды виртуалды мекенжай кеңістік, сондықтан жадпен бейнеленген нысандарды кең қолдану мүмкін болмас еді.
  • Жеңіл процестер - The ядро Бір MMU контекстімен бөлісетін бірнеше ағынның өзінде қолданушы процестеріне дейін жай болуы керек еді. The API салдары мұның ең қиын бөлігі болар еді.
  • Қатынауды басқару тізімдері - қор файлдық жүйесінде орнатылған ACL өңдегішін қолдану арқылы маңызды емес.
  • Бірнеше своп бөлімдері - DNIX ауыстыру үшін таңдалған көлемде бос орынды қолданған, оны кезекпен көруге болатын көлемдер тізімін беру оңай болар еді, мүмкін көлемнің барлық бос кеңістігін тұтынудан сақтап қалу үшін байланысты кеңістік шектерімен. келесіге өту.
  • Арқылы ядроны қашықтан жөндеу gdb - Мұнда әдеттегі сериялық порт немесе Ethernet арқылы ядро ​​ендірілген X.25 сілтеме бағдарламалық жасақтамасын қолдану арқылы жасауға болатын, бірақ олар ешқашан жиналмаған.
  • 68030 қолдау - ISC прототиптері ешқашан аяқталмаған. Екі қондырмалы плагин-карта жасалды, бірақ олар ешқашан 68020 жылдамдығынан артық пайдаланылмаған. Олар сенімді емес еді және олар 68020 ұясына сыйып кету мүмкін болғандықтан жылдам болмады. ISU MMU жылдам контексттік коммутациясы өшірулі болып қалады (және ұсынылатын өндірістік қондырғыларда мүлдем қалдырылады), және оның орнына DS80-20-нің MMU кодының туындысын қолданып, 68030-дің біреуі қолданылуы керек еді. MMU ISC өте тиімді болғанымен және 32 резиденттік процестердің арасында жедел ауысуға қолдау көрсеткенімен, адресатта өте шектеулі болды. 68030 MMU процесс кезінде 8 МВ виртуалды кеңістіктен әлдеқайда көп мүмкіндік алады, бұл MMU ISC шегі болды. Бұл MMU баяу болса да, 68030 жылдамдығының жалпы жылдамдығы оның орнын толтырудан гөрі көп болуы керек, сондықтан 68030 машинасы барлық жағынан тезірек болады және әлдеқайда үлкен процестерді қолдайды.

Сондай-ақ қараңыз

Әдебиеттер тізімі