Systemova console

Dan Lukes dan at obluda.cz
Sun Aug 26 21:23:26 CEST 2007


	Mam tu WRAPa (to je takove male PC bez graficke karty) a k nemu pres 
LPC sbernici pripojeny vlastni QVGA display. Celkem bez problemu jsem si 
k nemu napsal syscon-compatible ovladac, takze mam v dev vice-mene 
standardni tty zarizeni. Potud celkem bez problemu.

	Nicmene, chtel bych z nej mit taky low-level systemovou konsoli.

	Zarizeni, ktera vubec teoreticky mohou byt takovou konzoli ma kernel 
ulozeny v globalni promenne cons_set. Ta vznika skrzeva makro 
CONS_DRIVER(name, ...) , ve kterem je DATA_SET(cons_set, name##_consdev)

	Makro DATA_SET(cons_set, name##_consdev) pochazi z linker_set.h a znamena:

static void const * const __set_cons_set_sym_name_consdev 
__section("set_", cons_set) __used=&name_consdev

	Vyrozumel jsem, ze jadrem triku je, ze pro kazdy takovy list je 
vytvoren specialni segment a protoze jednotlive polozky jsou v ruznych 
modluech ukladany do segmentu tohoto jednoho jmena, tak je linker pri 
sestavovani spoji do jednoho segmentu - cizm vznikne "souhrnny seznam".

	Ti, co pak potrebuji k seznamu pristup pouziji
SET_DECLARE(cons_set, struct consdev) coz vytvori dve promenne
extern struct consdev __start_set_cons_set
extern struct consdev __stop_set_cons_set

	Znalost zacatku a konce, spolecne se znamou velikosti jedne polozky 
umoznuji seznam prochazet.

	No a ted, po dlouhem uvodu, docela otazka velmi kratka - tenhle 
mechanismus funguj pouze pro staticky linking, nebo funguje i v pripade 
modulu dynamicky linkovanych do systemu ?

						Dan



-- 
Dan Lukes                                               SISAL MFF UK
AKA: dan at obluda.cz, dan at freebsd.cz, dan at (kolej.)mff.cuni.cz



More information about the Users-l mailing list