Posts Tagged ‘howto’

HDR timelapse

Saturday, April 9th, 2011

Става много бързо и лесно.
Използван хардуер:
- Canon SX120IS (става всеки CHDK-съвместим фотоапарат)
Използван софтуер:
- CHDK
- intervalometer script - без значение точно кой
- enfuse - за сливане на различните експозиции и получаване на HDR
- PHP - долу ще намерите бърз скрипт за сливане на много на брой кадри
- mencoder - за сливане на HDR-ите във финално клипче

Какво е timelapse?
Това е кинематографска техника при която честотата на заснемане на кадрите е по-малка от честотата на възпроизвеждането им. Примерно ако една сцена се снима всяка секунда и после клипа се пусне на 30 fps резултатът ще бъде увеличаване на скоростта 30 пъти.

Какво е HDR?
Ако се абстрахираме от математиката и засуканите термини, можем разговорно да кажем че това е техника за получаване на равномерно осветен кадър (с изчистени преекспонирани и недоекспонирани области). Технологията стандартно използва три кадъра с различна експозиция (-2, 0, +2), които слива в един - изчистен.

Какво става като комбинираме HDR с timelapse?
Красиви клипчета :)

Как се прави HDR timelapse с CHDK?
CHDK не прави HDR - това се прави после от софтуера, който слива трите снимки на сцената. CHDK прави "bracketing" - автоматичното заснемане на трите кадъра с различна експозиция. Следвайте следните стъпки:
1. В менюто на CHDK изберете "Extra Photo Operations" -> "Bracketing in Continuous Mode". Там изберете "Tv bracketing" = 2EV, "Av bracketing" = OFF, "Bracketing type" = "+/-"
2. В менюто на фотоапарата изберете режим "Continuous Mode".
3. В менюто за самоснимачка изберете "Custom mode" със следните параметри: "Delay" = 0s, "Shots" = 3
От тук нататък пуснете кой да е intervalometer скрипт с параметри по избор. Какво ще се случи когато скриптът даде команда за снимане? Ще се задейства самоснимачката, която ще направи 3 последователни снимки с различна експозиция.

В края на сесията след няколко минути/часа ще имате X броя сцени с Х*3 броя изображения. Прехвърляте ги на компютъра и със следния скрипт получавате HDR-ите:

  1.  
  2. <?php
  3. $rDir = opendir(".");
  4. $aFileList = array();
  5. while( ($sFileName = readdir($rDir)) !== false){
  6.     if (!strstr($sFileName, "IMG")) continue;
  7.     $aFileList[] = $sFileName;
  8. }
  9. sort($aFileList);
  10. $aFileList = array_chunk($aFileList, 3);
  11. foreach ($aFileList as $iShotKey => $aFileGroup){
  12.     $sGroupList = join(" ", $aFileGroup);
  13.     $iShotKey = sprintf("%03d", $iShotKey);
  14.     print "Enfuse shot #$iShotKey...";
  15.     `enfuse $sGroupList -o hdr_shot_$iShotKey.jpg`;
  16.     print " done!\n";
  17. }
  18. print_r($aFileList);
  19. ?>
  20.  

От тук нататък имате всяка сцена на HDR с име от типа hdr_shot_001.jpg. От тези трябва да се получи клипче.
Това става с mencoder:
mencoder mf://*.jpg -mf w=640:h=480:fps=15:type=jpg -ovc lavc -lavcopts vcodec=mpeg4:mbd=2:trell -oac copy -o output.avi
Тук 640 и 480 са размерите на снимките ви. Може да си поиграете с параметъра fps за да получите по-бързи или по-бавни клипчета.

Настоящата статия не претендира за изчерпаемост на темата, нито за професионализъм. Но пък претендира за най-лесния и бърз начин за създаване на HDR timelapse :)

И накрая резултата от едно пробно снимане:

Мониторинг качеството на нета

Wednesday, March 11th, 2009

