- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
[...]
switch (dssdev->type) {
#ifdef CONFIG_OMAP2_DSS_DPI
case OMAP_DISPLAY_TYPE_DPI:
#endif
#ifdef CONFIG_OMAP2_DSS_RFBI
case OMAP_DISPLAY_TYPE_DBI:
#endif
#ifdef CONFIG_OMAP2_DSS_SDI
case OMAP_DISPLAY_TYPE_SDI:
#endif
#ifdef CONFIG_OMAP2_DSS_DSI
case OMAP_DISPLAY_TYPE_DSI:
#endif
#ifdef CONFIG_OMAP2_DSS_VENC
case OMAP_DISPLAY_TYPE_VENC:
#endif
#ifdef CONFIG_OMAP2_DSS_HDMI
case OMAP_DISPLAY_TYPE_HDMI:
#endif
break;
default:
DSSERR("Support for display '%s' not compiled in.\n",
dssdev->name);
return;
}
switch (dssdev->type) {
#ifdef CONFIG_OMAP2_DSS_DPI
case OMAP_DISPLAY_TYPE_DPI:
r = dpi_init_display(dssdev);
break;
#endif
#ifdef CONFIG_OMAP2_DSS_RFBI
case OMAP_DISPLAY_TYPE_DBI:
r = rfbi_init_display(dssdev);
break;
#endif
#ifdef CONFIG_OMAP2_DSS_VENC
case OMAP_DISPLAY_TYPE_VENC:
r = venc_init_display(dssdev);
break;
#endif
#ifdef CONFIG_OMAP2_DSS_SDI
case OMAP_DISPLAY_TYPE_SDI:
r = sdi_init_display(dssdev);
break;
#endif
#ifdef CONFIG_OMAP2_DSS_DSI
case OMAP_DISPLAY_TYPE_DSI:
r = dsi_init_display(dssdev);
break;
#endif
#ifdef CONFIG_OMAP2_DSS_HDMI
case OMAP_DISPLAY_TYPE_HDMI:
r = hdmi_init_display(dssdev);
break;
#endif
default:
BUG();
}
if (r) {
DSSERR("failed to init display %s\n", dssdev->name);
return;
}
[...]
linux kernel..
Драйвер контроллера дисплея (drivers/video/omap2/dss/display.c).
Про кошмар из #ifndef-ов молчу, но к чему первый switch?
ling 11.04.2011 14:41 # +10
Lure Of Chaos 11.04.2011 23:18 # +4
guest 11.04.2011 19:00 # 0
rat4 11.04.2011 22:23 # +4
А как по-другому обрабатывать конфиг ядра?
>но к чему первый switch?
Некроманты атакуют?
http://git.kernel.org/?p=linux/kernel/git/next/linux-next.git;a=commit;h=e528e3a8b4e005e6e2c9 e50fdee1ab7e84cf1e27
grub670 12.04.2011 10:58 # −1
это надо в .h файлах делать, а не в коде. В гайдлайнах это прямо указано.
>http://git.kernel.org/?p=linux/kernel/git/next/linux-next.git;a=commit;h=e528e3a8b4e005e6e2c9 e50fdee1ab7e84cf1e27
наконец то :) жаль что только в next
это ты поправил?
grub670 12.04.2011 11:06 # +1
TheCalligrapher 13.04.2011 02:52 # 0
Можно было, конечно, одним свичем сделать, но вот авторам захотелось так...
Govnoeb 13.04.2011 14:03 # 0
Govnoeb 13.04.2011 14:07 # −2
а хули?
TheCalligrapher 13.04.2011 20:53 # −1
Govnoeb 15.04.2011 16:59 # 0