Changeset a33f0a6 in mainline for kernel/generic/src/console/console.c
- Timestamp:
- 2011-08-03T17:34:57Z (13 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 1940326
- Parents:
- 52a79081 (diff), 3fab770 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/generic/src/console/console.c
r52a79081 ra33f0a6 53 53 #include <str.h> 54 54 55 #define KLOG_PAGES 455 #define KLOG_PAGES 8 56 56 #define KLOG_LENGTH (KLOG_PAGES * PAGE_SIZE / sizeof(wchar_t)) 57 #define KLOG_LATENCY 858 57 59 58 /** Kernel log cyclic buffer */ … … 61 60 62 61 /** Kernel log initialized */ 63 static bool klog_inited = false;62 static atomic_t klog_inited = {false}; 64 63 65 64 /** First kernel log characters */ … … 76 75 77 76 /** Kernel log spinlock */ 78 SPINLOCK_STATIC_INITIALIZE_NAME(klog_lock, " *klog_lock");77 SPINLOCK_STATIC_INITIALIZE_NAME(klog_lock, "klog_lock"); 79 78 80 79 /** Physical memory area used for klog buffer */ … … 88 87 }; 89 88 90 static void stdout_write(outdev_t *, wchar_t , bool);89 static void stdout_write(outdev_t *, wchar_t); 91 90 static void stdout_redraw(outdev_t *); 92 91 … … 96 95 }; 97 96 98 /** Silence output */99 bool silent= false;97 /** Override kernel console lockout */ 98 bool console_override = false; 100 99 101 100 /** Standard input and output character devices */ … … 123 122 } 124 123 125 static void stdout_write(outdev_t *dev, wchar_t ch, bool silent) 126 { 127 link_t *cur; 128 129 for (cur = dev->list.next; cur != &dev->list; cur = cur->next) { 124 static void stdout_write(outdev_t *dev, wchar_t ch) 125 { 126 list_foreach(dev->list, cur) { 130 127 outdev_t *sink = list_get_instance(cur, outdev_t, link); 131 128 if ((sink) && (sink->op->write)) 132 sink->op->write(sink, ch , silent);129 sink->op->write(sink, ch); 133 130 } 134 131 } … … 136 133 static void stdout_redraw(outdev_t *dev) 137 134 { 138 link_t *cur; 139 140 for (cur = dev->list.next; cur != &dev->list; cur = cur->next) { 135 list_foreach(dev->list, cur) { 141 136 outdev_t *sink = list_get_instance(cur, outdev_t, link); 142 137 if ((sink) && (sink->op->redraw)) … … 161 156 klog_parea.frames = SIZE2FRAMES(sizeof(klog)); 162 157 klog_parea.unpriv = false; 158 klog_parea.mapped = false; 163 159 ddi_parea_register(&klog_parea); 164 160 … … 166 162 sysinfo_set_item_val("klog.pages", NULL, KLOG_PAGES); 167 163 168 spinlock_lock(&klog_lock); 169 klog_inited = true; 170 spinlock_unlock(&klog_lock); 164 event_set_unmask_callback(EVENT_KLOG, klog_update); 165 atomic_set(&klog_inited, true); 171 166 } 172 167 173 168 void grab_console(void) 174 169 { 175 bool prev = silent;176 177 silent = false;170 bool prev = console_override; 171 172 console_override = true; 178 173 if ((stdout) && (stdout->op->redraw)) 179 174 stdout->op->redraw(stdout); 180 175 181 if ((stdin) && ( prev)) {176 if ((stdin) && (!prev)) { 182 177 /* 183 178 * Force the console to print the prompt. … … 189 184 void release_console(void) 190 185 { 191 // FIXME arch_release_console 192 silent = true; 193 } 194 195 /** Tell kernel to get keyboard/console access again */ 196 sysarg_t sys_debug_enable_console(void) 186 console_override = false; 187 } 188 189 /** Activate kernel console override */ 190 sysarg_t sys_debug_activate_console(void) 197 191 { 198 192 #ifdef CONFIG_KCONSOLE … … 202 196 return false; 203 197 #endif 204 }205 206 /** Tell kernel to relinquish keyboard/console access */207 sysarg_t sys_debug_disable_console(void)208 {209 release_console();210 return true;211 198 } 212 199 … … 263 250 void klog_update(void) 264 251 { 252 if (!atomic_get(&klog_inited)) 253 return; 254 265 255 spinlock_lock(&klog_lock); 266 256 267 if ((klog_inited) && (event_is_subscribed(EVENT_KLOG)) && (klog_uspace > 0)) { 268 event_notify_3(EVENT_KLOG, klog_start, klog_len, klog_uspace); 269 klog_uspace = 0; 257 if (klog_uspace > 0) { 258 if (event_notify_3(EVENT_KLOG, true, klog_start, klog_len, 259 klog_uspace) == EOK) 260 klog_uspace = 0; 270 261 } 271 262 … … 275 266 void putchar(const wchar_t ch) 276 267 { 268 bool ordy = ((stdout) && (stdout->op->write)); 269 277 270 spinlock_lock(&klog_lock); 278 271 279 if ((klog_stored > 0) && (stdout) && (stdout->op->write)) { 280 /* Print charaters stored in kernel log */ 281 size_t i; 282 for (i = klog_len - klog_stored; i < klog_len; i++) 283 stdout->op->write(stdout, klog[(klog_start + i) % KLOG_LENGTH], silent); 284 klog_stored = 0; 272 /* Print charaters stored in kernel log */ 273 if (ordy) { 274 while (klog_stored > 0) { 275 wchar_t tmp = klog[(klog_start + klog_len - klog_stored) % KLOG_LENGTH]; 276 klog_stored--; 277 278 /* 279 * We need to give up the spinlock for 280 * the physical operation of writting out 281 * the character. 282 */ 283 spinlock_unlock(&klog_lock); 284 stdout->op->write(stdout, tmp); 285 spinlock_lock(&klog_lock); 286 } 285 287 } 286 288 … … 292 294 klog_start = (klog_start + 1) % KLOG_LENGTH; 293 295 294 if ((stdout) && (stdout->op->write)) 295 stdout->op->write(stdout, ch, silent); 296 else { 296 if (!ordy) { 297 if (klog_stored < klog_len) 298 klog_stored++; 299 } 300 301 /* The character is stored for uspace */ 302 if (klog_uspace < klog_len) 303 klog_uspace++; 304 305 spinlock_unlock(&klog_lock); 306 307 if (ordy) { 308 /* 309 * Output the character. In this case 310 * it should be no longer buffered. 311 */ 312 stdout->op->write(stdout, ch); 313 } else { 297 314 /* 298 315 * No standard output routine defined yet. … … 304 321 * Note that the early_putc() function might be 305 322 * a no-op on certain hardware configurations. 306 *307 323 */ 308 324 early_putchar(ch); 309 310 if (klog_stored < klog_len) 311 klog_stored++; 312 } 313 314 /* The character is stored for uspace */ 315 if (klog_uspace < klog_len) 316 klog_uspace++; 317 318 /* Check notify uspace to update */ 319 bool update; 320 if ((klog_uspace > KLOG_LATENCY) || (ch == '\n')) 321 update = true; 322 else 323 update = false; 324 325 spinlock_unlock(&klog_lock); 326 327 if (update) 325 } 326 327 /* Force notification on newline */ 328 if (ch == '\n') 328 329 klog_update(); 329 330 }
Note:
See TracChangeset
for help on using the changeset viewer.