Терминът "качество на нета" по-скоро е взет от някой тинейджърски журнал, но уцелва точно нуждите на крайния клиент. Аз като клиент на моя ISP се нуждая от две неща - ниска (по възможност - никаква) загуба на пакети и ниско (по възможност - никакво) забавяне на пакетите. Това трябва да ми се поднесе разбираемо, с картинка.
Нужен софтуер:

  • RRDtool - има страхотни възможности за представяне на числова информация. За примерни графики вижте галерията им.
  • ping - резултата от изпълнението на ping съдържа всичко необходимо за изграждане на статистиката ни - Round trip time и Packet loss
  • Perl - или друг удобен ви език. Трябва ви за парсване на изхода от ping
  • crontab - искаме статистиката да се събира през определен интервал от време

Системата може да бъде разделена на две части: част за събиране на статистика и част за графично представяне на данните.
Събиране на статистика
На всеки 5 минути ще се пуска ping до няколко избрани хоста в различни зони на пиъринга. Естествено върнатите резултати ще са субективни, защото зависят от параметрите на отсрещната точка. Все пак цялото задание "качество на нета" е субективно, така че да продължаваме :) Избрал съм единия хост да бъде шлюза на доставчика ми, втория хост да бъде dir.bg (тест на bg пиъринга) и третия хост да бъде ivanatora.info (за тест на международната свързаност).
Логът се изгражда от следния скрипт:
/home/ivanatora/perl_razni/ping_stats.pl

  1.  
  2. #!/usr/bin/perl
  3. $target = $ARGV[0]; # тук ще идва адреса на целта
  4. $db = $ARGV[1]; # тук ще идва в коя база ще се записва
  5. $dump = "/home/ivanatora/stats_ping/$target.log"; # лога с крайните резултати
  6. $rrd_path = "/home/ivanatora/rrd/temps/pings"; # директорията с RRD базите
  7. open (FH, ">>", $dump) or die "$!";
  8. ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime(time);
  9. $mon++;
  10. $year += 1900;
  11. $time = sprintf("%02d/%02d/%4d %02d:%02d:%02d", $mday, $mon, $year, $hour, $min, $sec);
  12. $output = `/bin/ping -q -c100 -w100 $target`; # пуска ping със 100 пакета и чака максимално 100 секунди за изпълнението на командата
  13.  
  14. if ($output =~ /(\d+?)% packet loss/){
  15.         $loss = $1;
  16.         $percent = sprintf("%3d", $1);
  17. }
  18. if ($output =~ /rtt min\/avg\/max\/mdev = .+?\/(.+?)\//){
  19.         $avg = $1;
  20.         print FH "$time : $percent% loss to $target Average: $1 ms\n";
  21.         # update RRD
  22.         $ts = time;
  23.         $mod = $ts % 300;
  24.         $ts -= $mod;
  25.         $avg =~ /^(.+?)\./;
  26.         $rtt = $1;
  27.         `/home/ivanatora/rrd/bin/rrdtool update $rrd_path/$db.rrd $ts:$loss:$rtt`; # командата за ъпдейт на базата; TODO: да направя пътя до изпълнимия файл на rrdtool в променлива
  28. }
  29. close (FH);
  30.  

Малко изпреварвам времето, защото още не сме създали RRD базите. Каква е идеята на RRD? Round Robin Database е способ за запазване на постоянно изменяща се информация във времето, като всяка промяна се регистрира в цикличен буфер. Ако имаме един буфер със 12 слота и ъпдейтваме базата през 5 минути, във всеки момент ще имаме данните от предния час. Какво става с по-старите данни - губят ли се? Да. Ако ни трябват ще направим още един буфер, който ще се ъпдейтва на всяко цялостно извъртане на часовия буфер - ще взима средната стойност на всички измервания и ще го записва в един негов слот. Така ако този буфер има 24 слота ще имаме статистика на средната часова стойност на измерванията. Може да имате колкото си искате вторични буфери и всички се съхраняват в една и съща база и се ъпдейтват автоматично. Освен това в един буфер може да пазите стойностите на няколко променливи. Предимствата на RRD е че всяка промяна се регистрира, като размера на базата не нараства линейно във времето.
До тук вероятно имаме лог с нещо такова:
/home/ivanatora/stats_ping/dir.bg.log

