various formatting improvements
This commit is contained in:
@@ -1,3 +1,2 @@
|
|||||||
// ADD PREDEFINED MACROS HERE!
|
// Add predefined macros for your project here. For example:
|
||||||
#define MACHINE_FIREBEE
|
// #define THE_ANSWER 42
|
||||||
// #define MACHINE_M5484LITE
|
|
||||||
|
|||||||
@@ -4,232 +4,19 @@ dma/MCD_tasks.c
|
|||||||
dma/MCD_tasksInit.c
|
dma/MCD_tasksInit.c
|
||||||
exe/basflash.c
|
exe/basflash.c
|
||||||
exe/basflash_start.c
|
exe/basflash_start.c
|
||||||
flash/flash.c
|
|
||||||
flash/s19reader.c
|
|
||||||
fs/cc932.c
|
|
||||||
fs/cc936.c
|
|
||||||
fs/cc949.c
|
|
||||||
fs/cc950.c
|
|
||||||
fs/ccsbcs.c
|
|
||||||
fs/ff.c
|
|
||||||
fs/unicode.c
|
|
||||||
if/driver_vec.c
|
|
||||||
include/acia.h
|
|
||||||
include/am79c874.h
|
|
||||||
include/arp.h
|
|
||||||
include/ati_ids.h
|
|
||||||
include/bas_printf.h
|
|
||||||
include/bas_string.h
|
|
||||||
include/bas_types.h
|
|
||||||
include/bas_utils.h
|
|
||||||
include/bcm5222.h
|
|
||||||
include/bootp.h
|
|
||||||
include/cache.h
|
|
||||||
include/diskio.h
|
|
||||||
include/dma.h
|
|
||||||
include/driver_mem.h
|
|
||||||
include/driver_vec.h
|
|
||||||
include/edid.h
|
|
||||||
include/ehci.h
|
|
||||||
include/eth.h
|
|
||||||
include/exceptions.h
|
|
||||||
include/fb.h
|
|
||||||
include/fec.h
|
|
||||||
include/fecbd.h
|
|
||||||
include/ff.h
|
|
||||||
include/ffconf.h
|
|
||||||
include/firebee.h
|
|
||||||
include/font.h
|
|
||||||
include/i2c-algo-bit.h
|
|
||||||
include/i2c.h
|
|
||||||
include/icmp.h
|
|
||||||
include/ikbd.h
|
|
||||||
include/interrupts.h
|
|
||||||
include/ip.h
|
|
||||||
include/m54455.h
|
|
||||||
include/m5484l.h
|
|
||||||
include/MCD_dma.h
|
|
||||||
include/mcd_initiators.h
|
|
||||||
include/MCD_progCheck.h
|
|
||||||
include/MCD_tasksInit.h
|
|
||||||
include/MCF5475.h
|
|
||||||
include/MCF5475_CLOCK.h
|
|
||||||
include/MCF5475_CTM.h
|
|
||||||
include/MCF5475_DMA.h
|
|
||||||
include/MCF5475_DSPI.h
|
|
||||||
include/MCF5475_EPORT.h
|
|
||||||
include/MCF5475_FBCS.h
|
|
||||||
include/MCF5475_FEC.h
|
|
||||||
include/MCF5475_GPIO.h
|
|
||||||
include/MCF5475_GPT.h
|
|
||||||
include/MCF5475_I2C.h
|
|
||||||
include/MCF5475_INTC.h
|
|
||||||
include/MCF5475_MMU.h
|
|
||||||
include/MCF5475_PAD.h
|
|
||||||
include/MCF5475_PCI.h
|
|
||||||
include/MCF5475_PCIARB.h
|
|
||||||
include/MCF5475_PSC.h
|
|
||||||
include/MCF5475_SDRAMC.h
|
|
||||||
include/MCF5475_SEC.h
|
|
||||||
include/MCF5475_SIU.h
|
|
||||||
include/MCF5475_SLT.h
|
|
||||||
include/MCF5475_SRAM.h
|
|
||||||
include/MCF5475_USB.h
|
|
||||||
include/MCF5475_XLB.h
|
|
||||||
include/mmu.h
|
|
||||||
include/mod_devicetable.h
|
|
||||||
include/nbuf.h
|
|
||||||
include/net.h
|
|
||||||
include/net_timer.h
|
|
||||||
include/nif.h
|
|
||||||
include/ohci.h
|
|
||||||
include/part.h
|
|
||||||
include/pci.h
|
|
||||||
include/pci_ids.h
|
|
||||||
include/queue.h
|
|
||||||
include/radeon_reg.h
|
|
||||||
include/radeonfb.h
|
|
||||||
include/s19reader.h
|
|
||||||
include/screen.h
|
|
||||||
include/sd_card.h
|
|
||||||
include/startcf.h
|
|
||||||
include/sysinit.h
|
|
||||||
include/tftp.h
|
|
||||||
include/udp.h
|
|
||||||
include/usb.h
|
|
||||||
include/usb_defs.h
|
|
||||||
include/usb_hub.h
|
|
||||||
include/user_io.h
|
|
||||||
include/util.h
|
|
||||||
include/version.h
|
|
||||||
include/videl.h
|
|
||||||
include/video.h
|
|
||||||
include/wait.h
|
|
||||||
include/x86debug.h
|
|
||||||
include/x86decode.h
|
|
||||||
include/x86emu.h
|
|
||||||
include/x86emui.h
|
|
||||||
include/x86fpu.h
|
|
||||||
include/x86fpu_regs.h
|
|
||||||
include/x86ops.h
|
|
||||||
include/x86pcibios.h
|
|
||||||
include/x86prim_asm.h
|
|
||||||
include/x86prim_ops.h
|
|
||||||
include/x86regs.h
|
|
||||||
include/xhdi_sd.h
|
|
||||||
kbd/ikbd.c
|
|
||||||
net/am79c874.c
|
|
||||||
net/arp.c
|
|
||||||
net/bcm5222.c
|
|
||||||
net/bootp.c
|
|
||||||
net/fec.c
|
|
||||||
net/fecbd.c
|
|
||||||
net/ip.c
|
|
||||||
net/nbuf.c
|
|
||||||
net/net_timer.c
|
|
||||||
net/nif.c
|
|
||||||
net/queue.c
|
|
||||||
net/tftp.c
|
|
||||||
net/udp.c
|
|
||||||
nutil/s19header.c
|
|
||||||
pci/ehci-hcd.c
|
|
||||||
pci/ohci-hcd.c
|
|
||||||
pci/pci.c
|
|
||||||
radeon/radeon_accel.c
|
|
||||||
radeon/radeon_base.c
|
|
||||||
radeon/radeon_cursor.c
|
|
||||||
radeon/radeon_monitor.c
|
|
||||||
spi/dspi.c
|
|
||||||
spi/mmc.c
|
|
||||||
spi/sd_card.c
|
|
||||||
sys/BaS.c
|
|
||||||
sys/cache.c
|
|
||||||
sys/driver_mem.c
|
|
||||||
sys/fault_vectors.c
|
|
||||||
sys/init_fpga.c
|
|
||||||
sys/interrupts.c
|
|
||||||
sys/mmu.c
|
|
||||||
sys/sysinit.c
|
|
||||||
tos/bascook/sources/bascook.c
|
|
||||||
tos/jtagwait/include/bas_printf.h
|
|
||||||
tos/jtagwait/include/bas_string.h
|
|
||||||
tos/jtagwait/include/driver_vec.h
|
|
||||||
tos/jtagwait/include/MCF5475.h
|
|
||||||
tos/jtagwait/include/MCF5475_CLOCK.h
|
|
||||||
tos/jtagwait/include/MCF5475_CTM.h
|
|
||||||
tos/jtagwait/include/MCF5475_DMA.h
|
|
||||||
tos/jtagwait/include/MCF5475_DSPI.h
|
|
||||||
tos/jtagwait/include/MCF5475_EPORT.h
|
|
||||||
tos/jtagwait/include/MCF5475_FBCS.h
|
|
||||||
tos/jtagwait/include/MCF5475_FEC.h
|
|
||||||
tos/jtagwait/include/MCF5475_GPIO.h
|
|
||||||
tos/jtagwait/include/MCF5475_GPT.h
|
|
||||||
tos/jtagwait/include/MCF5475_I2C.h
|
|
||||||
tos/jtagwait/include/MCF5475_INTC.h
|
|
||||||
tos/jtagwait/include/MCF5475_MMU.h
|
|
||||||
tos/jtagwait/include/MCF5475_PAD.h
|
|
||||||
tos/jtagwait/include/MCF5475_PCI.h
|
|
||||||
tos/jtagwait/include/MCF5475_PCIARB.h
|
|
||||||
tos/jtagwait/include/MCF5475_PSC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SDRAMC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SEC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SIU.h
|
|
||||||
tos/jtagwait/include/MCF5475_SLT.h
|
|
||||||
tos/jtagwait/include/MCF5475_SRAM.h
|
|
||||||
tos/jtagwait/include/MCF5475_USB.h
|
|
||||||
tos/jtagwait/include/MCF5475_XLB.h
|
|
||||||
tos/jtagwait/sources/jtagwait.c
|
|
||||||
usb/usb.c
|
|
||||||
usb/usb_hub.c
|
|
||||||
usb/usb_kbd.c
|
|
||||||
tos/jtagwait/sources/bas_printf.c
|
|
||||||
tos/jtagwait/sources/bas_string.c
|
|
||||||
tos/vmem_test/Makefile
|
|
||||||
sys/startcf.S
|
|
||||||
sys/exceptions.S
|
|
||||||
util/bas_printf.c
|
|
||||||
util/bas_string.c
|
|
||||||
util/wait.c
|
|
||||||
bas.lk.in
|
|
||||||
i2c/i2c.c
|
|
||||||
Makefile
|
|
||||||
x86emu/x86biosemu.c
|
|
||||||
x86emu/x86emu.c
|
|
||||||
x86emu/x86pcibios.c
|
|
||||||
util/libgcc_helper.S
|
|
||||||
util/setjmp.c
|
|
||||||
util/setjmp.S
|
|
||||||
include/x86emu_regs.h
|
|
||||||
x86emu/x86emu_util.c
|
|
||||||
include/setjmp.h
|
|
||||||
video/video.c
|
|
||||||
video/fbmem.c
|
|
||||||
video/fbmodedb.c
|
|
||||||
video/fbmon.c
|
|
||||||
video/fnt_st_8x16.c
|
|
||||||
video/offscreen.c
|
|
||||||
video/vdi_fill.c
|
|
||||||
video/videl.c
|
|
||||||
video/video.c
|
|
||||||
tos/jtagwait/Makefile
|
|
||||||
tos/Makefile
|
|
||||||
dma/dma.c
|
|
||||||
dma/MCD_dmaApi.c
|
|
||||||
dma/MCD_tasks.c
|
|
||||||
dma/MCD_tasksInit.c
|
|
||||||
exe/basflash.c
|
|
||||||
exe/basflash_start.c
|
|
||||||
firebee/bas.elf
|
firebee/bas.elf
|
||||||
firebee/bas.lk
|
firebee/bas.lk
|
||||||
firebee/bas.map
|
firebee/bas.map
|
||||||
firebee/bas.s19
|
firebee/bas.s19
|
||||||
firebee/basflash.elf
|
firebee/basflash.elf
|
||||||
|
firebee/basflash.lk
|
||||||
firebee/basflash.map
|
firebee/basflash.map
|
||||||
firebee/basflash.s19
|
firebee/basflash.s19
|
||||||
firebee/bashflash.lk
|
|
||||||
firebee/depend
|
firebee/depend
|
||||||
|
firebee/libbas.a
|
||||||
firebee/ram.elf
|
firebee/ram.elf
|
||||||
firebee/ram.lk
|
firebee/ram.lk
|
||||||
|
firebee/ram.map
|
||||||
firebee/ram.s19
|
firebee/ram.s19
|
||||||
flash/flash.c
|
flash/flash.c
|
||||||
flash/s19reader.c
|
flash/s19reader.c
|
||||||
@@ -240,6 +27,9 @@ flash_scripts/flash_firebee_fpga.bdm
|
|||||||
flash_scripts/flash_m548x_bas.bdm
|
flash_scripts/flash_m548x_bas.bdm
|
||||||
flash_scripts/flash_m548x_dbug.bdm
|
flash_scripts/flash_m548x_dbug.bdm
|
||||||
flash_scripts/flash_m548x_etos.bdm
|
flash_scripts/flash_m548x_etos.bdm
|
||||||
|
flash_scripts/m548xlite_dbug_ram.elf
|
||||||
|
flash_scripts/m548xlite_dbug_ram.s19
|
||||||
|
flash_scripts/run_m548x_dbug.bdm
|
||||||
fs/cc932.c
|
fs/cc932.c
|
||||||
fs/cc936.c
|
fs/cc936.c
|
||||||
fs/cc949.c
|
fs/cc949.c
|
||||||
@@ -260,6 +50,8 @@ include/bas_utils.h
|
|||||||
include/bcm5222.h
|
include/bcm5222.h
|
||||||
include/bootp.h
|
include/bootp.h
|
||||||
include/cache.h
|
include/cache.h
|
||||||
|
include/conout.h
|
||||||
|
include/debug.h
|
||||||
include/diskio.h
|
include/diskio.h
|
||||||
include/dma.h
|
include/dma.h
|
||||||
include/driver_mem.h
|
include/driver_mem.h
|
||||||
@@ -320,6 +112,7 @@ include/nif.h
|
|||||||
include/ohci.h
|
include/ohci.h
|
||||||
include/part.h
|
include/part.h
|
||||||
include/pci.h
|
include/pci.h
|
||||||
|
include/pci_errata.h
|
||||||
include/pci_ids.h
|
include/pci_ids.h
|
||||||
include/queue.h
|
include/queue.h
|
||||||
include/radeon_reg.h
|
include/radeon_reg.h
|
||||||
@@ -351,24 +144,28 @@ m54455/bas.lk
|
|||||||
m54455/bas.map
|
m54455/bas.map
|
||||||
m54455/bas.s19
|
m54455/bas.s19
|
||||||
m54455/basflash.elf
|
m54455/basflash.elf
|
||||||
|
m54455/basflash.lk
|
||||||
m54455/basflash.map
|
m54455/basflash.map
|
||||||
m54455/basflash.s19
|
m54455/basflash.s19
|
||||||
m54455/bashflash.lk
|
|
||||||
m54455/depend
|
m54455/depend
|
||||||
|
m54455/libbas.a
|
||||||
m54455/ram.elf
|
m54455/ram.elf
|
||||||
m54455/ram.lk
|
m54455/ram.lk
|
||||||
|
m54455/ram.map
|
||||||
m54455/ram.s19
|
m54455/ram.s19
|
||||||
m5484lite/bas.elf
|
m5484lite/bas.elf
|
||||||
m5484lite/bas.lk
|
m5484lite/bas.lk
|
||||||
m5484lite/bas.map
|
m5484lite/bas.map
|
||||||
m5484lite/bas.s19
|
m5484lite/bas.s19
|
||||||
m5484lite/basflash.elf
|
m5484lite/basflash.elf
|
||||||
|
m5484lite/basflash.lk
|
||||||
m5484lite/basflash.map
|
m5484lite/basflash.map
|
||||||
m5484lite/basflash.s19
|
m5484lite/basflash.s19
|
||||||
m5484lite/bashflash.lk
|
|
||||||
m5484lite/depend
|
m5484lite/depend
|
||||||
|
m5484lite/libbas.a
|
||||||
m5484lite/ram.elf
|
m5484lite/ram.elf
|
||||||
m5484lite/ram.lk
|
m5484lite/ram.lk
|
||||||
|
m5484lite/ram.map
|
||||||
m5484lite/ram.s19
|
m5484lite/ram.s19
|
||||||
net/am79c874.c
|
net/am79c874.c
|
||||||
net/arp.c
|
net/arp.c
|
||||||
@@ -387,11 +184,18 @@ nutil/s19header.c
|
|||||||
pci/ehci-hcd.c
|
pci/ehci-hcd.c
|
||||||
pci/ohci-hcd.c
|
pci/ohci-hcd.c
|
||||||
pci/pci.c
|
pci/pci.c
|
||||||
|
pci/pci_errata.c
|
||||||
pci/pci_wrappers.S
|
pci/pci_wrappers.S
|
||||||
|
radeon/i2c-algo-bit.c
|
||||||
radeon/radeon_accel.c
|
radeon/radeon_accel.c
|
||||||
radeon/radeon_base.c
|
radeon/radeon_base.c
|
||||||
radeon/radeon_cursor.c
|
radeon/radeon_cursor.c
|
||||||
|
radeon/radeon_i2c.c
|
||||||
radeon/radeon_monitor.c
|
radeon/radeon_monitor.c
|
||||||
|
release/firebee/bas.s19
|
||||||
|
release/m5484lite/bas.s19
|
||||||
|
release/bascook.prg
|
||||||
|
release/readme.txt
|
||||||
spi/dspi.c
|
spi/dspi.c
|
||||||
spi/mmc.c
|
spi/mmc.c
|
||||||
spi/sd_card.c
|
spi/sd_card.c
|
||||||
@@ -408,8 +212,14 @@ sys/sysinit.c
|
|||||||
tos/bascook/sources/bascook.c
|
tos/bascook/sources/bascook.c
|
||||||
tos/bascook/bascook.prg
|
tos/bascook/bascook.prg
|
||||||
tos/bascook/depend
|
tos/bascook/depend
|
||||||
tos/bascook/Makefile
|
|
||||||
tos/bascook/mapfile
|
tos/bascook/mapfile
|
||||||
|
tos/fpga_test/m5475/mshort/fpga_test.prg
|
||||||
|
tos/fpga_test/m5475/fpga_test.prg
|
||||||
|
tos/fpga_test/sources/fpga_test.c
|
||||||
|
tos/fpga_test/sources/ser_printf.c
|
||||||
|
tos/fpga_test/sources/vmem_test.c
|
||||||
|
tos/fpga_test/depend
|
||||||
|
tos/fpga_test/mapfile
|
||||||
tos/jtagwait/include/bas_printf.h
|
tos/jtagwait/include/bas_printf.h
|
||||||
tos/jtagwait/include/bas_string.h
|
tos/jtagwait/include/bas_string.h
|
||||||
tos/jtagwait/include/driver_vec.h
|
tos/jtagwait/include/driver_vec.h
|
||||||
@@ -444,318 +254,7 @@ tos/jtagwait/sources/bas_string.c
|
|||||||
tos/jtagwait/sources/jtagwait.c
|
tos/jtagwait/sources/jtagwait.c
|
||||||
tos/jtagwait/sources/printf_helper.S
|
tos/jtagwait/sources/printf_helper.S
|
||||||
tos/jtagwait/depend
|
tos/jtagwait/depend
|
||||||
tos/jtagwait/jtagwait.config
|
|
||||||
tos/jtagwait/jtagwait.creator
|
|
||||||
tos/jtagwait/jtagwait.creator.user
|
|
||||||
tos/jtagwait/jtagwait.files
|
|
||||||
tos/jtagwait/jtagwait.includes
|
|
||||||
tos/jtagwait/Makefile
|
|
||||||
tos/jtagwait/mapfile
|
tos/jtagwait/mapfile
|
||||||
tos/pci_test/include/bas_string.h
|
|
||||||
tos/pci_test/include/driver_vec.h
|
|
||||||
tos/pci_test/include/MCF5475.h
|
|
||||||
tos/pci_test/include/MCF5475_CLOCK.h
|
|
||||||
tos/pci_test/include/MCF5475_CTM.h
|
|
||||||
tos/pci_test/include/MCF5475_DMA.h
|
|
||||||
tos/pci_test/include/MCF5475_DSPI.h
|
|
||||||
tos/pci_test/include/MCF5475_EPORT.h
|
|
||||||
tos/pci_test/include/MCF5475_FBCS.h
|
|
||||||
tos/pci_test/include/MCF5475_FEC.h
|
|
||||||
tos/pci_test/include/MCF5475_GPIO.h
|
|
||||||
tos/pci_test/include/MCF5475_GPT.h
|
|
||||||
tos/pci_test/include/MCF5475_I2C.h
|
|
||||||
tos/pci_test/include/MCF5475_INTC.h
|
|
||||||
tos/pci_test/include/MCF5475_MMU.h
|
|
||||||
tos/pci_test/include/MCF5475_PAD.h
|
|
||||||
tos/pci_test/include/MCF5475_PCI.h
|
|
||||||
tos/pci_test/include/MCF5475_PCIARB.h
|
|
||||||
tos/pci_test/include/MCF5475_PSC.h
|
|
||||||
tos/pci_test/include/MCF5475_SDRAMC.h
|
|
||||||
tos/pci_test/include/MCF5475_SEC.h
|
|
||||||
tos/pci_test/include/MCF5475_SIU.h
|
|
||||||
tos/pci_test/include/MCF5475_SLT.h
|
|
||||||
tos/pci_test/include/MCF5475_SRAM.h
|
|
||||||
tos/pci_test/include/MCF5475_USB.h
|
|
||||||
tos/pci_test/include/MCF5475_XLB.h
|
|
||||||
tos/pci_test/m5475/mshort/pci_test.prg
|
|
||||||
tos/pci_test/m5475/pci_test.prg
|
|
||||||
tos/pci_test/sources/pci_test.c
|
|
||||||
tos/pci_test/sources/printf_helper.S
|
|
||||||
tos/pci_test/depend
|
|
||||||
tos/pci_test/Makefile
|
|
||||||
tos/pci_test/mapfile
|
|
||||||
tos/pci_test/pci_test.config
|
|
||||||
tos/pci_test/pci_test.creator
|
|
||||||
tos/pci_test/pci_test.files
|
|
||||||
tos/pci_test/pci_test.includes
|
|
||||||
tos/vmem_test/include/bas_printf.h
|
|
||||||
tos/vmem_test/include/bas_string.h
|
|
||||||
tos/vmem_test/include/driver_vec.h
|
|
||||||
tos/vmem_test/include/MCF5475.h
|
|
||||||
tos/vmem_test/include/MCF5475_CLOCK.h
|
|
||||||
tos/vmem_test/include/MCF5475_CTM.h
|
|
||||||
tos/vmem_test/include/MCF5475_DMA.h
|
|
||||||
tos/vmem_test/include/MCF5475_DSPI.h
|
|
||||||
tos/vmem_test/include/MCF5475_EPORT.h
|
|
||||||
tos/vmem_test/include/MCF5475_FBCS.h
|
|
||||||
tos/vmem_test/include/MCF5475_FEC.h
|
|
||||||
tos/vmem_test/include/MCF5475_GPIO.h
|
|
||||||
tos/vmem_test/include/MCF5475_GPT.h
|
|
||||||
tos/vmem_test/include/MCF5475_I2C.h
|
|
||||||
tos/vmem_test/include/MCF5475_INTC.h
|
|
||||||
tos/vmem_test/include/MCF5475_MMU.h
|
|
||||||
tos/vmem_test/include/MCF5475_PAD.h
|
|
||||||
tos/vmem_test/include/MCF5475_PCI.h
|
|
||||||
tos/vmem_test/include/MCF5475_PCIARB.h
|
|
||||||
tos/vmem_test/include/MCF5475_PSC.h
|
|
||||||
tos/vmem_test/include/MCF5475_SDRAMC.h
|
|
||||||
tos/vmem_test/include/MCF5475_SEC.h
|
|
||||||
tos/vmem_test/include/MCF5475_SIU.h
|
|
||||||
tos/vmem_test/include/MCF5475_SLT.h
|
|
||||||
tos/vmem_test/include/MCF5475_SRAM.h
|
|
||||||
tos/vmem_test/include/MCF5475_USB.h
|
|
||||||
tos/vmem_test/include/MCF5475_XLB.h
|
|
||||||
tos/vmem_test/m5475/mshort/vmem_test.prg
|
|
||||||
tos/vmem_test/m5475/vmem_test.prg
|
|
||||||
tos/vmem_test/Makefile
|
|
||||||
tos/vmem_test/mapfile
|
|
||||||
tos/vmem_test/vmem_test.config
|
|
||||||
tos/vmem_test/vmem_test.creator
|
|
||||||
tos/vmem_test/vmem_test.files
|
|
||||||
tos/vmem_test/vmem_test.includes
|
|
||||||
tos/Makefile
|
|
||||||
usb/usb.c
|
|
||||||
usb/usb_hub.c
|
|
||||||
usb/usb_kbd.c
|
|
||||||
usb/usb_mouse.c
|
|
||||||
util/bas_printf.c
|
|
||||||
util/bas_string.c
|
|
||||||
util/libgcc_helper.S
|
|
||||||
util/setjmp.S
|
|
||||||
util/wait.c
|
|
||||||
video/fbmem.c
|
|
||||||
video/fbmodedb.c
|
|
||||||
video/fbmon.c
|
|
||||||
video/fnt_st_8x16.c
|
|
||||||
video/offscreen.c
|
|
||||||
video/vdi_fill.c
|
|
||||||
video/videl.c
|
|
||||||
video/video.c
|
|
||||||
x86emu/x86biosemu.c
|
|
||||||
x86emu/x86emu.c
|
|
||||||
x86emu/x86emu_util.c
|
|
||||||
x86emu/x86pcibios.c
|
|
||||||
xhdi/xhdi_interface.c
|
|
||||||
xhdi/xhdi_sd.c
|
|
||||||
xhdi/xhdi_vec.S
|
|
||||||
bas.lk.in
|
|
||||||
bas_firebee.bdm
|
|
||||||
BaS_gcc.config
|
|
||||||
BaS_gcc.creator
|
|
||||||
BaS_gcc.creator.user
|
|
||||||
BaS_gcc.creator.user.3.2-pre1
|
|
||||||
BaS_gcc.creator.user.ori
|
|
||||||
BaS_gcc.files
|
|
||||||
BaS_gcc.includes
|
|
||||||
bas_m5484.bdm
|
|
||||||
basflash.lk.in
|
|
||||||
check.bdm
|
|
||||||
COPYING
|
|
||||||
COPYING.LESSER
|
|
||||||
Doxyfile
|
|
||||||
dump.bdm
|
|
||||||
Makefile
|
|
||||||
mcf5474.gdb
|
|
||||||
tos/pci_test/include/bas_printf.h
|
|
||||||
tos/pci_test/include/bas_string.h
|
|
||||||
tos/pci_test/include/driver_vec.h
|
|
||||||
tos/pci_test/include/MCF5475_CLOCK.h
|
|
||||||
tos/pci_test/include/MCF5475_CTM.h
|
|
||||||
tos/pci_test/include/MCF5475_DMA.h
|
|
||||||
tos/pci_test/include/MCF5475_DSPI.h
|
|
||||||
tos/pci_test/include/MCF5475_EPORT.h
|
|
||||||
tos/pci_test/include/MCF5475_FBCS.h
|
|
||||||
tos/pci_test/include/MCF5475_FEC.h
|
|
||||||
tos/pci_test/include/MCF5475_GPIO.h
|
|
||||||
tos/pci_test/include/MCF5475_GPT.h
|
|
||||||
tos/pci_test/include/MCF5475_I2C.h
|
|
||||||
tos/pci_test/include/MCF5475_INTC.h
|
|
||||||
tos/pci_test/include/MCF5475_MMU.h
|
|
||||||
tos/pci_test/include/MCF5475_PAD.h
|
|
||||||
tos/pci_test/include/MCF5475_PCI.h
|
|
||||||
tos/pci_test/include/MCF5475_PCIARB.h
|
|
||||||
tos/pci_test/include/MCF5475_PSC.h
|
|
||||||
tos/pci_test/include/MCF5475_SDRAMC.h
|
|
||||||
tos/pci_test/include/MCF5475_SEC.h
|
|
||||||
tos/pci_test/include/MCF5475_SIU.h
|
|
||||||
tos/pci_test/include/MCF5475_SLT.h
|
|
||||||
tos/pci_test/include/MCF5475_SRAM.h
|
|
||||||
tos/pci_test/include/MCF5475_USB.h
|
|
||||||
tos/pci_test/include/MCF5475_XLB.h
|
|
||||||
tos/pci_test/include/MCF5475.h
|
|
||||||
tos/pci_test/include/pci.h
|
|
||||||
memory_map.txt
|
|
||||||
pci/pci_errata.c
|
|
||||||
include/pci_errata.h
|
|
||||||
tos/bascook/sources/bascook.c
|
|
||||||
tos/bascook/Makefile
|
|
||||||
tos/fpga_test/Makefile
|
|
||||||
tos/jtagwait/include/bas_printf.h
|
|
||||||
tos/jtagwait/include/bas_string.h
|
|
||||||
tos/jtagwait/include/driver_vec.h
|
|
||||||
tos/jtagwait/include/MCF5475.h
|
|
||||||
tos/jtagwait/include/MCF5475_CLOCK.h
|
|
||||||
tos/jtagwait/include/MCF5475_CTM.h
|
|
||||||
tos/jtagwait/include/MCF5475_DMA.h
|
|
||||||
tos/jtagwait/include/MCF5475_DSPI.h
|
|
||||||
tos/jtagwait/include/MCF5475_EPORT.h
|
|
||||||
tos/jtagwait/include/MCF5475_FBCS.h
|
|
||||||
tos/jtagwait/include/MCF5475_FEC.h
|
|
||||||
tos/jtagwait/include/MCF5475_GPIO.h
|
|
||||||
tos/jtagwait/include/MCF5475_GPT.h
|
|
||||||
tos/jtagwait/include/MCF5475_I2C.h
|
|
||||||
tos/jtagwait/include/MCF5475_INTC.h
|
|
||||||
tos/jtagwait/include/MCF5475_MMU.h
|
|
||||||
tos/jtagwait/include/MCF5475_PAD.h
|
|
||||||
tos/jtagwait/include/MCF5475_PCI.h
|
|
||||||
tos/jtagwait/include/MCF5475_PCIARB.h
|
|
||||||
tos/jtagwait/include/MCF5475_PSC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SDRAMC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SEC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SIU.h
|
|
||||||
tos/jtagwait/include/MCF5475_SLT.h
|
|
||||||
tos/jtagwait/include/MCF5475_SRAM.h
|
|
||||||
tos/jtagwait/include/MCF5475_USB.h
|
|
||||||
tos/jtagwait/include/MCF5475_XLB.h
|
|
||||||
tos/jtagwait/sources/bas_printf.c
|
|
||||||
tos/jtagwait/sources/bas_string.c
|
|
||||||
tos/jtagwait/sources/jtagwait.c
|
|
||||||
tos/jtagwait/sources/printf_helper.S
|
|
||||||
tos/jtagwait/Makefile
|
|
||||||
tos/pci_test/include/bas_printf.h
|
|
||||||
tos/pci_test/include/bas_string.h
|
|
||||||
tos/pci_test/include/driver_vec.h
|
|
||||||
tos/pci_test/include/MCF5475.h
|
|
||||||
tos/pci_test/include/MCF5475_CLOCK.h
|
|
||||||
tos/pci_test/include/MCF5475_CTM.h
|
|
||||||
tos/pci_test/include/MCF5475_DMA.h
|
|
||||||
tos/pci_test/include/MCF5475_DSPI.h
|
|
||||||
tos/pci_test/include/MCF5475_EPORT.h
|
|
||||||
tos/pci_test/include/MCF5475_FBCS.h
|
|
||||||
tos/pci_test/include/MCF5475_FEC.h
|
|
||||||
tos/pci_test/include/MCF5475_GPIO.h
|
|
||||||
tos/pci_test/include/MCF5475_GPT.h
|
|
||||||
tos/pci_test/include/MCF5475_I2C.h
|
|
||||||
tos/pci_test/include/MCF5475_INTC.h
|
|
||||||
tos/pci_test/include/MCF5475_MMU.h
|
|
||||||
tos/pci_test/include/MCF5475_PAD.h
|
|
||||||
tos/pci_test/include/MCF5475_PCI.h
|
|
||||||
tos/pci_test/include/MCF5475_PCIARB.h
|
|
||||||
tos/pci_test/include/MCF5475_PSC.h
|
|
||||||
tos/pci_test/include/MCF5475_SDRAMC.h
|
|
||||||
tos/pci_test/include/MCF5475_SEC.h
|
|
||||||
tos/pci_test/include/MCF5475_SIU.h
|
|
||||||
tos/pci_test/include/MCF5475_SLT.h
|
|
||||||
tos/pci_test/include/MCF5475_SRAM.h
|
|
||||||
tos/pci_test/include/MCF5475_USB.h
|
|
||||||
tos/pci_test/include/MCF5475_XLB.h
|
|
||||||
tos/pci_test/include/pci.h
|
|
||||||
tos/pci_test/sources/bas_printf.c
|
|
||||||
tos/pci_test/sources/bas_string.c
|
|
||||||
tos/pci_test/sources/pci_test.c
|
|
||||||
tos/pci_test/sources/printf_helper.S
|
|
||||||
tos/pci_test/Makefile
|
|
||||||
tos/vmem_test/include/bas_printf.h
|
|
||||||
tos/vmem_test/include/bas_string.h
|
|
||||||
tos/vmem_test/include/driver_vec.h
|
|
||||||
tos/vmem_test/include/MCF5475.h
|
|
||||||
tos/vmem_test/include/MCF5475_CLOCK.h
|
|
||||||
tos/vmem_test/include/MCF5475_CTM.h
|
|
||||||
tos/vmem_test/include/MCF5475_DMA.h
|
|
||||||
tos/vmem_test/include/MCF5475_DSPI.h
|
|
||||||
tos/vmem_test/include/MCF5475_EPORT.h
|
|
||||||
tos/vmem_test/include/MCF5475_FBCS.h
|
|
||||||
tos/vmem_test/include/MCF5475_FEC.h
|
|
||||||
tos/vmem_test/include/MCF5475_GPIO.h
|
|
||||||
tos/vmem_test/include/MCF5475_GPT.h
|
|
||||||
tos/vmem_test/include/MCF5475_I2C.h
|
|
||||||
tos/vmem_test/include/MCF5475_INTC.h
|
|
||||||
tos/vmem_test/include/MCF5475_MMU.h
|
|
||||||
tos/vmem_test/include/MCF5475_PAD.h
|
|
||||||
tos/vmem_test/include/MCF5475_PCI.h
|
|
||||||
tos/vmem_test/include/MCF5475_PCIARB.h
|
|
||||||
tos/vmem_test/include/MCF5475_PSC.h
|
|
||||||
tos/vmem_test/include/MCF5475_SDRAMC.h
|
|
||||||
tos/vmem_test/include/MCF5475_SEC.h
|
|
||||||
tos/vmem_test/include/MCF5475_SIU.h
|
|
||||||
tos/vmem_test/include/MCF5475_SLT.h
|
|
||||||
tos/vmem_test/include/MCF5475_SRAM.h
|
|
||||||
tos/vmem_test/include/MCF5475_USB.h
|
|
||||||
tos/vmem_test/include/MCF5475_XLB.h
|
|
||||||
tos/vmem_test/sources/fpga_test.c
|
|
||||||
tos/vmem_test/Makefile
|
|
||||||
tos/Makefile
|
|
||||||
tos/fpga_test/sources/fpga_test.c
|
|
||||||
include/debug.h
|
|
||||||
tos/bascook/sources/bascook.c
|
|
||||||
tos/bascook/Makefile
|
|
||||||
tos/fpga_test/include/bas_string.h
|
|
||||||
tos/fpga_test/include/MCF5475.h
|
|
||||||
tos/fpga_test/include/MCF5475_CLOCK.h
|
|
||||||
tos/fpga_test/include/MCF5475_FEC.h
|
|
||||||
tos/fpga_test/include/MCF5475_GPIO.h
|
|
||||||
tos/fpga_test/include/MCF5475_GPT.h
|
|
||||||
tos/fpga_test/include/MCF5475_I2C.h
|
|
||||||
tos/fpga_test/include/MCF5475_INTC.h
|
|
||||||
tos/fpga_test/include/MCF5475_MMU.h
|
|
||||||
tos/fpga_test/include/MCF5475_PAD.h
|
|
||||||
tos/fpga_test/include/MCF5475_PCI.h
|
|
||||||
tos/fpga_test/include/MCF5475_PCIARB.h
|
|
||||||
tos/fpga_test/include/MCF5475_PSC.h
|
|
||||||
tos/fpga_test/include/MCF5475_SDRAMC.h
|
|
||||||
tos/fpga_test/include/MCF5475_SEC.h
|
|
||||||
tos/fpga_test/include/MCF5475_SIU.h
|
|
||||||
tos/fpga_test/include/MCF5475_SLT.h
|
|
||||||
tos/fpga_test/include/MCF5475_SRAM.h
|
|
||||||
tos/fpga_test/include/MCF5475_USB.h
|
|
||||||
tos/fpga_test/include/MCF5475_XLB.h
|
|
||||||
tos/fpga_test/sources/bas_printf.c
|
|
||||||
tos/fpga_test/sources/bas_string.c
|
|
||||||
tos/fpga_test/sources/fpga_test.c
|
|
||||||
tos/fpga_test/sources/printf_helper.S
|
|
||||||
tos/fpga_test/Makefile
|
|
||||||
tos/jtagwait/include/bas_printf.h
|
|
||||||
tos/jtagwait/include/bas_string.h
|
|
||||||
tos/jtagwait/include/driver_vec.h
|
|
||||||
tos/jtagwait/include/MCF5475.h
|
|
||||||
tos/jtagwait/include/MCF5475_CLOCK.h
|
|
||||||
tos/jtagwait/include/MCF5475_CTM.h
|
|
||||||
tos/jtagwait/include/MCF5475_DMA.h
|
|
||||||
tos/jtagwait/include/MCF5475_DSPI.h
|
|
||||||
tos/jtagwait/include/MCF5475_EPORT.h
|
|
||||||
tos/jtagwait/include/MCF5475_FBCS.h
|
|
||||||
tos/jtagwait/include/MCF5475_FEC.h
|
|
||||||
tos/jtagwait/include/MCF5475_GPIO.h
|
|
||||||
tos/jtagwait/include/MCF5475_GPT.h
|
|
||||||
tos/jtagwait/include/MCF5475_I2C.h
|
|
||||||
tos/jtagwait/include/MCF5475_INTC.h
|
|
||||||
tos/jtagwait/include/MCF5475_MMU.h
|
|
||||||
tos/jtagwait/include/MCF5475_PAD.h
|
|
||||||
tos/jtagwait/include/MCF5475_PCI.h
|
|
||||||
tos/jtagwait/include/MCF5475_PCIARB.h
|
|
||||||
tos/jtagwait/include/MCF5475_PSC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SDRAMC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SEC.h
|
|
||||||
tos/jtagwait/include/MCF5475_SIU.h
|
|
||||||
tos/jtagwait/include/MCF5475_SLT.h
|
|
||||||
tos/jtagwait/include/MCF5475_SRAM.h
|
|
||||||
tos/jtagwait/include/MCF5475_USB.h
|
|
||||||
tos/jtagwait/include/MCF5475_XLB.h
|
|
||||||
tos/jtagwait/sources/bas_printf.c
|
|
||||||
tos/jtagwait/sources/bas_string.c
|
|
||||||
tos/jtagwait/sources/jtagwait.c
|
|
||||||
tos/jtagwait/sources/printf_helper.S
|
|
||||||
tos/jtagwait/Makefile
|
|
||||||
tos/pci_mem/include/bas_string.h
|
tos/pci_mem/include/bas_string.h
|
||||||
tos/pci_mem/include/bas_types.h
|
tos/pci_mem/include/bas_types.h
|
||||||
tos/pci_mem/include/driver_vec.h
|
tos/pci_mem/include/driver_vec.h
|
||||||
@@ -785,8 +284,11 @@ tos/pci_mem/include/MCF5475_USB.h
|
|||||||
tos/pci_mem/include/MCF5475_XLB.h
|
tos/pci_mem/include/MCF5475_XLB.h
|
||||||
tos/pci_mem/include/pci.h
|
tos/pci_mem/include/pci.h
|
||||||
tos/pci_mem/include/util.h
|
tos/pci_mem/include/util.h
|
||||||
|
tos/pci_mem/m5475/mshort/pci_mem.prg
|
||||||
|
tos/pci_mem/m5475/pci_mem.prg
|
||||||
tos/pci_mem/sources/pci_mem.c
|
tos/pci_mem/sources/pci_mem.c
|
||||||
tos/pci_mem/Makefile
|
tos/pci_mem/depend
|
||||||
|
tos/pci_mem/mapfile
|
||||||
tos/pci_test/include/bas_string.h
|
tos/pci_test/include/bas_string.h
|
||||||
tos/pci_test/include/bas_types.h
|
tos/pci_test/include/bas_types.h
|
||||||
tos/pci_test/include/driver_vec.h
|
tos/pci_test/include/driver_vec.h
|
||||||
@@ -816,9 +318,12 @@ tos/pci_test/include/MCF5475_USB.h
|
|||||||
tos/pci_test/include/MCF5475_XLB.h
|
tos/pci_test/include/MCF5475_XLB.h
|
||||||
tos/pci_test/include/pci.h
|
tos/pci_test/include/pci.h
|
||||||
tos/pci_test/include/util.h
|
tos/pci_test/include/util.h
|
||||||
|
tos/pci_test/m5475/mshort/pci_test.prg
|
||||||
|
tos/pci_test/m5475/pci_test.prg
|
||||||
tos/pci_test/sources/pci_test.c
|
tos/pci_test/sources/pci_test.c
|
||||||
tos/pci_test/sources/printf_helper.S
|
tos/pci_test/sources/printf_helper.S
|
||||||
tos/pci_test/Makefile
|
tos/pci_test/depend
|
||||||
|
tos/pci_test/mapfile
|
||||||
tos/vmem_test/include/bas_printf.h
|
tos/vmem_test/include/bas_printf.h
|
||||||
tos/vmem_test/include/bas_string.h
|
tos/vmem_test/include/bas_string.h
|
||||||
tos/vmem_test/include/driver_vec.h
|
tos/vmem_test/include/driver_vec.h
|
||||||
@@ -846,15 +351,47 @@ tos/vmem_test/include/MCF5475_SLT.h
|
|||||||
tos/vmem_test/include/MCF5475_SRAM.h
|
tos/vmem_test/include/MCF5475_SRAM.h
|
||||||
tos/vmem_test/include/MCF5475_USB.h
|
tos/vmem_test/include/MCF5475_USB.h
|
||||||
tos/vmem_test/include/MCF5475_XLB.h
|
tos/vmem_test/include/MCF5475_XLB.h
|
||||||
|
tos/vmem_test/m5475/mshort/vmem_test.prg
|
||||||
|
tos/vmem_test/m5475/vmem_test.prg
|
||||||
tos/vmem_test/sources/bas_printf.c
|
tos/vmem_test/sources/bas_printf.c
|
||||||
tos/vmem_test/sources/bas_string.c
|
tos/vmem_test/sources/bas_string.c
|
||||||
tos/vmem_test/sources/printf_helper.S
|
tos/vmem_test/sources/printf_helper.S
|
||||||
tos/vmem_test/sources/vmem_test.c
|
tos/vmem_test/sources/vmem_test.c
|
||||||
tos/vmem_test/Makefile
|
tos/vmem_test/depend
|
||||||
tos/Makefile
|
tos/vmem_test/mapfile
|
||||||
radeon/radeon_i2c.c
|
usb/usb.c
|
||||||
basflash.lk.in
|
usb/usb_hub.c
|
||||||
radeon/i2c-algo-bit.c
|
usb/usb_kbd.c
|
||||||
|
usb/usb_mouse.c
|
||||||
|
util/bas_printf.c
|
||||||
|
util/bas_string.c
|
||||||
util/conout.c
|
util/conout.c
|
||||||
include/conout.h
|
util/libgcc_helper.S
|
||||||
tos/fpga_test/sources/ser_printf.c
|
util/setjmp.S
|
||||||
|
util/wait.c
|
||||||
|
video/fbmem.c
|
||||||
|
video/fbmodedb.c
|
||||||
|
video/fbmon.c
|
||||||
|
video/fnt_st_8x16.c
|
||||||
|
video/offscreen.c
|
||||||
|
video/vdi_fill.c
|
||||||
|
video/videl.c
|
||||||
|
video/video.c
|
||||||
|
x86emu/x86biosemu.c
|
||||||
|
x86emu/x86emu.c
|
||||||
|
x86emu/x86emu_util.c
|
||||||
|
x86emu/x86pcibios.c
|
||||||
|
xhdi/xhdi_interface.c
|
||||||
|
xhdi/xhdi_sd.c
|
||||||
|
xhdi/xhdi_vec.S
|
||||||
|
bas.lk.in
|
||||||
|
bas_firebee.bdm
|
||||||
|
bas_m5484.bdm
|
||||||
|
basflash.lk.in
|
||||||
|
check.bdm
|
||||||
|
COPYING
|
||||||
|
COPYING.LESSER
|
||||||
|
Doxyfile
|
||||||
|
dump.bdm
|
||||||
|
mcf5474.gdb
|
||||||
|
memory_map.txt
|
||||||
|
|||||||
@@ -1,55 +1,5 @@
|
|||||||
include
|
include
|
||||||
tos/jtagwait/include
|
tos/jtagwait/include
|
||||||
tos/pci_test/include
|
|
||||||
/usr/m68k-atari-mint/include
|
|
||||||
/opt/cross-mint/m68k-atari-mint/include
|
|
||||||
/opt/gygwin/opt/cross-mint/m68k-atari-mint/include
|
|
||||||
/opt/m68k-elf/include
|
|
||||||
/opt/cygwin/opt/m68k-elf/include
|
|
||||||
/opt/cygwin/opt/m68k-elf/lib/gcc/m68k-elf/4.6.4/include
|
|
||||||
dma
|
|
||||||
m54455
|
|
||||||
sys
|
|
||||||
pci
|
|
||||||
tos/pci_test
|
|
||||||
tos/jtagwait/m5475/mshort
|
|
||||||
m5484lite
|
|
||||||
tos/pci_test/include
|
|
||||||
tos/bascook
|
|
||||||
tos/vmem_test/m5475/mshort
|
|
||||||
i2c
|
|
||||||
fs
|
|
||||||
tos/vmem_test/m5475
|
|
||||||
tos/pci_test/m5475
|
|
||||||
spi
|
|
||||||
if
|
|
||||||
tos/jtagwait/m5475
|
|
||||||
util
|
|
||||||
kbd
|
|
||||||
flash_scripts
|
|
||||||
video
|
|
||||||
usb
|
|
||||||
exe
|
|
||||||
tos/vmem_test/sources
|
|
||||||
tos
|
|
||||||
nutil
|
|
||||||
tos/jtagwait/sources
|
|
||||||
x86emu
|
|
||||||
flash
|
|
||||||
tos/vmem_test/include
|
|
||||||
tos/bascook/sources
|
|
||||||
tos/pci_test/m5475/mshort
|
|
||||||
.
|
|
||||||
radeon
|
|
||||||
net
|
|
||||||
xhdi
|
|
||||||
tos/vmem_test
|
|
||||||
tos/pci_test/sources
|
|
||||||
firebee
|
|
||||||
tos/jtagwait
|
|
||||||
tos/fpga_test/include
|
|
||||||
tos/fpga_test
|
|
||||||
tos/fpga_test/sources
|
|
||||||
tos/pci_mem
|
|
||||||
tos/pci_mem/include
|
tos/pci_mem/include
|
||||||
tos/pci_mem/sources
|
tos/pci_test/include
|
||||||
|
tos/vmem_test/include
|
||||||
@@ -8,9 +8,8 @@
|
|||||||
# installation, but allows source level debugging over BDM with a recent gdb (tested with 7.5),
|
# installation, but allows source level debugging over BDM with a recent gdb (tested with 7.5),
|
||||||
# the m68k BDM tools from sourceforge (http://bdm.sourceforge.net) and a BDM pod (TBLCF and P&E tested).
|
# the m68k BDM tools from sourceforge (http://bdm.sourceforge.net) and a BDM pod (TBLCF and P&E tested).
|
||||||
|
|
||||||
VERBOSE=N
|
|
||||||
|
|
||||||
ifneq (Y,$(VERBOSE))
|
ifneq (yes,$(VERBOSE))
|
||||||
Q=@
|
Q=@
|
||||||
else
|
else
|
||||||
Q=
|
Q=
|
||||||
|
|||||||
@@ -513,7 +513,7 @@ extern void offscreen_init(struct fb_info *info);
|
|||||||
#define FB_MODE_IS_FROM_VAR 32
|
#define FB_MODE_IS_FROM_VAR 32
|
||||||
|
|
||||||
extern void fb_destroy_modedb(struct fb_videomode *modedb);
|
extern void fb_destroy_modedb(struct fb_videomode *modedb);
|
||||||
extern int32_t fb_parse_edid(uint8_t *edid, struct fb_var_screeninfo *var);
|
extern int fb_parse_edid(uint8_t *edid, struct fb_var_screeninfo *var);
|
||||||
extern void fb_edid_to_monspecs(uint8_t *edid, struct fb_monspecs *specs);
|
extern void fb_edid_to_monspecs(uint8_t *edid, struct fb_monspecs *specs);
|
||||||
extern int32_t fb_get_mode(int32_t flags, uint32_t val, struct fb_var_screeninfo *var, struct fb_info *info);
|
extern int32_t fb_get_mode(int32_t flags, uint32_t val, struct fb_var_screeninfo *var, struct fb_info *info);
|
||||||
extern int32_t fb_validate_mode(const struct fb_var_screeninfo *var, struct fb_info *info);
|
extern int32_t fb_validate_mode(const struct fb_var_screeninfo *var, struct fb_info *info);
|
||||||
|
|||||||
@@ -46,6 +46,7 @@ int fb_pan_display(struct fb_info *info, struct fb_var_screeninfo *var)
|
|||||||
if ((err = info->fbops->fb_pan_display(var, info)))
|
if ((err = info->fbops->fb_pan_display(var, info)))
|
||||||
{
|
{
|
||||||
dbg("fb_pan_display returned %d\r\n", err);
|
dbg("fb_pan_display returned %d\r\n", err);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -55,6 +56,7 @@ int fb_pan_display(struct fb_info *info, struct fb_var_screeninfo *var)
|
|||||||
info->var.vmode |= FB_VMODE_YWRAP;
|
info->var.vmode |= FB_VMODE_YWRAP;
|
||||||
else
|
else
|
||||||
info->var.vmode &= ~FB_VMODE_YWRAP;
|
info->var.vmode &= ~FB_VMODE_YWRAP;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -67,6 +69,7 @@ int fb_set_var(struct fb_info *info, struct fb_var_screeninfo *var)
|
|||||||
if (var->activate & FB_ACTIVATE_INV_MODE)
|
if (var->activate & FB_ACTIVATE_INV_MODE)
|
||||||
{
|
{
|
||||||
dbg("invalid mode\r\n");
|
dbg("invalid mode\r\n");
|
||||||
|
|
||||||
return !memcmp((char *) &info->var, (char *) var, sizeof(struct fb_var_screeninfo));
|
return !memcmp((char *) &info->var, (char *) var, sizeof(struct fb_var_screeninfo));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -76,6 +79,7 @@ int fb_set_var(struct fb_info *info, struct fb_var_screeninfo *var)
|
|||||||
if ((err = info->fbops->fb_check_var(var, info)))
|
if ((err = info->fbops->fb_check_var(var, info)))
|
||||||
{
|
{
|
||||||
dbg("fb_check_var failed\r\n");
|
dbg("fb_check_var failed\r\n");
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -96,7 +100,8 @@ int fb_blank(struct fb_info *info, int blank)
|
|||||||
dbg("\r\n");
|
dbg("\r\n");
|
||||||
if (blank > FB_BLANK_POWERDOWN)
|
if (blank > FB_BLANK_POWERDOWN)
|
||||||
blank = FB_BLANK_POWERDOWN;
|
blank = FB_BLANK_POWERDOWN;
|
||||||
return(info->fbops->fb_blank(blank, info));
|
|
||||||
|
return info->fbops->fb_blank(blank, info);
|
||||||
}
|
}
|
||||||
|
|
||||||
int fb_ioctl(struct fb_info *info, uint32_t cmd, uint32_t arg)
|
int fb_ioctl(struct fb_info *info, uint32_t cmd, uint32_t arg)
|
||||||
@@ -111,6 +116,7 @@ int fb_ioctl(struct fb_info *info, uint32_t cmd, uint32_t arg)
|
|||||||
{
|
{
|
||||||
case FBIOGET_VSCREENINFO:
|
case FBIOGET_VSCREENINFO:
|
||||||
memcpy(argp, &info->var, sizeof(var));
|
memcpy(argp, &info->var, sizeof(var));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case FBIOPUT_VSCREENINFO:
|
case FBIOPUT_VSCREENINFO:
|
||||||
@@ -119,10 +125,12 @@ int fb_ioctl(struct fb_info *info, uint32_t cmd, uint32_t arg)
|
|||||||
if (i)
|
if (i)
|
||||||
return i;
|
return i;
|
||||||
memcpy(argp, &var, sizeof(var));
|
memcpy(argp, &var, sizeof(var));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case FBIOGET_FSCREENINFO:
|
case FBIOGET_FSCREENINFO:
|
||||||
memcpy(argp, &info->fix, sizeof(fix));
|
memcpy(argp, &info->fix, sizeof(fix));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case FBIOPAN_DISPLAY:
|
case FBIOPAN_DISPLAY:
|
||||||
@@ -131,6 +139,7 @@ int fb_ioctl(struct fb_info *info, uint32_t cmd, uint32_t arg)
|
|||||||
if (i)
|
if (i)
|
||||||
return i;
|
return i;
|
||||||
memcpy(argp, &var, sizeof(var));
|
memcpy(argp, &var, sizeof(var));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case FBIOBLANK:
|
case FBIOBLANK:
|
||||||
@@ -138,13 +147,13 @@ int fb_ioctl(struct fb_info *info, uint32_t cmd, uint32_t arg)
|
|||||||
return i;
|
return i;
|
||||||
|
|
||||||
case FBIO_ALLOC:
|
case FBIO_ALLOC:
|
||||||
return(offscreen_alloc(info, arg));
|
return offscreen_alloc(info, arg);
|
||||||
|
|
||||||
case FBIO_FREE:
|
case FBIO_FREE:
|
||||||
return(offscreen_free(info, (void *) arg));
|
return offscreen_free(info, (void *) arg);
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return(info->fbops->fb_ioctl(cmd, arg, info));
|
return info->fbops->fb_ioctl(cmd, arg, info);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -172,6 +181,7 @@ struct fb_info *framebuffer_alloc(uint32_t size)
|
|||||||
extern struct fb_info *info_fb;
|
extern struct fb_info *info_fb;
|
||||||
|
|
||||||
dbg("\r\n");
|
dbg("\r\n");
|
||||||
|
|
||||||
return info_fb;
|
return info_fb;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -187,6 +197,7 @@ struct fb_info *framebuffer_alloc(uint32_t size)
|
|||||||
void framebuffer_release(struct fb_info *info)
|
void framebuffer_release(struct fb_info *info)
|
||||||
{
|
{
|
||||||
dbg("\r\n");
|
dbg("\r\n");
|
||||||
|
|
||||||
driver_mem_free(info->par);
|
driver_mem_free(info->par);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -32,292 +32,292 @@
|
|||||||
|
|
||||||
const struct fb_videomode modedb[] =
|
const struct fb_videomode modedb[] =
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
/* 640x400 @ 70 Hz, 31.5 kHz hsync */
|
/* 640x400 @ 70 Hz, 31.5 kHz hsync */
|
||||||
70, 640, 400, 39721, 40, 24, 39, 9, 96, 2,
|
70, 640, 400, 39721, 40, 24, 39, 9, 96, 2,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 640x480 @ 60 Hz, 31.5 kHz hsync */
|
/* 640x480 @ 60 Hz, 31.5 kHz hsync */
|
||||||
60, 640, 480, 39721, 40, 24, 32, 11, 96, 2,
|
60, 640, 480, 39721, 40, 24, 32, 11, 96, 2,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 800x600 @ 56 Hz, 35.15 kHz hsync */
|
/* 800x600 @ 56 Hz, 35.15 kHz hsync */
|
||||||
56, 800, 600, 27777, 128, 24, 22, 1, 72, 2,
|
56, 800, 600, 27777, 128, 24, 22, 1, 72, 2,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1024x768 @ 87 Hz interlaced, 35.5 kHz hsync */
|
/* 1024x768 @ 87 Hz interlaced, 35.5 kHz hsync */
|
||||||
87, 1024, 768, 22271, 56, 24, 33, 8, 160, 8,
|
87, 1024, 768, 22271, 56, 24, 33, 8, 160, 8,
|
||||||
0, FB_VMODE_INTERLACED
|
0, FB_VMODE_INTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 640x400 @ 85 Hz, 37.86 kHz hsync */
|
/* 640x400 @ 85 Hz, 37.86 kHz hsync */
|
||||||
85, 640, 400, 31746, 96, 32, 41, 1, 64, 3,
|
85, 640, 400, 31746, 96, 32, 41, 1, 64, 3,
|
||||||
FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 640x480 @ 72 Hz, 36.5 kHz hsync */
|
/* 640x480 @ 72 Hz, 36.5 kHz hsync */
|
||||||
72, 640, 480, 31746, 144, 40, 30, 8, 40, 3,
|
72, 640, 480, 31746, 144, 40, 30, 8, 40, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 640x480 @ 75 Hz, 37.50 kHz hsync */
|
/* 640x480 @ 75 Hz, 37.50 kHz hsync */
|
||||||
75, 640, 480, 31746, 120, 16, 16, 1, 64, 3,
|
75, 640, 480, 31746, 120, 16, 16, 1, 64, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 800x600 @ 60 Hz, 37.8 kHz hsync */
|
/* 800x600 @ 60 Hz, 37.8 kHz hsync */
|
||||||
60, 800, 600, 25000, 88, 40, 23, 1, 128, 4,
|
60, 800, 600, 25000, 88, 40, 23, 1, 128, 4,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 640x480 @ 85 Hz, 43.27 kHz hsync */
|
/* 640x480 @ 85 Hz, 43.27 kHz hsync */
|
||||||
85, 640, 480, 27777, 80, 56, 25, 1, 56, 3,
|
85, 640, 480, 27777, 80, 56, 25, 1, 56, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1152x864 @ 89 Hz interlaced, 44 kHz hsync */
|
/* 1152x864 @ 89 Hz interlaced, 44 kHz hsync */
|
||||||
69, 1152, 864, 15384, 96, 16, 110, 1, 216, 10,
|
69, 1152, 864, 15384, 96, 16, 110, 1, 216, 10,
|
||||||
0, FB_VMODE_INTERLACED
|
0, FB_VMODE_INTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 800x600 @ 72 Hz, 48.0 kHz hsync */
|
/* 800x600 @ 72 Hz, 48.0 kHz hsync */
|
||||||
72, 800, 600, 20000, 64, 56, 23, 37, 120, 6,
|
72, 800, 600, 20000, 64, 56, 23, 37, 120, 6,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1024x768 @ 60 Hz, 48.4 kHz hsync */
|
/* 1024x768 @ 60 Hz, 48.4 kHz hsync */
|
||||||
60, 1024, 768, 15384, 168, 8, 29, 3, 144, 6,
|
60, 1024, 768, 15384, 168, 8, 29, 3, 144, 6,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 640x480 @ 100 Hz, 53.01 kHz hsync */
|
/* 640x480 @ 100 Hz, 53.01 kHz hsync */
|
||||||
100, 640, 480, 21834, 96, 32, 36, 8, 96, 6,
|
100, 640, 480, 21834, 96, 32, 36, 8, 96, 6,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1152x864 @ 60 Hz, 53.5 kHz hsync */
|
/* 1152x864 @ 60 Hz, 53.5 kHz hsync */
|
||||||
60, 1152, 864, 11123, 208, 64, 16, 4, 256, 8,
|
60, 1152, 864, 11123, 208, 64, 16, 4, 256, 8,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 800x600 @ 85 Hz, 55.84 kHz hsync */
|
/* 800x600 @ 85 Hz, 55.84 kHz hsync */
|
||||||
85, 800, 600, 16460, 160, 64, 36, 16, 64, 5,
|
85, 800, 600, 16460, 160, 64, 36, 16, 64, 5,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1024x768 @ 70 Hz, 56.5 kHz hsync */
|
/* 1024x768 @ 70 Hz, 56.5 kHz hsync */
|
||||||
70, 1024, 768, 13333, 144, 24, 29, 3, 136, 6,
|
70, 1024, 768, 13333, 144, 24, 29, 3, 136, 6,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x1024 @ 87 Hz interlaced, 51 kHz hsync */
|
/* 1280x1024 @ 87 Hz interlaced, 51 kHz hsync */
|
||||||
87, 1280, 1024, 12500, 56, 16, 128, 1, 216, 12,
|
87, 1280, 1024, 12500, 56, 16, 128, 1, 216, 12,
|
||||||
0, FB_VMODE_INTERLACED
|
0, FB_VMODE_INTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 800x600 @ 100 Hz, 64.02 kHz hsync */
|
/* 800x600 @ 100 Hz, 64.02 kHz hsync */
|
||||||
100, 800, 600, 14357, 160, 64, 30, 4, 64, 6,
|
100, 800, 600, 14357, 160, 64, 30, 4, 64, 6,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1024x768 @ 76 Hz, 62.5 kHz hsync */
|
/* 1024x768 @ 76 Hz, 62.5 kHz hsync */
|
||||||
76, 1024, 768, 11764, 208, 8, 36, 16, 120, 3,
|
76, 1024, 768, 11764, 208, 8, 36, 16, 120, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1152x864 @ 70 Hz, 62.4 kHz hsync */
|
/* 1152x864 @ 70 Hz, 62.4 kHz hsync */
|
||||||
70, 1152, 864, 10869, 106, 56, 20, 1, 160, 10,
|
70, 1152, 864, 10869, 106, 56, 20, 1, 160, 10,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x1024 @ 61 Hz, 64.2 kHz hsync */
|
/* 1280x1024 @ 61 Hz, 64.2 kHz hsync */
|
||||||
61, 1280, 1024, 9090, 200, 48, 26, 1, 184, 3,
|
61, 1280, 1024, 9090, 200, 48, 26, 1, 184, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1400x1050 @ 60Hz, 63.9 kHz hsync */
|
/* 1400x1050 @ 60Hz, 63.9 kHz hsync */
|
||||||
68, 1400, 1050, 9259, 136, 40, 13, 1, 112, 3,
|
68, 1400, 1050, 9259, 136, 40, 13, 1, 112, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1400x1050 @ 75,107 Hz, 82,392 kHz +hsync +vsync*/
|
/* 1400x1050 @ 75,107 Hz, 82,392 kHz +hsync +vsync*/
|
||||||
75, 1400, 1050, 9271, 120, 56, 13, 0, 112, 3,
|
75, 1400, 1050, 9271, 120, 56, 13, 0, 112, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1400x1050 @ 60 Hz, ? kHz +hsync +vsync*/
|
/* 1400x1050 @ 60 Hz, ? kHz +hsync +vsync*/
|
||||||
60, 1400, 1050, 9259, 128, 40, 12, 0, 112, 3,
|
60, 1400, 1050, 9259, 128, 40, 12, 0, 112, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1024x768 @ 85 Hz, 70.24 kHz hsync */
|
/* 1024x768 @ 85 Hz, 70.24 kHz hsync */
|
||||||
85, 1024, 768, 10111, 192, 32, 34, 14, 160, 6,
|
85, 1024, 768, 10111, 192, 32, 34, 14, 160, 6,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1152x864 @ 78 Hz, 70.8 kHz hsync */
|
/* 1152x864 @ 78 Hz, 70.8 kHz hsync */
|
||||||
78, 1152, 864, 9090, 228, 88, 32, 0, 84, 12,
|
78, 1152, 864, 9090, 228, 88, 32, 0, 84, 12,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x1024 @ 70 Hz, 74.59 kHz hsync */
|
/* 1280x1024 @ 70 Hz, 74.59 kHz hsync */
|
||||||
70, 1280, 1024, 7905, 224, 32, 28, 8, 160, 8,
|
70, 1280, 1024, 7905, 224, 32, 28, 8, 160, 8,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1600x1200 @ 60Hz, 75.00 kHz hsync */
|
/* 1600x1200 @ 60Hz, 75.00 kHz hsync */
|
||||||
60, 1600, 1200, 6172, 304, 64, 46, 1, 192, 3,
|
60, 1600, 1200, 6172, 304, 64, 46, 1, 192, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1152x864 @ 84 Hz, 76.0 kHz hsync */
|
/* 1152x864 @ 84 Hz, 76.0 kHz hsync */
|
||||||
84, 1152, 864, 7407, 184, 312, 32, 0, 128, 12,
|
84, 1152, 864, 7407, 184, 312, 32, 0, 128, 12,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x1024 @ 74 Hz, 78.85 kHz hsync */
|
/* 1280x1024 @ 74 Hz, 78.85 kHz hsync */
|
||||||
74, 1280, 1024, 7407, 256, 32, 34, 3, 144, 3,
|
74, 1280, 1024, 7407, 256, 32, 34, 3, 144, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1024x768 @ 100Hz, 80.21 kHz hsync */
|
/* 1024x768 @ 100Hz, 80.21 kHz hsync */
|
||||||
100, 1024, 768, 8658, 192, 32, 21, 3, 192, 10,
|
100, 1024, 768, 8658, 192, 32, 21, 3, 192, 10,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x1024 @ 76 Hz, 81.13 kHz hsync */
|
/* 1280x1024 @ 76 Hz, 81.13 kHz hsync */
|
||||||
76, 1280, 1024, 7407, 248, 32, 34, 3, 104, 3,
|
76, 1280, 1024, 7407, 248, 32, 34, 3, 104, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1600x1200 @ 70 Hz, 87.50 kHz hsync */
|
/* 1600x1200 @ 70 Hz, 87.50 kHz hsync */
|
||||||
70, 1600, 1200, 5291, 304, 64, 46, 1, 192, 3,
|
70, 1600, 1200, 5291, 304, 64, 46, 1, 192, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1152x864 @ 100 Hz, 89.62 kHz hsync */
|
/* 1152x864 @ 100 Hz, 89.62 kHz hsync */
|
||||||
100, 1152, 864, 7264, 224, 32, 17, 2, 128, 19,
|
100, 1152, 864, 7264, 224, 32, 17, 2, 128, 19,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x1024 @ 85 Hz, 91.15 kHz hsync */
|
/* 1280x1024 @ 85 Hz, 91.15 kHz hsync */
|
||||||
85, 1280, 1024, 6349, 224, 64, 44, 1, 160, 3,
|
85, 1280, 1024, 6349, 224, 64, 44, 1, 160, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1600x1200 @ 75 Hz, 93.75 kHz hsync */
|
/* 1600x1200 @ 75 Hz, 93.75 kHz hsync */
|
||||||
75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3,
|
75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1600x1200 @ 85 Hz, 105.77 kHz hsync */
|
/* 1600x1200 @ 85 Hz, 105.77 kHz hsync */
|
||||||
85, 1600, 1200, 4545, 272, 16, 37, 4, 192, 3,
|
85, 1600, 1200, 4545, 272, 16, 37, 4, 192, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x1024 @ 100 Hz, 107.16 kHz hsync */
|
/* 1280x1024 @ 100 Hz, 107.16 kHz hsync */
|
||||||
100, 1280, 1024, 5502, 256, 32, 26, 7, 128, 15,
|
100, 1280, 1024, 5502, 256, 32, 26, 7, 128, 15,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1800x1440 @ 64Hz, 96.15 kHz hsync */
|
/* 1800x1440 @ 64Hz, 96.15 kHz hsync */
|
||||||
64, 1800, 1440, 4347, 304, 96, 46, 1, 192, 3,
|
64, 1800, 1440, 4347, 304, 96, 46, 1, 192, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1800x1440 @ 70Hz, 104.52 kHz hsync */
|
/* 1800x1440 @ 70Hz, 104.52 kHz hsync */
|
||||||
70, 1800, 1440, 4000, 304, 96, 46, 1, 192, 3,
|
70, 1800, 1440, 4000, 304, 96, 46, 1, 192, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 512x384 @ 78 Hz, 31.50 kHz hsync */
|
/* 512x384 @ 78 Hz, 31.50 kHz hsync */
|
||||||
78, 512, 384, 49603, 48, 16, 16, 1, 64, 3,
|
78, 512, 384, 49603, 48, 16, 16, 1, 64, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 512x384 @ 85 Hz, 34.38 kHz hsync */
|
/* 512x384 @ 85 Hz, 34.38 kHz hsync */
|
||||||
85, 512, 384, 45454, 48, 16, 16, 1, 64, 3,
|
85, 512, 384, 45454, 48, 16, 16, 1, 64, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 320x200 @ 70 Hz, 31.5 kHz hsync, 8:5 aspect ratio */
|
/* 320x200 @ 70 Hz, 31.5 kHz hsync, 8:5 aspect ratio */
|
||||||
70, 320, 200, 79440, 16, 16, 20, 4, 48, 1,
|
70, 320, 200, 79440, 16, 16, 20, 4, 48, 1,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 320x240 @ 60 Hz, 31.5 kHz hsync, 4:3 aspect ratio */
|
/* 320x240 @ 60 Hz, 31.5 kHz hsync, 4:3 aspect ratio */
|
||||||
60, 320, 240, 79440, 16, 16, 16, 5, 48, 1,
|
60, 320, 240, 79440, 16, 16, 16, 5, 48, 1,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 320x240 @ 72 Hz, 36.5 kHz hsync */
|
/* 320x240 @ 72 Hz, 36.5 kHz hsync */
|
||||||
72, 320, 240, 63492, 16, 16, 16, 4, 48, 2,
|
72, 320, 240, 63492, 16, 16, 16, 4, 48, 2,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 400x300 @ 56 Hz, 35.2 kHz hsync, 4:3 aspect ratio */
|
/* 400x300 @ 56 Hz, 35.2 kHz hsync, 4:3 aspect ratio */
|
||||||
56, 400, 300, 55555, 64, 16, 10, 1, 32, 1,
|
56, 400, 300, 55555, 64, 16, 10, 1, 32, 1,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 400x300 @ 60 Hz, 37.8 kHz hsync */
|
/* 400x300 @ 60 Hz, 37.8 kHz hsync */
|
||||||
60, 400, 300, 50000, 48, 16, 11, 1, 64, 2,
|
60, 400, 300, 50000, 48, 16, 11, 1, 64, 2,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 400x300 @ 72 Hz, 48.0 kHz hsync */
|
/* 400x300 @ 72 Hz, 48.0 kHz hsync */
|
||||||
72, 400, 300, 40000, 32, 24, 11, 19, 64, 3,
|
72, 400, 300, 40000, 32, 24, 11, 19, 64, 3,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 480x300 @ 56 Hz, 35.2 kHz hsync, 8:5 aspect ratio */
|
/* 480x300 @ 56 Hz, 35.2 kHz hsync, 8:5 aspect ratio */
|
||||||
56, 480, 300, 46176, 80, 16, 10, 1, 40, 1,
|
56, 480, 300, 46176, 80, 16, 10, 1, 40, 1,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 480x300 @ 60 Hz, 37.8 kHz hsync */
|
/* 480x300 @ 60 Hz, 37.8 kHz hsync */
|
||||||
60, 480, 300, 41858, 56, 16, 11, 1, 80, 2,
|
60, 480, 300, 41858, 56, 16, 11, 1, 80, 2,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 480x300 @ 63 Hz, 39.6 kHz hsync */
|
/* 480x300 @ 63 Hz, 39.6 kHz hsync */
|
||||||
63, 480, 300, 40000, 56, 16, 11, 1, 80, 2,
|
63, 480, 300, 40000, 56, 16, 11, 1, 80, 2,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 480x300 @ 72 Hz, 48.0 kHz hsync */
|
/* 480x300 @ 72 Hz, 48.0 kHz hsync */
|
||||||
72, 480, 300, 33386, 40, 24, 11, 19, 80, 3,
|
72, 480, 300, 33386, 40, 24, 11, 19, 80, 3,
|
||||||
0, FB_VMODE_DOUBLE
|
0, FB_VMODE_DOUBLE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1920x1200 @ 60 Hz, 74.5 Khz hsync */
|
/* 1920x1200 @ 60 Hz, 74.5 Khz hsync */
|
||||||
60, 1920, 1200, 5177, 128, 336, 1, 38, 208, 3,
|
60, 1920, 1200, 5177, 128, 336, 1, 38, 208, 3,
|
||||||
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
|
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
|
||||||
FB_VMODE_NONINTERLACED
|
FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1152x768, 60 Hz, PowerBook G4 Titanium I and II */
|
/* 1152x768, 60 Hz, PowerBook G4 Titanium I and II */
|
||||||
60, 1152, 768, 14047, 158, 26, 29, 3, 136, 6,
|
60, 1152, 768, 14047, 158, 26, 29, 3, 136, 6,
|
||||||
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1920x1080, 60 Hz, 1080pf */
|
/* 1920x1080, 60 Hz, 1080pf */
|
||||||
60, 1920, 1080, 6741, 148, 44, 36, 4, 88, 5,
|
60, 1920, 1080, 6741, 148, 44, 36, 4, 88, 5,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1366x768, 60 Hz, 47.403 kHz hsync, WXGA 16:9 aspect ratio */
|
/* 1366x768, 60 Hz, 47.403 kHz hsync, WXGA 16:9 aspect ratio */
|
||||||
60, 1366, 768, 13806, 120, 10, 14, 3, 32, 5,
|
60, 1366, 768, 13806, 120, 10, 14, 3, 32, 5,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
/* 1280x800, 60 Hz, 47.403 kHz hsync, WXGA 16:10 aspect ratio */
|
/* 1280x800, 60 Hz, 47.403 kHz hsync, WXGA 16:10 aspect ratio */
|
||||||
60, 1280, 800, 12048, 200, 64, 24, 1, 136, 3,
|
60, 1280, 800, 12048, 200, 64, 24, 1, 136, 3,
|
||||||
0, FB_VMODE_NONINTERLACED
|
0, FB_VMODE_NONINTERLACED
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
long total_modedb = sizeof(modedb) / sizeof(*modedb);
|
long total_modedb = sizeof(modedb) / sizeof(*modedb);
|
||||||
@@ -325,73 +325,73 @@ long total_modedb = sizeof(modedb) / sizeof(*modedb);
|
|||||||
const struct fb_videomode vesa_modes[] =
|
const struct fb_videomode vesa_modes[] =
|
||||||
{
|
{
|
||||||
/* 0 640x350-85 VESA */
|
/* 0 640x350-85 VESA */
|
||||||
{ 85, 640, 350, 31746, 96, 32, 60, 32, 64, 3, FB_SYNC_HOR_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA},
|
{ 85, 640, 350, 31746, 96, 32, 60, 32, 64, 3, FB_SYNC_HOR_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA},
|
||||||
/* 1 640x400-85 VESA */
|
/* 1 640x400-85 VESA */
|
||||||
{ 85, 640, 400, 31746, 96, 32, 41, 01, 64, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 640, 400, 31746, 96, 32, 41, 01, 64, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 2 720x400-85 VESA */
|
/* 2 720x400-85 VESA */
|
||||||
{ 85, 721, 400, 28169, 108, 36, 42, 01, 72, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 721, 400, 28169, 108, 36, 42, 01, 72, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 3 640x480-60 VESA */
|
/* 3 640x480-60 VESA */
|
||||||
{ 60, 640, 480, 39682, 48, 16, 33, 10, 96, 2, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 640, 480, 39682, 48, 16, 33, 10, 96, 2, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 4 640x480-72 VESA */
|
/* 4 640x480-72 VESA */
|
||||||
{ 72, 640, 480, 31746, 128, 24, 29, 9, 40, 2, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 72, 640, 480, 31746, 128, 24, 29, 9, 40, 2, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 5 640x480-75 VESA */
|
/* 5 640x480-75 VESA */
|
||||||
{ 75, 640, 480, 31746, 120, 16, 16, 01, 64, 3, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 640, 480, 31746, 120, 16, 16, 01, 64, 3, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 6 640x480-85 VESA */
|
/* 6 640x480-85 VESA */
|
||||||
{ 85, 640, 480, 27777, 80, 56, 25, 01, 56, 3, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 640, 480, 27777, 80, 56, 25, 01, 56, 3, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 7 800x600-56 VESA */
|
/* 7 800x600-56 VESA */
|
||||||
{ 56, 800, 600, 27777, 128, 24, 22, 01, 72, 2, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 56, 800, 600, 27777, 128, 24, 22, 01, 72, 2, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 8 800x600-60 VESA */
|
/* 8 800x600-60 VESA */
|
||||||
{ 60, 800, 600, 25000, 88, 40, 23, 01, 128, 4, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 800, 600, 25000, 88, 40, 23, 01, 128, 4, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 9 800x600-72 VESA */
|
/* 9 800x600-72 VESA */
|
||||||
{ 72, 800, 600, 20000, 64, 56, 23, 37, 120, 6, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 72, 800, 600, 20000, 64, 56, 23, 37, 120, 6, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 10 800x600-75 VESA */
|
/* 10 800x600-75 VESA */
|
||||||
{ 75, 800, 600, 20202, 160, 16, 21, 01, 80, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 800, 600, 20202, 160, 16, 21, 01, 80, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 11 800x600-85 VESA */
|
/* 11 800x600-85 VESA */
|
||||||
{ 85, 800, 600, 17761, 152, 32, 27, 01, 64, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 800, 600, 17761, 152, 32, 27, 01, 64, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 12 1024x768i-43 VESA */
|
/* 12 1024x768i-43 VESA */
|
||||||
{ 53, 1024, 768, 22271, 56, 8, 41, 0, 176, 8, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_INTERLACED, FB_MODE_IS_VESA },
|
{ 53, 1024, 768, 22271, 56, 8, 41, 0, 176, 8, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_INTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 13 1024x768-60 VESA */
|
/* 13 1024x768-60 VESA */
|
||||||
{ 60, 1024, 768, 15384, 160, 24, 29, 3, 136, 6, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1024, 768, 15384, 160, 24, 29, 3, 136, 6, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 14 1024x768-70 VESA */
|
/* 14 1024x768-70 VESA */
|
||||||
{ 70, 1024, 768, 13333, 144, 24, 29, 3, 136, 6, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 70, 1024, 768, 13333, 144, 24, 29, 3, 136, 6, 0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 15 1024x768-75 VESA */
|
/* 15 1024x768-75 VESA */
|
||||||
{ 75, 1024, 768, 12690, 176, 16, 28, 1, 96, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 1024, 768, 12690, 176, 16, 28, 1, 96, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 16 1024x768-85 VESA */
|
/* 16 1024x768-85 VESA */
|
||||||
{ 85, 1024, 768, 10582, 208, 48, 36, 1, 96, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 1024, 768, 10582, 208, 48, 36, 1, 96, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 17 1152x864-75 VESA */
|
/* 17 1152x864-75 VESA */
|
||||||
{ 75, 1153, 864, 9259, 256, 64, 32, 1, 128, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 1153, 864, 9259, 256, 64, 32, 1, 128, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 18 1280x960-60 VESA */
|
/* 18 1280x960-60 VESA */
|
||||||
{ 60, 1280, 960, 9259, 312, 96, 36, 1, 112, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1280, 960, 9259, 312, 96, 36, 1, 112, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 19 1280x960-85 VESA */
|
/* 19 1280x960-85 VESA */
|
||||||
{ 85, 1280, 960, 6734, 224, 64, 47, 1, 160, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 1280, 960, 6734, 224, 64, 47, 1, 160, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 20 1280x1024-60 VESA */
|
/* 20 1280x1024-60 VESA */
|
||||||
{ 60, 1280, 1024, 9259, 248, 48, 38, 1, 112, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1280, 1024, 9259, 248, 48, 38, 1, 112, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 21 1280x1024-75 VESA */
|
/* 21 1280x1024-75 VESA */
|
||||||
{ 75, 1280, 1024, 7407, 248, 16, 38, 1, 144, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 1280, 1024, 7407, 248, 16, 38, 1, 144, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 22 1280x1024-85 VESA */
|
/* 22 1280x1024-85 VESA */
|
||||||
{ 85, 1280, 1024, 6349, 224, 64, 44, 1, 160, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 1280, 1024, 6349, 224, 64, 44, 1, 160, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 23 1600x1200-60 VESA */
|
/* 23 1600x1200-60 VESA */
|
||||||
{ 60, 1600, 1200, 6172, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1600, 1200, 6172, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 24 1600x1200-65 VESA */
|
/* 24 1600x1200-65 VESA */
|
||||||
{ 65, 1600, 1200, 5698, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 65, 1600, 1200, 5698, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 25 1600x1200-70 VESA */
|
/* 25 1600x1200-70 VESA */
|
||||||
{ 70, 1600, 1200, 5291, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 70, 1600, 1200, 5291, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 26 1600x1200-75 VESA */
|
/* 26 1600x1200-75 VESA */
|
||||||
{ 75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 27 1600x1200-85 VESA */
|
/* 27 1600x1200-85 VESA */
|
||||||
{ 85, 1600, 1200, 4357, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 85, 1600, 1200, 4357, 304, 64, 46, 1, 192, 3, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 28 1792x1344-60 VESA */
|
/* 28 1792x1344-60 VESA */
|
||||||
{ 60, 1792, 1344, 4882, 328, 128, 46, 1, 200, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1792, 1344, 4882, 328, 128, 46, 1, 200, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 29 1792x1344-75 VESA */
|
/* 29 1792x1344-75 VESA */
|
||||||
{ 75, 1792, 1344, 3831, 352, 96, 69, 1, 216, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 1792, 1344, 3831, 352, 96, 69, 1, 216, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 30 1856x1392-60 VESA */
|
/* 30 1856x1392-60 VESA */
|
||||||
{ 60, 1856, 1392, 4580, 352, 96, 43, 1, 224, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1856, 1392, 4580, 352, 96, 43, 1, 224, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 31 1856x1392-75 VESA */
|
/* 31 1856x1392-75 VESA */
|
||||||
{ 75, 1856, 1392, 3472, 352, 128, 104, 1, 224, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 75, 1856, 1392, 3472, 352, 128, 104, 1, 224, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 32 1920x1440-60 VESA */
|
/* 32 1920x1440-60 VESA */
|
||||||
{ 60, 1920, 1440, 4273, 344, 128, 56, 1, 200, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1920, 1440, 4273, 344, 128, 56, 1, 200, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
/* 33 1920x1440-75 VESA */
|
/* 33 1920x1440-75 VESA */
|
||||||
{ 60, 1920, 1440, 3367, 352, 144, 56, 1, 224, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
{ 60, 1920, 1440, 3367, 352, 144, 56, 1, 224, 3, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -77,12 +77,15 @@ static void copy_string(unsigned char *c, unsigned char *s)
|
|||||||
for (i = 0; (i < 13 && *c != 0x0A); i++)
|
for (i = 0; (i < 13 && *c != 0x0A); i++)
|
||||||
*(s++) = *(c++);
|
*(s++) = *(c++);
|
||||||
*s = 0;
|
*s = 0;
|
||||||
while (i-- && (*--s == 0x20)) *s = 0;
|
|
||||||
|
while (i-- && (*--s == 0x20))
|
||||||
|
*s = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t check_edid(unsigned char *edid)
|
static int32_t check_edid(unsigned char *edid)
|
||||||
{
|
{
|
||||||
unsigned char *block = edid + ID_MANUFACTURER_NAME, manufacturer[4];
|
unsigned char *block = edid + ID_MANUFACTURER_NAME;
|
||||||
|
unsigned char manufacturer[4];
|
||||||
unsigned char *b;
|
unsigned char *b;
|
||||||
unsigned long model;
|
unsigned long model;
|
||||||
int32_t i, fix = 0, ret = 0;
|
int32_t i, fix = 0, ret = 0;
|
||||||
@@ -92,6 +95,7 @@ static int32_t check_edid(unsigned char *edid)
|
|||||||
manufacturer[2] = (block[1] & 0x1f) + '@';
|
manufacturer[2] = (block[1] & 0x1f) + '@';
|
||||||
manufacturer[3] = 0;
|
manufacturer[3] = 0;
|
||||||
model = block[2] + (block[3] << 8);
|
model = block[2] + (block[3] << 8);
|
||||||
|
|
||||||
for (i = 0; i < sizeof(brokendb)/sizeof(*brokendb); i++)
|
for (i = 0; i < sizeof(brokendb)/sizeof(*brokendb); i++)
|
||||||
{
|
{
|
||||||
if (manufacturer[0] == brokendb[i].manufacturer[0] &&
|
if (manufacturer[0] == brokendb[i].manufacturer[0] &&
|
||||||
@@ -104,6 +108,7 @@ static int32_t check_edid(unsigned char *edid)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (fix)
|
switch (fix)
|
||||||
{
|
{
|
||||||
case FBMON_FIX_HEADER:
|
case FBMON_FIX_HEADER:
|
||||||
@@ -122,6 +127,7 @@ static int32_t check_edid(unsigned char *edid)
|
|||||||
ret = fix;
|
ret = fix;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -146,36 +152,46 @@ static void fix_edid(unsigned char *edid, int32_t fix)
|
|||||||
static int32_t edid_checksum(unsigned char *edid)
|
static int32_t edid_checksum(unsigned char *edid)
|
||||||
{
|
{
|
||||||
unsigned char i, csum = 0, all_null = 0;
|
unsigned char i, csum = 0, all_null = 0;
|
||||||
int32_t err = 0, fix = check_edid(edid);
|
int err = 0;
|
||||||
|
int fix = check_edid(edid);
|
||||||
|
|
||||||
if (fix)
|
if (fix)
|
||||||
fix_edid(edid, fix);
|
fix_edid(edid, fix);
|
||||||
|
|
||||||
for (i = 0; i < EDID_LENGTH; i++)
|
for (i = 0; i < EDID_LENGTH; i++)
|
||||||
{
|
{
|
||||||
csum += edid[i];
|
csum += edid[i];
|
||||||
all_null |= edid[i];
|
all_null |= edid[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((csum == 0x00) && all_null)
|
if ((csum == 0x00) && all_null)
|
||||||
/* checksum passed, everything's good */
|
/* checksum passed, everything's good */
|
||||||
err = 1;
|
err = 1;
|
||||||
|
|
||||||
if (!err)
|
if (!err)
|
||||||
dbg("edid bad checksum\r\n");
|
dbg("edid bad checksum\r\n");
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t edid_check_header(unsigned char *edid)
|
static int32_t edid_check_header(unsigned char *edid)
|
||||||
{
|
{
|
||||||
int32_t i, err = 1, fix = check_edid(edid);
|
int i;
|
||||||
|
int err = 1;
|
||||||
|
int fix = check_edid(edid);
|
||||||
|
|
||||||
if (fix)
|
if (fix)
|
||||||
fix_edid(edid, fix);
|
fix_edid(edid, fix);
|
||||||
|
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
{
|
{
|
||||||
if (edid[i] != edid_v1_header[i])
|
if (edid[i] != edid_v1_header[i])
|
||||||
err = 0;
|
err = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!err)
|
if (!err)
|
||||||
dbg("edid bad header\r\n");
|
dbg("edid bad header\r\n");
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -199,12 +215,16 @@ static void parse_vendor_block(unsigned char *block, struct fb_monspecs *specs)
|
|||||||
static void get_dpms_capabilities(unsigned char flags, struct fb_monspecs *specs)
|
static void get_dpms_capabilities(unsigned char flags, struct fb_monspecs *specs)
|
||||||
{
|
{
|
||||||
specs->dpms = 0;
|
specs->dpms = 0;
|
||||||
|
|
||||||
if (flags & DPMS_ACTIVE_OFF)
|
if (flags & DPMS_ACTIVE_OFF)
|
||||||
specs->dpms |= FB_DPMS_ACTIVE_OFF;
|
specs->dpms |= FB_DPMS_ACTIVE_OFF;
|
||||||
|
|
||||||
if (flags & DPMS_SUSPEND)
|
if (flags & DPMS_SUSPEND)
|
||||||
specs->dpms |= FB_DPMS_SUSPEND;
|
specs->dpms |= FB_DPMS_SUSPEND;
|
||||||
|
|
||||||
if (flags & DPMS_STANDBY)
|
if (flags & DPMS_STANDBY)
|
||||||
specs->dpms |= FB_DPMS_STANDBY;
|
specs->dpms |= FB_DPMS_STANDBY;
|
||||||
|
|
||||||
dbg(" DPMS: Active %s\r\n", (flags & DPMS_ACTIVE_OFF) ? "yes" : "no");
|
dbg(" DPMS: Active %s\r\n", (flags & DPMS_ACTIVE_OFF) ? "yes" : "no");
|
||||||
dbg(" Suspend: %s\r\n", (flags & DPMS_SUSPEND) ? "yes" : "no");
|
dbg(" Suspend: %s\r\n", (flags & DPMS_SUSPEND) ? "yes" : "no");
|
||||||
dbg(" Standby %s\r\n", (flags & DPMS_STANDBY) ? "yes\r\n" : "no\r\n");
|
dbg(" Standby %s\r\n", (flags & DPMS_STANDBY) ? "yes\r\n" : "no\r\n");
|
||||||
@@ -212,7 +232,7 @@ static void get_dpms_capabilities(unsigned char flags, struct fb_monspecs *specs
|
|||||||
|
|
||||||
static void get_chroma(unsigned char *block, struct fb_monspecs *specs)
|
static void get_chroma(unsigned char *block, struct fb_monspecs *specs)
|
||||||
{
|
{
|
||||||
int32_t tmp;
|
int tmp;
|
||||||
|
|
||||||
/* Chromaticity data */
|
/* Chromaticity data */
|
||||||
tmp = ((block[5] & (3 << 6)) >> 6) | (block[0x7] << 2);
|
tmp = ((block[5] & (3 << 6)) >> 6) | (block[0x7] << 2);
|
||||||
@@ -264,7 +284,7 @@ static void get_chroma(unsigned char *block, struct fb_monspecs *specs)
|
|||||||
dbg(" WhiteY: %d\r\n", specs->chroma.whitey / 10);
|
dbg(" WhiteY: %d\r\n", specs->chroma.whitey / 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t edid_is_serial_block(unsigned char *block)
|
static int edid_is_serial_block(unsigned char *block)
|
||||||
{
|
{
|
||||||
if ((block[0] == 0x00) && (block[1] == 0x00)
|
if ((block[0] == 0x00) && (block[1] == 0x00)
|
||||||
&& (block[2] == 0x00) && (block[3] == 0xff) && (block[4] == 0x00))
|
&& (block[2] == 0x00) && (block[3] == 0xff) && (block[4] == 0x00))
|
||||||
@@ -273,7 +293,7 @@ static int32_t edid_is_serial_block(unsigned char *block)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t edid_is_ascii_block(unsigned char *block)
|
static int edid_is_ascii_block(unsigned char *block)
|
||||||
{
|
{
|
||||||
if ((block[0] == 0x00) && (block[1] == 0x00)
|
if ((block[0] == 0x00) && (block[1] == 0x00)
|
||||||
&& (block[2] == 0x00) && (block[3] == 0xfe) && (block[4] == 0x00))
|
&& (block[2] == 0x00) && (block[3] == 0xfe) && (block[4] == 0x00))
|
||||||
@@ -282,7 +302,7 @@ static int32_t edid_is_ascii_block(unsigned char *block)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t edid_is_limits_block(unsigned char *block)
|
static int edid_is_limits_block(unsigned char *block)
|
||||||
{
|
{
|
||||||
if ((block[0] == 0x00) && (block[1] == 0x00)
|
if ((block[0] == 0x00) && (block[1] == 0x00)
|
||||||
&& (block[2] == 0x00) && (block[3] == 0xfd) && (block[4] == 0x00))
|
&& (block[2] == 0x00) && (block[3] == 0xfd) && (block[4] == 0x00))
|
||||||
@@ -291,7 +311,7 @@ static int32_t edid_is_limits_block(unsigned char *block)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t edid_is_monitor_block(unsigned char *block)
|
static int edid_is_monitor_block(unsigned char *block)
|
||||||
{
|
{
|
||||||
if ((block[0] == 0x00) && (block[1] == 0x00)
|
if ((block[0] == 0x00) && (block[1] == 0x00)
|
||||||
&& (block[2] == 0x00) && (block[3] == 0xfc) && (block[4] == 0x00))
|
&& (block[2] == 0x00) && (block[3] == 0xfc) && (block[4] == 0x00))
|
||||||
@@ -304,6 +324,7 @@ static void calc_mode_timings(int32_t xres, int32_t yres, int32_t refresh, struc
|
|||||||
{
|
{
|
||||||
struct fb_var_screeninfo var;
|
struct fb_var_screeninfo var;
|
||||||
struct fb_info info;
|
struct fb_info info;
|
||||||
|
|
||||||
var.xres = xres;
|
var.xres = xres;
|
||||||
var.yres = yres;
|
var.yres = yres;
|
||||||
fb_get_mode(FB_VSYNCTIMINGS | FB_IGNOREMON, refresh, &var, &info);
|
fb_get_mode(FB_VSYNCTIMINGS | FB_IGNOREMON, refresh, &var, &info);
|
||||||
@@ -321,97 +342,117 @@ static void calc_mode_timings(int32_t xres, int32_t yres, int32_t refresh, struc
|
|||||||
mode->sync = 0;
|
mode->sync = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t get_est_timing(unsigned char *block, struct fb_videomode *mode)
|
static int get_est_timing(unsigned char *block, struct fb_videomode *mode)
|
||||||
{
|
{
|
||||||
int32_t num = 0;
|
int num = 0;
|
||||||
unsigned char c;
|
unsigned char c;
|
||||||
|
|
||||||
c = block[0];
|
c = block[0];
|
||||||
|
|
||||||
if (c & 0x80)
|
if (c & 0x80)
|
||||||
{
|
{
|
||||||
calc_mode_timings(720, 400, 70, &mode[num]);
|
calc_mode_timings(720, 400, 70, &mode[num]);
|
||||||
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
||||||
dbg(" 720x400@70Hz\r\n");
|
dbg(" 720x400@70Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x40)
|
if (c & 0x40)
|
||||||
{
|
{
|
||||||
calc_mode_timings(720, 400, 88, &mode[num]);
|
calc_mode_timings(720, 400, 88, &mode[num]);
|
||||||
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
||||||
dbg(" 720x400@88Hz\r\n");
|
dbg(" 720x400@88Hz\r\n");
|
||||||
}
|
}
|
||||||
if (c&0x20)
|
|
||||||
|
if (c & 0x20)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[3];
|
mode[num++] = vesa_modes[3];
|
||||||
dbg(" 640x480@60Hz\r\n");
|
dbg(" 640x480@60Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x10)
|
if (c & 0x10)
|
||||||
{
|
{
|
||||||
calc_mode_timings(640, 480, 67, &mode[num]);
|
calc_mode_timings(640, 480, 67, &mode[num]);
|
||||||
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
||||||
dbg(" 640x480@67Hz\r\n");
|
dbg(" 640x480@67Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x08)
|
if (c & 0x08)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[4];
|
mode[num++] = vesa_modes[4];
|
||||||
dbg(" 640x480@72Hz\r\n");
|
dbg(" 640x480@72Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x04)
|
if (c & 0x04)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[5];
|
mode[num++] = vesa_modes[5];
|
||||||
dbg(" 640x480@75Hz\r\n");
|
dbg(" 640x480@75Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x02)
|
if (c & 0x02)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[7];
|
mode[num++] = vesa_modes[7];
|
||||||
dbg(" 800x600@56Hz\r\n");
|
dbg(" 800x600@56Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x01)
|
if (c & 0x01)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[8];
|
mode[num++] = vesa_modes[8];
|
||||||
dbg(" 800x600@60Hz\r\n");
|
dbg(" 800x600@60Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
c = block[1];
|
c = block[1];
|
||||||
|
|
||||||
if (c & 0x80)
|
if (c & 0x80)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[9];
|
mode[num++] = vesa_modes[9];
|
||||||
dbg(" 800x600@72Hz\r\n");
|
dbg(" 800x600@72Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x40)
|
if (c & 0x40)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[10];
|
mode[num++] = vesa_modes[10];
|
||||||
dbg(" 800x600@75Hz\r\n");
|
dbg(" 800x600@75Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x20)
|
if (c & 0x20)
|
||||||
{
|
{
|
||||||
calc_mode_timings(832, 624, 75, &mode[num]);
|
calc_mode_timings(832, 624, 75, &mode[num]);
|
||||||
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
mode[num++].flag = FB_MODE_IS_CALCULATED;
|
||||||
dbg(" 832x624@75Hz\r\n");
|
dbg(" 832x624@75Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x10)
|
if (c & 0x10)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[12];
|
mode[num++] = vesa_modes[12];
|
||||||
dbg(" 1024x768@87Hz Interlaced\r\n");
|
dbg(" 1024x768@87Hz Interlaced\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x08)
|
if (c & 0x08)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[13];
|
mode[num++] = vesa_modes[13];
|
||||||
dbg(" 1024x768@60Hz\r\n");
|
dbg(" 1024x768@60Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x04)
|
if (c & 0x04)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[14];
|
mode[num++] = vesa_modes[14];
|
||||||
dbg(" 1024x768@70Hz\r\n");
|
dbg(" 1024x768@70Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x02)
|
if (c & 0x02)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[15];
|
mode[num++] = vesa_modes[15];
|
||||||
dbg(" 1024x768@75Hz\r\n");
|
dbg(" 1024x768@75Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c & 0x01)
|
if (c & 0x01)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[21];
|
mode[num++] = vesa_modes[21];
|
||||||
dbg(" 1280x1024@75Hz\r\n");
|
dbg(" 1280x1024@75Hz\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
c = block[2];
|
c = block[2];
|
||||||
|
|
||||||
if (c & 0x80)
|
if (c & 0x80)
|
||||||
{
|
{
|
||||||
mode[num++] = vesa_modes[17];
|
mode[num++] = vesa_modes[17];
|
||||||
@@ -422,13 +463,21 @@ static int32_t get_est_timing(unsigned char *block, struct fb_videomode *mode)
|
|||||||
return num;
|
return num;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t get_std_timing(unsigned char *block, struct fb_videomode *mode)
|
static int get_std_timing(unsigned char *block, struct fb_videomode *mode)
|
||||||
{
|
{
|
||||||
int32_t xres, yres = 0, refresh, ratio, i;
|
int xres;
|
||||||
|
int yres = 0;
|
||||||
|
int refresh;
|
||||||
|
int ratio;
|
||||||
|
int i;
|
||||||
|
|
||||||
xres = (block[0] + 31) * 8;
|
xres = (block[0] + 31) * 8;
|
||||||
if(xres <= 256)
|
|
||||||
|
if (xres <= 256)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
ratio = (block[1] & 0xc0) >> 6;
|
ratio = (block[1] & 0xc0) >> 6;
|
||||||
|
|
||||||
switch(ratio)
|
switch(ratio)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
@@ -461,14 +510,18 @@ static int32_t get_std_timing(unsigned char *block, struct fb_videomode *mode)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
calc_mode_timings(xres, yres, refresh, mode);
|
calc_mode_timings(xres, yres, refresh, mode);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t get_dst_timing(unsigned char *block, struct fb_videomode *mode)
|
static int get_dst_timing(unsigned char *block, struct fb_videomode *mode)
|
||||||
{
|
{
|
||||||
int32_t j, num = 0;
|
int j;
|
||||||
|
int num = 0;
|
||||||
|
|
||||||
for (j = 0; j < 6; j++, block+= STD_TIMING_DESCRIPTION_SIZE)
|
for (j = 0; j < 6; j++, block+= STD_TIMING_DESCRIPTION_SIZE)
|
||||||
num += get_std_timing(block, &mode[num]);
|
num += get_std_timing(block, &mode[num]);
|
||||||
|
|
||||||
return num;
|
return num;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -485,11 +538,14 @@ static void get_detailed_timing(unsigned char *block, struct fb_videomode *mode)
|
|||||||
mode->lower_margin = V_SYNC_OFFSET;
|
mode->lower_margin = V_SYNC_OFFSET;
|
||||||
mode->hsync_len = H_SYNC_WIDTH;
|
mode->hsync_len = H_SYNC_WIDTH;
|
||||||
mode->vsync_len = V_SYNC_WIDTH;
|
mode->vsync_len = V_SYNC_WIDTH;
|
||||||
if(HSYNC_POSITIVE)
|
|
||||||
|
if (HSYNC_POSITIVE)
|
||||||
mode->sync |= FB_SYNC_HOR_HIGH_ACT;
|
mode->sync |= FB_SYNC_HOR_HIGH_ACT;
|
||||||
if(VSYNC_POSITIVE)
|
|
||||||
|
if (VSYNC_POSITIVE)
|
||||||
mode->sync |= FB_SYNC_VERT_HIGH_ACT;
|
mode->sync |= FB_SYNC_VERT_HIGH_ACT;
|
||||||
mode->refresh = PIXEL_CLOCK/((H_ACTIVE + H_BLANKING) * (V_ACTIVE + V_BLANKING));
|
|
||||||
|
mode->refresh = PIXEL_CLOCK / ((H_ACTIVE + H_BLANKING) * (V_ACTIVE + V_BLANKING));
|
||||||
mode->vmode = 0;
|
mode->vmode = 0;
|
||||||
mode->flag = FB_MODE_IS_DETAILED;
|
mode->flag = FB_MODE_IS_DETAILED;
|
||||||
dbg("%d MHz 0x%04x 0x%04x 0x%04x 0x%04x 0x%04x 0x%04x 0x%04x\r\n",
|
dbg("%d MHz 0x%04x 0x%04x 0x%04x 0x%04x 0x%04x 0x%04x 0x%04x\r\n",
|
||||||
@@ -511,11 +567,13 @@ static void get_detailed_timing(unsigned char *block, struct fb_videomode *mode)
|
|||||||
static struct fb_videomode tab_db[MAX_DB_ALLOC];
|
static struct fb_videomode tab_db[MAX_DB_ALLOC];
|
||||||
static struct fb_videomode *db_used[MAX_DB_ALLOC];
|
static struct fb_videomode *db_used[MAX_DB_ALLOC];
|
||||||
|
|
||||||
static struct fb_videomode *alloc_db(int32_t num)
|
static struct fb_videomode *alloc_db(int num)
|
||||||
{
|
{
|
||||||
int32_t i = 0;
|
int i = 0;
|
||||||
|
|
||||||
if (!num)
|
if (!num)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
while (i < MAX_DB_ALLOC)
|
while (i < MAX_DB_ALLOC)
|
||||||
{
|
{
|
||||||
if ((db_used[i] == NULL) && ((i + num) <= MAX_DB_ALLOC))
|
if ((db_used[i] == NULL) && ((i + num) <= MAX_DB_ALLOC))
|
||||||
@@ -524,7 +582,7 @@ static struct fb_videomode *alloc_db(int32_t num)
|
|||||||
|
|
||||||
for (j = 0; j < num; j++)
|
for (j = 0; j < num; j++)
|
||||||
{
|
{
|
||||||
if (db_used[i+j] != NULL)
|
if (db_used[i + j] != NULL)
|
||||||
break; /* already used */
|
break; /* already used */
|
||||||
}
|
}
|
||||||
if (j >= num)
|
if (j >= num)
|
||||||
@@ -576,18 +634,22 @@ void fb_destroy_modedb(struct fb_videomode *modedb)
|
|||||||
* This function builds a mode database using the contents of the EDID
|
* This function builds a mode database using the contents of the EDID
|
||||||
* data
|
* data
|
||||||
*/
|
*/
|
||||||
static struct fb_videomode *fb_create_modedb(unsigned char *edid, int32_t *dbsize)
|
static struct fb_videomode *fb_create_modedb(unsigned char *edid, int *dbsize)
|
||||||
{
|
{
|
||||||
struct fb_videomode *mode, *m;
|
struct fb_videomode *mode;
|
||||||
|
struct fb_videomode *m;
|
||||||
unsigned char *block;
|
unsigned char *block;
|
||||||
int32_t num = 0, i;
|
int num = 0;
|
||||||
|
int i;
|
||||||
|
|
||||||
// mode = Funcs_malloc(50 * sizeof(struct fb_videomode), 3);
|
// mode = Funcs_malloc(50 * sizeof(struct fb_videomode), 3);
|
||||||
mode = alloc_db(50);
|
mode = alloc_db(50);
|
||||||
|
|
||||||
if (mode == NULL)
|
if (mode == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
memset((char *)mode, 0, 50 * sizeof(struct fb_videomode));
|
memset(mode, 0, 50 * sizeof(struct fb_videomode));
|
||||||
|
|
||||||
if (edid == NULL || !edid_checksum(edid) || !edid_check_header(edid))
|
if (edid == NULL || !edid_checksum(edid) || !edid_check_header(edid))
|
||||||
{
|
{
|
||||||
fb_destroy_modedb(mode);
|
fb_destroy_modedb(mode);
|
||||||
@@ -606,7 +668,7 @@ static struct fb_videomode *fb_create_modedb(unsigned char *edid, int32_t *dbsiz
|
|||||||
block = edid + DETAILED_TIMING_DESCRIPTIONS_START;
|
block = edid + DETAILED_TIMING_DESCRIPTIONS_START;
|
||||||
for (i = 0; i < 4; i++, block+= DETAILED_TIMING_DESCRIPTION_SIZE)
|
for (i = 0; i < 4; i++, block+= DETAILED_TIMING_DESCRIPTION_SIZE)
|
||||||
{
|
{
|
||||||
int32_t first = 1;
|
int first = 1;
|
||||||
|
|
||||||
if (block[0] == 0x00 && block[1] == 0x00)
|
if (block[0] == 0x00 && block[1] == 0x00)
|
||||||
{
|
{
|
||||||
@@ -624,6 +686,7 @@ static struct fb_videomode *fb_create_modedb(unsigned char *edid, int32_t *dbsiz
|
|||||||
num++;
|
num++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Yikes, EDID data is totally useless */
|
/* Yikes, EDID data is totally useless */
|
||||||
if (!num)
|
if (!num)
|
||||||
{
|
{
|
||||||
@@ -642,9 +705,10 @@ static struct fb_videomode *fb_create_modedb(unsigned char *edid, int32_t *dbsiz
|
|||||||
return m;
|
return m;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t fb_get_monitor_limits(unsigned char *edid, struct fb_monspecs *specs)
|
static int fb_get_monitor_limits(unsigned char *edid, struct fb_monspecs *specs)
|
||||||
{
|
{
|
||||||
int32_t i, retval = 1;
|
int i;
|
||||||
|
int retval = 1;
|
||||||
unsigned char *block;
|
unsigned char *block;
|
||||||
|
|
||||||
block = edid + DETAILED_TIMING_DESCRIPTIONS_START;
|
block = edid + DETAILED_TIMING_DESCRIPTIONS_START;
|
||||||
@@ -664,11 +728,16 @@ static int32_t fb_get_monitor_limits(unsigned char *edid, struct fb_monspecs *sp
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* estimate monitor limits based on modes supported */
|
/* estimate monitor limits based on modes supported */
|
||||||
if (retval)
|
if (retval)
|
||||||
{
|
{
|
||||||
struct fb_videomode *modes;
|
struct fb_videomode *modes;
|
||||||
int32_t num_modes, i, hz, hscan, pixclock;
|
int num_modes;
|
||||||
|
int i;
|
||||||
|
int hz;
|
||||||
|
int hscan;
|
||||||
|
int pixclock;
|
||||||
|
|
||||||
modes = fb_create_modedb(edid, &num_modes);
|
modes = fb_create_modedb(edid, &num_modes);
|
||||||
if (!modes)
|
if (!modes)
|
||||||
@@ -748,12 +817,15 @@ static void get_monspecs(unsigned char *edid, struct fb_monspecs *specs)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// dbg("Sync: ");
|
// dbg("Sync: ");
|
||||||
c = block[0] & 0x10;
|
c = block[0] & 0x10;
|
||||||
|
|
||||||
if (c)
|
if (c)
|
||||||
{
|
{
|
||||||
dbg(" Configurable signal level\r\n");
|
dbg(" Configurable signal level\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
c = block[0] & 0x0f;
|
c = block[0] & 0x0f;
|
||||||
specs->signal = 0;
|
specs->signal = 0;
|
||||||
|
|
||||||
@@ -798,22 +870,22 @@ static void get_monspecs(unsigned char *edid, struct fb_monspecs *specs)
|
|||||||
switch ((block[4] & 0x18) >> 3)
|
switch ((block[4] & 0x18) >> 3)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
//DPRINT(" Monochrome/Grayscale\r\n");
|
dbg(" Monochrome/Grayscale\r\n");
|
||||||
specs->input |= FB_DISP_MONO;
|
specs->input |= FB_DISP_MONO;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
//DPRINT(" RGB Color Display\r\n");
|
dbg(" RGB Color Display\r\n");
|
||||||
specs->input |= FB_DISP_RGB;
|
specs->input |= FB_DISP_RGB;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
//DPRINT(" Non-RGB Multicolor Display\r\n");
|
dbg(" Non-RGB Multicolor Display\r\n");
|
||||||
specs->input |= FB_DISP_MULTI;
|
specs->input |= FB_DISP_MULTI;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
//DPRINT(" Unknown\r\n");
|
dbg(" Unknown\r\n");
|
||||||
specs->input |= FB_DISP_UNKNOWN;
|
specs->input |= FB_DISP_UNKNOWN;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -837,7 +909,7 @@ static void get_monspecs(unsigned char *edid, struct fb_monspecs *specs)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t edid_is_timing_block(unsigned char *block)
|
static int edid_is_timing_block(unsigned char *block)
|
||||||
{
|
{
|
||||||
if ((block[0] != 0x00) || (block[1] != 0x00)
|
if ((block[0] != 0x00) || (block[1] != 0x00)
|
||||||
|| (block[2] != 0x00) || (block[4] != 0x00))
|
|| (block[2] != 0x00) || (block[4] != 0x00))
|
||||||
@@ -846,7 +918,7 @@ static int32_t edid_is_timing_block(unsigned char *block)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t fb_parse_edid(unsigned char *edid, struct fb_var_screeninfo *var)
|
int fb_parse_edid(unsigned char *edid, struct fb_var_screeninfo *var)
|
||||||
{
|
{
|
||||||
int32_t i;
|
int32_t i;
|
||||||
unsigned char *block;
|
unsigned char *block;
|
||||||
@@ -889,17 +961,21 @@ int32_t fb_parse_edid(unsigned char *edid, struct fb_var_screeninfo *var)
|
|||||||
void fb_edid_to_monspecs(unsigned char *edid, struct fb_monspecs *specs)
|
void fb_edid_to_monspecs(unsigned char *edid, struct fb_monspecs *specs)
|
||||||
{
|
{
|
||||||
unsigned char *block;
|
unsigned char *block;
|
||||||
int32_t i;
|
int i;
|
||||||
|
|
||||||
if (edid == NULL)
|
if (edid == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!(edid_checksum(edid)))
|
if (!(edid_checksum(edid)))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!(edid_check_header(edid)))
|
if (!(edid_check_header(edid)))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (specs->modedb != NULL)
|
if (specs->modedb != NULL)
|
||||||
fb_destroy_modedb(specs->modedb);
|
fb_destroy_modedb(specs->modedb);
|
||||||
memset((char *)specs, 0, sizeof(struct fb_monspecs));
|
|
||||||
|
memset(specs, 0, sizeof(struct fb_monspecs));
|
||||||
specs->version = edid[EDID_STRUCT_VERSION];
|
specs->version = edid[EDID_STRUCT_VERSION];
|
||||||
specs->revision = edid[EDID_STRUCT_REVISION];
|
specs->revision = edid[EDID_STRUCT_REVISION];
|
||||||
dbg("========================================\r\n");
|
dbg("========================================\r\n");
|
||||||
@@ -914,9 +990,7 @@ void fb_edid_to_monspecs(unsigned char *edid, struct fb_monspecs *specs)
|
|||||||
if (edid_is_serial_block(block))
|
if (edid_is_serial_block(block))
|
||||||
{
|
{
|
||||||
copy_string(block, specs->serial_no);
|
copy_string(block, specs->serial_no);
|
||||||
//DPRINT(" Serial Number: ");
|
dbg(" Serial Number: %d\r\n", specs->serial_no);
|
||||||
//DPRINT((void *)specs->serial_no);
|
|
||||||
//DPRINT("\r\n");
|
|
||||||
}
|
}
|
||||||
else if (edid_is_ascii_block(block))
|
else if (edid_is_ascii_block(block))
|
||||||
{
|
{
|
||||||
@@ -935,7 +1009,7 @@ void fb_edid_to_monspecs(unsigned char *edid, struct fb_monspecs *specs)
|
|||||||
}
|
}
|
||||||
//DPRINT(" Display Characteristics:\r\n");
|
//DPRINT(" Display Characteristics:\r\n");
|
||||||
get_monspecs(edid, specs);
|
get_monspecs(edid, specs);
|
||||||
specs->modedb = fb_create_modedb(edid, (int32_t *)&specs->modedb_len);
|
specs->modedb = fb_create_modedb(edid, (int *) &specs->modedb_len);
|
||||||
dbg("========================================\r\n");
|
dbg("========================================\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1208,7 +1282,7 @@ int32_t fb_get_mode(int32_t flags, uint32_t val, struct fb_var_screeninfo *var,
|
|||||||
dclkmin = info->monspecs.dclkmin;
|
dclkmin = info->monspecs.dclkmin;
|
||||||
dclkmax = info->monspecs.dclkmax;
|
dclkmax = info->monspecs.dclkmax;
|
||||||
}
|
}
|
||||||
memset((char *)&timings, 0, sizeof(struct __fb_timings));
|
memset(&timings, 0, sizeof(struct __fb_timings));
|
||||||
timings.hactive = var->xres;
|
timings.hactive = var->xres;
|
||||||
timings.vactive = var->yres;
|
timings.vactive = var->yres;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user