martedì 2 luglio 2013

Raspberry WiFi

A circa un anno di distanza dall'ultimo utilizzo ho ritirato fuori la Raspberry per montare la nuova versione della Raspbian e vedere come sono migliorate le cose.

La cosa piu' immediata e' stata che alcuni dongle usb wireless, essendo Raspbian passata a Wheezy, vengono riconosciuti al volo come nel caso il chip Ralink...stranamente il Realtek non viene riconosciuta in modo corretto
Inoltre e' stata aggiunta una GUI per la configurazione della rete Wireless che rende l'utilizzo del WiFi molto semplice





--------------------------
Jul  2 10:20:04 debian kernel: [  220.652158] usb 1-3: new high-speed USB device number 4 using ehci_hcd
Jul  2 10:20:05 debian kernel: [  220.802197] usb 1-3: New USB device found, idVendor=148f, idProduct=5370
Jul  2 10:20:05 debian kernel: [  220.802214] usb 1-3: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Jul  2 10:20:05 debian kernel: [  220.802230] usb 1-3: Product: 802.11 n WLAN
Jul  2 10:20:05 debian kernel: [  220.802241] usb 1-3: Manufacturer: Ralink
Jul  2 10:20:05 debian kernel: [  220.802253] usb 1-3: SerialNumber: 1.0
Jul  2 10:20:05 debian mtp-probe: checking bus 1, device 4: "/sys/devices/pci0000:00/0000:00:1d.7/usb1/1-3"
Jul  2 10:20:05 debian mtp-probe: bus: 1, device: 4 was not an MTP device
Jul  2 10:20:05 debian kernel: [  221.352215] usb 1-3: reset high-speed USB device number 4 using ehci_hcd
Jul  2 10:20:05 debian kernel: [  221.517326] usbcore: registered new interface driver rt2800usb


lunedì 1 luglio 2013

SQlite in Python

Un esempio su come usare Sqlite in Python

Per installare le librerie di Sqlite si digita

apt-get install python-sqlite

--------------------------------------------------------
#!/usr/bin/python
# -*- coding: utf-8 -*-

import sqlite3 as lite
import sys

con = lite.connect('birra.db')

with con:
    
cur = con.cursor()    
cur.execute("DROP TABLE IF EXISTS birra")
cur.execute("CREATE TABLE birra(Rifd TEXT, Gratis INT)")
cur.execute("INSERT INTO birra VALUES('12345',1)")
cur.execute("SELECT * FROM birra")
while True:
row = cur.fetchone()

if row == None:
break

print row[0], row[1]
if row[1] == 1: 
print "Birra gratis"
else:
print "Birra da pagare"

cur.execute("UPDATE birra SET Gratis=0 WHERE Rifd='12345'")
cur.execute("SELECT * FROM birra")
while True:
row = cur.fetchone()

if row == None:
break

print row[0], row[1]
if row[1] == 1: 
print "Birra gratis"
else:
print "Birra da pagare"

venerdì 28 giugno 2013

Emulatore Android Genymotion


Avendo visto un po' di recensioni positive ho provato l'emulatore Android Genymotion.

Come gia' visto in altri post si possono usare emulatori differenti da quello presente nell'SDK, per esempio usando Virtual Box... in questo caso l'emulatore e' stato scritto ex-novo.

Per la prova ho lanciato sulla stessa macchina una emulazione di un NeXus S con le API16





I risultati si commentano da soli

Emulatore Genymotion 18 secondi
Emulatore SDK 1 inuto e 28 secondi

Pattern Lock and Unlock su Android

Per cercare di limitare i danni dalla perdita del telefono (vedi il precedente post) ho deciso di abilitare il Pattern Lock di Android ...e' un po' scomodo ma puo' valere la pena tenerlo abilitato



Ma e' vera sicurezza ?
Basta un po' di ricerca per trovare su YouTube video come questo


dove si insegna la procedura per rimuovere il Pattern Lock.
L'unico dettaglio non scontato e' che il telefono abbia il Debugging abilitato (ma dato che ogni tanto sviluppo per Android tutte le mie perifieriche sono abilitate)
Si deve collegare il cavo ed avere l'SDK Android disponibile, dopo di cio' da shell si digitano i comandi

adb shell
su
rm /data/system/locksettings.db
rm /data/system/locksettings.db-wal
rm /data/system/locksettings.db-shm
reboot


Oltre a cio' c'e' da segnalare che dopo tre falliti tentativi il telefono si blocca e deve essere attivata una differen

Abbondare un telefono cellulare

Mi e' capitato di trovare in un cestino della spazzatura un nemmen troppo vecchio cellulare Sony Ericsson W395 rotto e privo di battera ma ero sempre stato incuriosito dal sistema di chiusura a slide e lo ho preso per studiarlo