11/03/2009 00:05:01 : 0% loss to dir.bg Average: 7.271 ms
11/03/2009 00:10:01 : 0% loss to dir.bg Average: 9.091 ms
11/03/2009 00:15:01 : 0% loss to dir.bg Average: 7.466 ms
11/03/2009 00:20:01 : 1% loss to dir.bg Average: 7.152 ms
11/03/2009 00:25:01 : 0% loss to dir.bg Average: 8.273 ms
11/03/2009 00:30:01 : 0% loss to dir.bg Average: 6.863 ms
11/03/2009 00:35:01 : 0% loss to dir.bg Average: 11.690 ms

Този лог може да използваме за каквото си искаме, а може и въобще да не го правим. Горния скрипт работи ъпдейтва директно rrdtool, така че ако не искате излишни логове да се пазят на машината ви насочете $dump = "/dev/null"; :)

Създаване на RRD бази.
За всеки изследван хост ще направим по една база. В тази база ще се съхраняват стойностите за Round Trip Time и Packet Loss.
Правим си следното bash скриптче (освен ако не ви мързи да го пишете на ръка за всяка база - може да имате и повече от три бази):

  1.  
  2. #!/bin/bash
  3. NOW=`date +%s`
  4. rrdtool create $1.rrd --start $NOW --step 300 \
  5. DS:PacketLoss:GAUGE:300:0:100 \
  6. DS:RTT:GAUGE:300:0:10000 \
  7. RRA:LAST:0.5:1:288 \
  8. RRA:AVERAGE:0.5:6:336 \
  9. RRA:AVERAGE:0.5:24:360 \
  10. RRA:AVERAGE:0.5:288:365
  11.  

Подробностите за синтаксиса можете да намерите в документацията на RRDtool. На кратко - създаваме база с 2 източника на данни (променливи, които ще следим): PacketLoss и RTT. Задават се интервалите на ъпдейт на всеки източник,минимални и максимални допустими стойности. След това се правят 4 Round Robin Archives (буферите, за които говорихме по-рано).
Създаваме трите бази:

[ivanatora@~/rrd/temps/pings]$ sh create_script.sh bg
[ivanatora@~/rrd/temps/pings]$ sh create_script.sh gw
[ivanatora@~/rrd/temps/pings]$ sh create_script.sh int

Слагаме cronjob за изпълнение на ъпдейтващия скрипт на 5 минути:

*/5 * * * * perl /home/ivanatora/perl_razni/ping_stats.pl 87.120.194.1 gw
*/5 * * * * perl /home/ivanatora/perl_razni/ping_stats.pl dir.bg bg
*/5 * * * * perl /home/ivanatora/perl_razni/ping_stats.pl ivanatora.info int

Както видяхме скрипта приема два аргумента: адрес за ping и име на базата, която ъпдейтва.
Рисуване на графиките
Ще имаме отделна графика за всяка следена величина. Може да комбинираме няколко от графиките на една, но само ако очаквате там приблизително еднакви резултати. Големите отклонения на величините карат rrdtool да измества разделителната способност на графиката и една от графиките в общата картинка не се вижда добре. Ще имаме два скрипта за чертане на графики - един за Round Trip Time и един за Packet Loss.
/home/ivanatora/rrd/temps/pings/loss_graph.sh

  1.  
  2. #!/bin/bash
  3. PATH=$PATH:/home/ivanatora/rrd/bin
  4. DIR=/home/ivanatora/rrd/temps/pings/
  5. rrdtool graph $DIR/img/loss-$1.png \
  6. --title="<$1> Packet loss" \
  7. --color CANVAS#000000 \
  8. --color BACK#000000 \
  9. --color GRID#006600 \
  10. --color MGRID#003300 \
  11. --color AXIS#00ff00 \
  12. --color FONT#00ff00 \
  13. --color SHADEA#000000 \
  14. --color SHADEB#000000 \
  15. --slope-mode \
  16. --upper-limit 100 \
  17. --rigid \
  18. --width 480 \
  19. --height 300 \
  20. --font DEFAULT:10:Arial \
  21. DEF:loss=$DIR/$1.rrd:PacketLoss:LAST \
  22. DEF:rtt=$DIR/$1.rrd:RTT:LAST \
  23. AREA:loss#00FF00:"Packet loss (%)"
  24.  

