Add the implementation of tfs
[thunix.git] / init / init.c
blob094a0adfa8bc0b8093455de0f69987eb57d08da6
1 #include <stdio.h>
2 #include <string.h>
3 #include <console.h>
4 #include <asm/system.h>
5 #include <asm/io.h>
6 #include <keyboard.h>
7 #include <timer.h>
8 #include <time.h>
9 #include <thunix.h>
10 #include <tfs.h>
11 #include <cache.h>
12 #include <dirent.h>
13 #include <fd.h>
14 /*#include <sched.h>*/
15 //#include <rd.h>
16 //#include <fs_ext2.h>
18 extern void trap_init(void);
19 extern void con_init(void);
20 extern void keyboard_init(void);
21 extern void timer_init(int);
22 extern long kernel_mktime(struct tm*);
23 extern void timer_interrupt(void);
24 extern void floppy_interrupt(void);
25 //extern void rd_init(void);
26 //extern void ram_ext2fs_init();
27 //extern void ext2_fs_init();
30 #define CMOS_READ(addr) ({ \
31 outb_p(addr, 0x70); \
32 inb_p(0x71); \
35 #define BCD_TO_BIN(val) ((val) = ((val)&0xF) + ((val)>>4)*10)
40 unsigned long get_current_time(struct tm * time)
42 unsigned long current_time;
43 do {
44 time->tm_sec = CMOS_READ(0);
45 time->tm_min = CMOS_READ(2);
46 time->tm_hour = CMOS_READ(4);
47 time->tm_mday = CMOS_READ(7);
48 time->tm_mon = CMOS_READ(8);
49 time->tm_year = CMOS_READ(9);
50 }while(time->tm_sec != CMOS_READ(0));
54 BCD_TO_BIN(time->tm_sec);
55 BCD_TO_BIN(time->tm_min);
56 BCD_TO_BIN(time->tm_hour);
57 BCD_TO_BIN(time->tm_mday);
58 BCD_TO_BIN(time->tm_mon);
59 BCD_TO_BIN(time->tm_year);
61 /* desrease for mktime to get the right seconds*/
62 time->tm_mon--;
63 current_time = kernel_mktime(time);
65 /* restore it */
66 time->tm_mon++;
68 return current_time;
75 /*
76 * Detecting Floppy Drives
78 void detect_floppy_drive()
80 /* First Getting the data from cmos */
81 int high, low;
82 unsigned char c;
83 outb_p (0x10, 0x70);
84 c = inb_p (0x71);
86 /* Decodding it... */
87 high = c >> 4;
88 low = c &0xF;
91 * Now, there are 5 official types of floppy drives that the most
92 * CMOSes can detect:
93 * Type of drive: Number the CMOS gives it:
94 * 360kb 5.25in 1
95 * 1.2mb 5.25in 2
96 * 720kb 3.5in 3
97 * 1.44mb 3.5in 4
98 * 2.88mb 3.5in 5
99 * No drive 0
101 char *drive_type[6] = {
102 "no floppy drive",
103 "360kb 5.25in floppy drive",
104 "1.2mb 5.25in floppy drive",
105 "720kb 3.5in", "1.44mb 3.5in",
106 "2.88mb 3.5in"
108 printk("Floppy drive A is an:\n");
109 printk(drive_type[high]);
110 printk("\nFloppy drive B is an:\n");
111 printk(drive_type[low]);
112 printk("\n");
117 extern unsigned long long * idt;
118 extern unsigned long timer_ticks;
119 extern unsigned long count_down;
120 extern char tmp_floppy_area[1024];
122 extern void keyboard_interrupt(void);
123 extern void do_timer(void);
124 extern unsigned long read_eip();
125 //extern void ram_mke2fs();
126 //extern struct m_inode *ext2_namei(char *);
128 extern void shell_init();
132 char *trap_msg = "Setting Interrupt Handling ...";
133 char *con_msg = "Console initialization ...";
134 char *kb_msg = "Keyboard initialization ...";
135 char *time_msg = "Timer clock initialization ...";
136 char *flp_msg = "Floppy initialization ...";
137 //char *rd_msg = "Ram disk initialization ...";
138 //char *ram_ext2_msg = "Ram ext2 fs initialization ...";
139 //char *ext2_msg = "Ext2 filesystem initialization ...";
140 //char *ram_mke2fs_msg = "Making Ram ext2 filesystem ...";
143 void init(void)
145 char ok[] = "[OK]";
146 unsigned long startup_time;
147 struct tm time;
148 struct tfs_sb_info *tfs_sbi;
150 cli();
152 malloc_init();
154 trap_init();
155 con_init();
157 printk("%s", kb_msg);
158 keyboard_init();
159 printk("\t\t%s\n", ok);
161 printk("%s", time_msg);
162 timer_init(100);
163 printk("\t\t%s\n", ok);
165 printk("Getting Current time ....");
166 startup_time = get_current_time(&time);
167 printk("\t\t%s\n", ok);
169 printk("%s", flp_msg);
170 floppy_init();
171 printk("\t\t%s\n", ok);
173 printk("mounting tfs image as root fs...");
174 tfs_sbi = tfs_mount();
175 printk("\t%s\n", ok);
177 printk("Cache system initialiaztion...");
178 cache_init(tfs_sbi);
179 printk("\t\t%s\n", ok);
183 printk("%s", rd_msg);
184 rd_init();
185 printk("\t\t%s\n", ok);
187 printk("%s", ram_ext2_msg);
188 ram_ext2fs_init();
189 printk("\t\t%s\n", ok);
191 printk("%s", ext2_msg);
192 ext2_fs_init();
193 printk("\t%s\n", ok);
195 printk("%s",ram_mke2fs_msg);
196 ram_mke2fs();
197 printk("\t\t%s\n", ok);
200 /* Hope it quite safe now */
201 sti();
206 #if 0 /* debug like, read curret eip or divide error */
207 memcpy((char *)0, "ERROR",4);
208 printk("%s\n",(char *)0);
209 printk("eip: %08x\n",read_eip());
210 a = a/b;
211 printk("eip: %08x\n",read_eip());
212 printk("eip: %0xx\n",get_eip());
213 #endif
217 #if 0
218 for (;;) {
219 __asm__ ("movb %%al, 0xb8000+160*24"::"a"(wheel[i]));
220 if (i == sizeof wheel)
221 i = 0;
222 else
223 ++i;
225 #endif
228 #if 0 /* idt addr test */
229 printk("num\taddr\t\tnum\taddr\n");
230 for (i = 0; i < 0x32;) {
231 printk("%x\t%08x\t",i,idt[i]&0xffff);
232 i++;
233 printk("%x\t%08x\n",i,idt[i]&0xffff);
234 i++;
236 #endif
239 #if 0 /* timer ticks test */
240 while (1) {
241 if (timer_ticks % 16 == 0)
242 printk("timer ticks: %08x\n",timer_ticks);
244 #endif
246 #if 0 /* count down And sleep test */
247 count_down = 10;
248 while (count_down) {
249 printk("counter rest : %08x\n", count_down);
250 sleep(9);
254 printk("timer_ticks:%d\n",timer_ticks);
255 sleep(500); /* sleep 5s */
256 printk("timer_ticks:%d\n",timer_ticks);
257 pause();
258 #endif
263 * the floppy driver is not ready , and i think....
266 #if 0 /*
267 * floppy driver test
269 * it seems work now! what a happy day - the last day of 2008
270 * And laterly the first day of 2009.
271 * but it always output something noisy...
274 * Bochs is exiting with the following message:
275 * [FDD ] read/write command: sector size 33554432 not supported
277 * and i got no idea. Please FIX ME.
281 char *buf = (char *)0x10000;
283 //detect_floppy_drive();
284 printk("floppy_interrupt addr:%08x\n",floppy_interrupt);
285 floppy_read(0, buf, 1);
286 printk("returned but not sure read_ok\n");
287 hexdump(buf, 64);
289 #endif
292 #if 0 /* EXT2_FS test */
293 /* debug */
294 extern char dir[8];
295 mkdir("/usr");
296 ls("/","-l");
297 ls(dir, "-l");
298 #endif
301 printk("\n");
302 printk("\t**************************\n");
303 printk("\t* *\n");
304 printk("\t* Welcome to Thunix *\n");
305 printk("\t* *\n");
306 printk("\t**************************\n");
307 printk("\tType 'help' for more information\n");
308 printk("\n");
311 shell_init();
313 pause();