Прошу прощенья, действительно забыл самое главное...
Итак, числа...
Прерывания идут 64 раза в секунду, это 15.62 мс между прерываниями.
Через одну-две милисекунды после прихода прерывания уходит запрос, еще
через пару милисекунд приходит ответ. В результате у нас остается
приблизительно 7 мс чтоб записать максимум 1540 байт на диск и
приготовиться к новому прерыванию.
После проведения тестов выяснили следующее:
Скорость прямой записи на flash (/dev/hda)
ориентировочно 1.3 мегабайта в секунду.
(при записи через ext2 на /dev/hda1 скорость выше 10 мегабайт в секунду,
но потом - при размере файла больше 10 мегабайт падает).
Получается, что для записи 1540 байт у нас есть 1.5 милисекунды, т.е. должно вроде бы хватать. А оно не хватат...
# uname -a
Linux viper 2.4.21-rmk1-pxa1-arcom1-mmx #22 Tue Aug 31 17:08:01 EEST 2004 armv5tel unknown
# dmesg
Linux version 2.4.21-rmk1-pxa1-arcom1-mmx (mmx@alligator) (gcc version 3.3.2) #22 Tue Aug 31 17:08:01 EEST 2004
CPU: XScale-PXA255 revision 6
Machine: Arcom VIPER SBC
Memory clock: 99.53MHz (*27)
Run Mode clock: 199.07MHz (*2)
Turbo Mode clock: 199.07MHz (*1.0, active)
On node 0 totalpages: 16384
zone(0): 16384 pages.
zone(1): 0 pages.
zone(2): 0 pages.
Kernel command line: ro console=ttyS0,115200n8 root=/dev/mtdblock3
Relocating machine vectors to 0xffff0000
Configuring ISA interrupt 3 as IRQ 104
Configuring ISA interrupt 4 as IRQ 105
Configuring ISA interrupt 5 as IRQ 106
Configuring ISA interrupt 6 as IRQ 107
Configuring ISA interrupt 7 as IRQ 108
Configuring ISA interrupt 10 as IRQ 109
Configuring ISA interrupt 11 as IRQ 110
Configuring ISA interrupt 12 as IRQ 111
Console: colour dummy device 80x30
Calibrating delay loop... 198.24 BogoMIPS
Memory: 64MB = 64MB total
Memory: 63416KB available (1036K code, 275K data, 60K init)
Dentry cache hash table entries: 8192 (order: 4, 65536 bytes)
Inode cache hash table entries: 4096 (order: 3, 32768 bytes)
Mount cache hash table entries: 512 (order: 0, 4096 bytes)
Buffer-cache hash table entries: 4096 (order: 2, 16384 bytes)
Page-cache hash table entries: 16384 (order: 4, 65536 bytes)
POSIX conformance testing by UNIFIX
Linux NET4.0 for Linux 2.4
Based upon Swansea University Computer Society NET3.039
Initializing RT netlink socket
Setting core voltage 1.0V (scaling factor 0xfff)<6>
befole cycle 'for'
after cycle 'for'
LD_SET...
udelay...
LD_CLR...
DONE.
Using PXA255 frequency points.
Registering CPU frequency change support.
CPU clock: 199.065 MHz (99.000-400.000 MHz)
Starting kswapd
JFFS2 version 2.2. (C) 2001-2003 Red Hat, Inc.
Not calling pckbd_init_hw()
pty: 256 Unix98 ptys configured
Serial driver version 5.05c (2001-07-08) with MANY_PORTS SHARE_IRQ enabled
ttyS00 at 0x0000 (irq = 15) is a PXA UART
ttyS01 at 0x0000 (irq = 14) is a PXA UART
ttyS02 at 0x0000 (irq = 13) is a PXA UART
ttyS03 at 0xf3300010 (irq = 27) is a 16550A
ttyS04 at 0xf3300000 (irq = 26) is a 16550A
loop: loaded (max 8 devices)
Probing VIPER flash device at physical address 0x04000000
flash: Found 1 x16 devices at 0x0 in 16-bit mode
flash: Found an alias at 0x1000000 for the chip at 0x0
flash: Found an alias at 0x2000000 for the chip at 0x0
flash: Found an alias at 0x3000000 for the chip at 0x0
Intel/Sharp Extended Query Table at 0x0031
cfi_cmdset_0001: Erase suspend on write enabled
0: offset=0x0,size=0x20000,blocks=128
Using buffer write method
4 RedBoot partitions found on MTD device flash
Creating 4 MTD partitions on "flash":
0x00000000-0x0001f000 : "FIS directory"
mtd: partition "FIS directory" doesn't end on an erase block -- force read-only
0x0001f000-0x00020000 : "RedBoot config"
mtd: partition "RedBoot config" doesn't start on an erase block boundary -- force read-only
0x00020000-0x000c0000 : "kernel"
0x000c0000-0x01000000 : "filesystem"
NET4: Linux TCP/IP 1.0 for NET4.0
IP Protocols: ICMP, UDP, TCP
IP: routing cache hash table of 512 buckets, 4Kbytes
TCP: Hash tables configured (established 4096 bind 8192)
NET4: Unix domain sockets 1.0/SMP for Linux NET4.0.
NetWinder Floating Point Emulator V0.97 (double precision)
VFS: Mounted root (jffs2 filesystem) readonly.
Freeing init memory: 60K
i2c-core.o: i2c core module
i2c-algo-bit.o: i2c bit algorithm module
i2c-viper: VIPER I2C Driver
I2C: DS1307 RTC driver successfully loaded. Device at 0x68
usb.c: registered new driver usbdevfs
usb.c: registered new driver hub
hc_isp116x.c: USB ISP116x at f4000000/f4000002,240 IRQ 25 Rev. 10 ChipID: 6122
usb.c: new USB bus registered, assigned bus number 1
hub.c: USB hub found
hub.c: 2 ports detected
smc91x.c: v1.0, mar 07 2003 by Nicolas Pitre <nico@cam.org>
eth0: SMC91C11xFD (rev 1) at 0xc8898300 IRQ 1 [nowait]
eth0: Ethernet addr: 00:80:66:10:06:2e
eth0: PHY=LAN83C183 (LAN91C111 Internal)
<5>eth0: PHY remote fault detected
<5>eth0: Ethernet Link Detected
eth0: PHY 100BaseT
eth0: PHY Full Duplex
root# /usr/sbin/hdparm -I /dev/hda
/dev/hda:
CompactFlash ATA device, with removable media
Model Number: CF 64MB
Serial Number: GHS2ABPCF03031400005
Firmware Revision: 02/08/29
Standards:
Likely used: 4
Configuration:
Logical max current
cylinders 1000 1000
heads 4 4
sectors/track 32 32
--
bytes/track: 0 bytes/sector: 512
CHS current addressable sectors: 128000
LBA user addressable sectors: 128000
device size with M = 1024*1024: 62 MBytes
device size with M = 1000*1000: 65 MBytes
Capabilities:
LBA, IORDY(may be)(cannot be disabled)
Buffer size: 0.5kB bytes avail on r/w long: 4 Queue
depth: 1
Standby timer values: spec'd by Vendor
R/W multiple sector transfer: Max = 1 Current = 0
DMA: not supported
PIO: pio0 pio1 pio2