In realta' il sistema a slitta di chiusura e' piuttosto banale ma quasi per caso mi sono accorto di una sorpresa; il cellulare era dotato di una porta per micromemoria e dentro era custodita una memoria




Di primo acchito ho estratto la memoria e la ho inserita nel lettore di microSD ma con mia sorpresa il fattore di forma era leggermente differente .. diciamo piu' quadrato


Leggendo meglio infatti non si tratta di un formato MicroSd ma di un formato M2, prodotto da Sony (guarda caso) e di cui al momento attuale e' stata sospesa la produzione.
In ogni caso con un lettore di schedine multiplo sono riuscito ad accedere alla memoria e di fatto ad entrare  virtualmente nella vita privata di un'altra persona.
Ovviamente non ho spulciato il contenuto in foto della scheda ne' altri dati sensibili, dopo aver accertato che era possibile ho formattato la memoria ma la considerazione e' banale....se perdendo od abbandandonando un telefono piuttosto vecchio (non certo uno smartphone Android od IPhone o Windows) si puo' esporre cosi' il proprio privato cosa accadrebbe se perdessi il mio telefono Android collegato al mio account Google dove c'e' praticamente di tutto (con la falsa sensazione di essere al sicuro) ???


USB Ethernet Dongle Apple A1277 su Debian

Recentemente mi e' stato presato l'adattatore Ethernet USB A1277 della Apple e ero curioso di vedere come avrebbe reagito la mia Debian Box


Una volta inserito nella porta USB il log ha mostrato quanto segue
-----------------------
Jun 27 23:18:27 debian kernel: [  426.872207] usb 1-3: new high-speed USB device number 5 using ehci_hcd
Jun 27 23:18:27 debian kernel: [  427.021199] usb 1-3: New USB device found, idVendor=05ac, idProduct=1402
Jun 27 23:18:27 debian kernel: [  427.021213] usb 1-3: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Jun 27 23:18:27 debian kernel: [  427.021224] usb 1-3: Product: Apple USB Ethernet Adapter
Jun 27 23:18:27 debian kernel: [  427.021233] usb 1-3: Manufacturer: Apple Inc.      
Jun 27 23:18:27 debian kernel: [  427.021241] usb 1-3: SerialNumber: 019F66
Jun 27 23:18:27 debian mtp-probe: checking bus 1, device 5: "/sys/devices/pci0000:00/0000:00:1d.7/usb1/1-3"
Jun 27 23:18:27 debian mtp-probe: bus: 1, device: 5 was not an MTP device
Jun 27 23:18:27 debian kernel: [  427.479994] asix 1-3:1.0: eth1: register 'asix' at usb-0000:00:1d.7-3, ASIX AX88772 USB 2.0 Ethernet, 00:1f:5b:ff:27:2e
Jun 27 23:18:27 debian kernel: [  427.480945] usbcore: registered new interface driver asix
Jun 27 23:18:28 debian kernel: [  428.407986] ADDRCONF(NETDEV_UP): eth1: link is not ready
-----------------------

La periferica ha quindi iniziato a funzionare perfettamente senza nient'altro da fare (Debian Wheezy)

giovedì 27 giugno 2013

Cavo seriale USB ADJ

Visto che ho perso il precedente convertitore da Seriale ad USB ne ho ripreso un altro.
Stavolta la scelta obbligato e' stata sul cavo della ADJ

Il problema e' che il componente non riportava all'interno della confezione ne' un libretto di istruzioni ne' un CD con i driver (almeno per Windows), tantomeno la compatibilita' con Linux


una volta inserito nella mia Debian Box il cavo e' stato riconosciuto con il seguente log
-----------------------------
Jun 25 18:02:19 debian kernel: [  139.010458] usbserial: USB Serial Driver core
Jun 25 18:02:19 debian kernel: [  139.021465] USB Serial support registered for pl2303
Jun 25 18:02:19 debian kernel: [  139.021543] pl2303 5-1:1.0: pl2303 converter detected
Jun 25 18:02:19 debian kernel: [  139.032608] usb 5-1: pl2303 converter now attached to ttyUSB0
Jun 25 18:02:19 debian kernel: [  139.032720] usbcore: registered new interface driver pl2303
Jun 25 18:02:19 debian kernel: [  139.032733] pl2303: Prolific PL2303 USB to serial adaptor driver
-----------------------------

Piu' difficile e' stato reperire il giusto driver per Windows. Quello funzionante e' risultato essere il Prolific USB-to Serial Comm Port


Feature Matching OpenCv

Il problema e' il seguente: trovare le differenze tra le due foto. Le due immagini sono state riprese a distanza di oltre un anno ed il ...