diff --git a/src/SConscript b/src/SConscript index 77018f4d2c5e1b0674bdfd13f6be6d20c5ac6505..6f56c29ca69f94a82ff752ee94ddf9eed68e8453 100644 --- a/src/SConscript +++ b/src/SConscript @@ -2,12 +2,35 @@ Import('RTT_ROOT') Import('rtconfig') from building import * -src = Glob('*.c') +src = Split(''' +device.c +thread.c +scheduler.c +timer.c +irq.c +kservice.c +clock.c +object.c +mempool.c +ipc.c +idle.c +''') + CPPPATH = [RTT_ROOT + '/include'] if rtconfig.CROSS_TOOL == 'keil' and GetDepend('RT_USING_MODULE') == True: LINKFLAGS = ' --keep __rtmsym_* ' else: LINKFLAGS = '' + +if GetDepend('RT_USING_MODULE'): + src += Split('rtm.c') + src += Split('module.c') + +if GetDepend('RT_USING_SLAB'): + src += Split('slab.c') +else: + src += Split('mem.c') + group = DefineGroup('Kernel', src, depend = [''], CPPPATH = CPPPATH, LINKFLAGS = LINKFLAGS) Return('group') diff --git a/src/kservice.c b/src/kservice.c index 6ecb2a5995fe692b218af6173a014f48644bab1f..34a3e8032e34a3800ced898cb8d3205b98b36ab0 100644 --- a/src/kservice.c +++ b/src/kservice.c @@ -940,6 +940,16 @@ rt_int32_t rt_sprintf(char *buf, const char *format, ...) #ifdef RT_USING_CONSOLE #ifdef RT_USING_DEVICE +/** + * This function returns the device using in console. + * + * @return the device using in console or RT_NULL + */ +rt_device_t rt_console_get_device(void) +{ + return _console_device; +} + /** * This function will set a device as console device. * After set a device to console, all output of rt_kprintf will be