/home/ivanatora/rrd/temps/pings/rtt_graph.sh

  1.  
  2. #!/bin/bash
  3. PATH=$PATH:/home/ivanatora/rrd/bin
  4. DIR=/home/ivanatora/rrd/temps/pings/
  5. rrdtool graph $DIR/img/rtt-$1.png \
  6. --title="<$1> Round trip time" \
  7. --color CANVAS#000000 \
  8. --color BACK#000000 \
  9. --color GRID#006600 \
  10. --color MGRID#003300 \
  11. --color AXIS#00ff00 \
  12. --color FONT#00ff00 \
  13. --color SHADEA#000000 \
  14. --color SHADEB#000000 \
  15. --slope-mode \
  16. --width 480 \
  17. --height 300 \
  18. --font DEFAULT:10:Arial \
  19. DEF:loss=$DIR/$1.rrd:PacketLoss:LAST \
  20. DEF:rtt=$DIR/$1.rrd:RTT:LAST \
  21. AREA:rtt#00FF00:"Round trip time (ms)"
  22.  

Тук можем да си поиграем с цветовете и крайния резултат да е доста eye-candy. Важните редове са DEF - където се извличат стойностите на променливите от базата и AREA - самото изчертаване. За повече подробности - документацията на RRDtool.
След това правим един скрипт, който да задейства изчертаване на всички графики:
/home/ivanatora/rrd/temps/pings/graph_all.sh

  1.  
  2. #!/bin/bash
  3. DIR=/home/ivanatora/rrd/temps/pings/
  4. $DIR/loss_graph.sh int
  5. $DIR/loss_graph.sh bg
  6. $DIR/loss_graph.sh gw
  7. $DIR/rtt_graph.sh int
  8. $DIR/rtt_graph.sh bg
  9. $DIR/rtt_graph.sh gw
  10.  

И поставяме съответната задача в crontab:

*/5 * * * * sh /home/ivanatora/rrd/temps/pings/graph_all.sh

В резултат всичките изображения се намират в директорията pings/img/. Остава да направим красива HTML страничка, която да събира всичко в едно.
Резултата можете да го видите тук.

SE k800i Linux Modem Part 2

Sunday, February 22nd, 2009

В миналата част си поговорихме как да закачим телефона към компютъра така че да се работи с USB CDC драйвъра. Сега ще стане дума как да си пуснете реален интернет на компютъра. Тук имам само карта към МТЕЛ и съм писал за него, така че всички читатели които ползват услугите на евентуален друг оператор ще трябва леко да си редактират настройките.
PPP
Трябва ви point-to-point protocol поддръжка под някаква форма. Дали вградено в ядрото или на модул - по ваш избор. Нужните отметки в конфигурацията на ядрото са следните:

  • Device Drivers --->[*] Network device support ---> PPP (point-to-point protocol) support
  • Device Drivers --->[*] Network device support ---> PPP support for async serial ports

Ако решите да ги компилирате като модули, първия модул ще се казва ppp_generic, а втория ppp_async. Трябват ви и двете неща, иначе ще получавате странни грешки от рода на:

The PPP daemon has died: Fatal pppd error (exit code = 1)
1 An immediately fatal error of some kind occurred, such as an
essential system call failing, or running out of virtual mem-
ory.

Wvdial
Хубавото на Wvdial е че само си открива поддържаните настройки от модема и само си създава конфигурационен файл. Освен това не е нужно да се мъчите с /etc/ppp/* скриптове и настройки и даже не е нужно да сте прочели и ред от pppd man-страницата :)
Създаване на конфигурационен файл:

# wvdialconf
Editing `/etc/wvdial.conf'.

Scanning your serial ports for a modem.

WvModem<*1>: Cannot set information for serial port.
ttyS0<*1>: ATQ0 V1 E1 -- failed with 2400 baud, next try: 9600 baud
ttyS0<*1>: ATQ0 V1 E1 -- failed with 9600 baud, next try: 115200 baud
ttyS0<*1>: ATQ0 V1 E1 -- and failed too at 115200, giving up.
WvModem<*1>: Cannot set information for serial port.
ttyS1<*1>: ATQ0 V1 E1 -- failed with 2400 baud, next try: 9600 baud
ttyS1<*1>: ATQ0 V1 E1 -- failed with 9600 baud, next try: 115200 baud
ttyS1<*1>: ATQ0 V1 E1 -- and failed too at 115200, giving up.
Modem Port Scan<*1>: S2 S3
WvModem<*1>: Cannot get information for serial port.
ttyACM0<*1>: ATQ0 V1 E1 -- OK
ttyACM0<*1>: ATQ0 V1 E1 Z -- OK
ttyACM0<*1>: ATQ0 V1 E1 S0=0 -- OK
ttyACM0<*1>: ATQ0 V1 E1 S0=0 &C1 -- OK
ttyACM0<*1>: ATQ0 V1 E1 S0=0 &C1 &D2 -- OK
ttyACM0<*1>: ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0 -- OK
ttyACM0<*1>: Modem Identifier: ATI -- Sony Ericsson K810
ttyACM0<*1>: Speed 4800: AT -- OK
ttyACM0<*1>: Speed 9600: AT -- OK
ttyACM0<*1>: Speed 19200: AT -- OK
ttyACM0<*1>: Speed 38400: AT -- OK
ttyACM0<*1>: Speed 57600: AT -- OK
ttyACM0<*1>: Speed 115200: AT -- OK
ttyACM0<*1>: Speed 230400: AT -- OK
ttyACM0<*1>: Speed 460800: AT -- OK
ttyACM0<*1>: Max speed is 460800; that should be safe.
ttyACM0<*1>: ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0 -- OK
WvModem<*1>: Cannot get information for serial port.
ttyACM1<*1>: ATQ0 V1 E1 -- failed with 2400 baud, next try: 9600 baud
ttyACM1<*1>: ATQ0 V1 E1 -- failed with 9600 baud, next try: 115200 baud
ttyACM1<*1>: ATQ0 V1 E1 -- and failed too at 115200, giving up.

Found an USB modem on /dev/ttyACM0.

Отваряме /etc/wvdial.conf и редактираме редовете Phone, Username, Password. Добавяме и ред Init3. Това е крайното състояние при мен (за МТЕЛ) :

[Dialer Defaults]
Init1 = ATZ
Init2 = ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0
Init3 = AT+CGDCONT=1,"IP","inet-gprs.mtel.bg"
Modem Type = USB Modem
ISDN = 0
Phone = *99#
Modem = /dev/ttyACM0
Username = dada
Password = dada
Baud = 460800

По принцип интернета на МТЕЛ се използва с каквито и да е Username и Password, но wvdial не ви позволява да оставяте тези полета празни. Из нета на разни места пишат че може и да се сложи следния ред:
Stupid Mode = 1
ако wvdial не може да си комуникира добре с модема ви. За k800i нямаше нужда.
Connect
Стартирането на pppd, което става автоматично от wvdial изисква отново да сте root.

# wvdial
--> WvDial: Internet dialer version 1.60
--> Cannot get information for serial port.
--> Initializing modem.
--> Sending: ATZ
ATZ
OK
--> Sending: ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0
ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0
OK
--> Sending: AT+CGDCONT=1,"IP","inet-gprs.mtel.bg"
AT+CGDCONT=1,"IP","inet-gprs.mtel.bg"
OK
--> Modem initialized.
--> Sending: ATDT*99***1#
--> Waiting for carrier.
ATDT*99***1#
CONNECT
~[7f]}#@!}!}!} }9}#}%B#}%}(}"}'}"}"}&} } } } }%}&VKD}1[7f])~
--> Carrier detected. Starting PPP immediately.
--> Starting pppd at Sun Feb 22 19:48:09 2009
--> Pid of pppd: 26823
--> Using interface ppp0
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> local IP address 10.161.47.249
--> pppd: 8[07][08]X¢[07][08][07][08]
--> remote IP address 10.64.64.64
--> pppd: 8[07][08]X¢[07][08][07][08]
--> primary DNS address 213.226.7.34
--> pppd: 8[07][08]X¢[07][08][07][08]
--> secondary DNS address 213.226.7.35
--> pppd: 8[07][08]X¢[07][08][07][08]
^CCaught signal 2: Attempting to exit gracefully...
--> Terminating on signal 15
--> pppd: 8[07][08]X¢[07][08][07][08]
--> Connect time 1.5 minutes.
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> pppd: 8[07][08]X¢[07][08][07][08]
--> Disconnecting at Sun Feb 22 19:49:38 2009

CTRL+C спира връзката.
Има няколко важни неща, които трябва да се видят тук. Това че сте свързан към GPRS access point при оператора ви все още не означава че компютъра ви може да ползва интернет. Трябва да се добави default route, със следния gateway:
--> remote IP address 10.64.64.64
Съответно:
# route add default gw 10.64.64.64
Ако преди това сте бил свързан към друг доставчик явно ще трябва да махнете default gw, който ви е от него.
При спирането на връзката може да забележите следния ред, който показва за колко време сте били connected:
--> Connect time 1.5 minutes.
Други статистики може да видите от ifconfig ppp0:

ppp0 Link encap:Point-to-Point Protocol
inet addr:10.161.47.249 P-t-P:10.64.64.64 Mask:255.255.255.255
UP POINTOPOINT RUNNING NOARP MULTICAST MTU:1500 Metric:1
RX packets:64 errors:0 dropped:0 overruns:0 frame:0
TX packets:317 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:3
RX bytes:7125 (6.9 KiB) TX bytes:53884 (52.6 KiB)

Конкретно това което ви интересува е RX и TX bytes, защото те струват пари. Не съм сигурен дали оператора отчита трафика по същия начин, за това не бих приел тези цифри много твърдо.

И финалния най-важен въпрос: колко бърз интернет можете да си пуснете - при мен стигна до четвърт мегабит:

wget http://mirrors.unixsol.org/linuxpackages//Slackware-12.0/ken/google-earth-4.2.205-i486-1kjz.tgz
--19:54:57-- http://mirrors.unixsol.org/linuxpackages//Slackware-12.0/ken/google-earth-4.2.205-i486-1kjz.tgz
=> `google-earth-4.2.205-i486-1kjz.tgz'
Resolving mirrors.unixsol.org... 193.110.159.35
Connecting to mirrors.unixsol.org|193.110.159.35|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 22,863,884 (22M) [application/x-tar]

1% [> ] 442,690 37.82K/s ETA 10:23

Това зависи от мрежата, която ви покрива. Максималните скорости са съответно:

  • CSD (WAP dial-up) - 9.6 Kbps
  • GPRS - 90 Kbps
  • EDGE - 236 Kbps
  • UMTS - 384 Kbps
  • HSDPA - 14.4 Mbps downlink

Внимание: всичко различно от WAP CSD може сериозно да ви бръкне в сметката! MTEL дават 1MB трафик за 2.50 лв. Тарифата за WAP е 11 ст. на минута. Горното howto е писано за всичко от GPRS нагоре. За чист WAP ще експериментирам и тези дни вероятно ще пусна Part 3 на това howto.

Update: Операторката от телефон 1010 ми съобщи че MTEL от една година насам не предлагат CSD достъп, а само GPRS.

SE k800i Linux modem

Wednesday, February 18th, 2009

Фен съм на GSM-модемите. Това е идеалната и най-проста backup линия за връзка с домашното (или сървърното) ви PC. Предполага се че това PC е винаги в зоната на покритие на някой от GSM операторите, така че телефона ви винаги ще е online. По-старите телефони с RS-232 комуникация имат един недостатък - батерията им пада с времето и трябва да пачвате буксата за да я вържете в постоянно включено в контакта зарядно. Иначе какъв backup е ако телефона ви остане без ток на третия ден :) Този недостатък го няма в по-съвременните телефони с USB кабели, където батерията постоянно се дозарежда през кабела. (От USB порта може да се извади максимум до 100mA ток, което е повече от колкото може да извади зарядното ви.)
Удивително успях да се свържа с модема на k800 за по-малко от час ръчкане. Ето нужните стъпки:
0) Телефона се свързва с кабел към компютъра. На екранчето излиза меню, което ви пита в какъв режим да работи телефона. Избирате "Phone Mode". Във "File transfer" режим телефона се рестартира и се mount-ва като флаш драйв, а това не ви трябва в момента.
1) Трябва ви CDC ACM драйвър, който служи като виртуален сериен порт под USB. Драйвърът обикновено върви в комплект с линукс кернела. Когато телефона ви е свързан с кабел към компютъра трябва да виждате устройства /dev/ttyACM*. Ако не виждате такива устройства вероятно нямате ACM драйвър. Може да се разминете без прекомпилиране на кернела, ако го добавите драйвъра като модул:
Device Drivers ---> USB support ---> USB Modem (CDC ACM) support (за кернел 2.6.25.6)
След това следват:
$ make modules
# make modules_install
при което ще бъде компилиран и инсталиран само този модул.
Можете да го заредите с:
# modprobe cdc_acm
Ако все още не се появяват устройства /dev/ttyACM*, проверете какво се вижда в lsusb. Трябва да виждате нещо като това:
Bus 5 Device 16: ID 0fce:d0a1 Sony Ericsson Mobile Communications AB
2) По подразбиране само root потребителя може да работи с тези устройства. При засичане на модем, драйвъра автоматично си създава ttyACM*, но режима на достъп обикновено е root:root 0600. Едно временно решение е:
# chmod a+rw /dev/ttyACM*
Но след презакачане на телефона udev ще възстанови 0600 режима.
За да направите така че всеки потребител да има достъп по всяко време, добавете следния ред в /etc/udev/rules.d/50-udev.rules:
KERNEL="ttyACM*", NAME="%k", GROUP="uucp", MODE="666"
3) След като имате виртуалните серийни портове, можете да използвате любимата си програма за серийна комуникация. Обикновено трябва да зададете порт с който да се свърже и настройки. Тук идва интересната част, защото при мен се появяват обикновено няколко виртуални порта (ttyACM0, ttyACM1, ttyACM2) на всяко свързване. Може да експериментирате с всеки от портовете докато откриете къде ви е модема. Слава богу поне не се грижите да следите на какъв default baud rate работи модема, защото той е умен и се синхронизира към скоростта на вашето предаване.
Полезна програмка, която можете да използвате и за dialing е wvdial. Хубавото в нея е че изследва какво имате вързано по портовете и сама се конфигурира.
За финал - написвате си daemon програмка, която следи за състоянието на модема и при дадено събитие изпълнява нещо. Например аз следя за входящо повикване от другия си номер и когато се появи, изпълнява командата `xmms -f` и сменя песните в XMMS-a. Ето на това му викам полезен backup и дистанционно за случаите когато ме мързи да стана от леглото :)
Друго примерно приложение е при получаване на SMS да се изъплнява шелска команда, която се съдържа в него. За целта обаче първо трябва да си разкодирате SMS-а, което е готина задачка. Прочетете повече за PDU формата на съобщенията тук.
Ето ви и едно примерно съобщение, с което можете да си поиграете за домашна работа (цялото съобщение е на един ред без интервали, които го разбиват):
AT+CMGL=4
+CMGL: 1,1,,86
07915389080003F104048111110000902061904403805146F9BBAD034DE
961777ACE0EDB413CFA7B3E9FC96280733B9C66BBC6EFB60F442DE3E93A
10A8999ECFD36F3768FC6EC3D9657A991C025DC3697ADA7D0699DF72D05
B4E2ECB4320
OK

P.S. Документацията с АТ командите може да си дръпнете от девелоперската секция в сайта на Sony Ericsson.

P.S.2. Подозирам че горното писание важи за всеки телефон с USB връзка и модем, не само за k800 :)

Какво е HFSC и има ли почва у нас

Thursday, January 29th, 2009

Снощи нямах какво да правя, та взех и преведох текст от разни места и го събрах в едно материалче което разглежда принципа на действие на HFSC. Има примери как се прави това в Linux и *BSD.

Статията може да е скучна за доста хора, така че който го интересува да чете навътре :)

(more...)