Herramientas de usuario

Herramientas del sitio


guias:orangepizero

Diferencias

Muestra las diferencias entre dos versiones de la página.

Enlace a la vista de comparación

Ambos lados, revisión anteriorRevisión previa
Próxima revisión
Revisión previa
guias:orangepizero [2018/01/31 23:35] – [Empezar rápido desde linux] Sergio Alvariñoguias:orangepizero [2023/01/02 17:26] (actual) Sergio Alvariño
Línea 5: Línea 5:
 ===== Crear una SD arrancable ===== ===== Crear una SD arrancable =====
  
-Dependiendo de donde conectemos la tarjeta tendremos que usar diferentes rutas. En el procedimiento descrito a continuación ''%%${card}%%'' será la ruta al dispositivo de la tarjeta y ${p} la partición (si la hay).+Dependiendo de donde conectemos la tarjeta tendremos que usar diferentes rutas. En el procedimiento descrito a continuación ''<nowiki>${card}</nowiki>'' será la ruta al dispositivo de la tarjeta y ${p} la partición (si la hay).
  
-Si la tarjeta se conecta via adaptador USB, linux la va a asociar a un dispositivo /dev/sdx, por ejemplo en mi portátil el disco duro es ''%%/dev/sda%%'' las distintas particiones serán ''%%/dev/sda1%%'', ''%%/devb/sda2%%'', etc.+Si la tarjeta se conecta via adaptador USB, linux la va a asociar a un dispositivo /dev/sdx, por ejemplo en mi portátil el disco duro es ''<nowiki>/dev/sda</nowiki>'' las distintas particiones serán ''<nowiki>/dev/sda1</nowiki>'', ''<nowiki>/devb/sda2</nowiki>'', etc.
  
-Si conectamos una memoria con un adaptador USB linux la podría mapear en ''%%/dev/sdb%%'' por ejemplo.+Si conectamos una memoria con un adaptador USB linux la podría mapear en ''<nowiki>/dev/sdb</nowiki>'' por ejemplo.
  
-Si la memoria se conecta mediante una ranura SD, linux la asociará a un dispositivo ''%%/dev/mmcblk0%%'' o ''%%/dev/mmcblk1%%'', etc. etc. Dependerá de la ranura usada. Las particiones en este tipo de dispositivos tienen rutas como por ejemplo ''%%/dev/mmcblk0p1%%''.+Si la memoria se conecta mediante una ranura SD, linux la asociará a un dispositivo ''<nowiki>/dev/mmcblk0</nowiki>'' o ''<nowiki>/dev/mmcblk1</nowiki>'', etc. etc. Dependerá de la ranura usada. Las particiones en este tipo de dispositivos tienen rutas como por ejemplo ''<nowiki>/dev/mmcblk0p1</nowiki>''.
  
 Los datos se pueden almacenar directamente en la memoria SD o en una partición creada en la memoria. Los datos se pueden almacenar directamente en la memoria SD o en una partición creada en la memoria.
Línea 17: Línea 17:
 Resumiendo: Resumiendo:
  
-  * ''%%${card}%%'' será ''%%/dev/sdb%%'' o ''%%/dev/mmcblk0%%'' +  * ''<nowiki>${card}</nowiki>''  será ''<nowiki>/dev/sdb</nowiki>''  o ''<nowiki>/dev/mmcblk0</nowiki>'' 
-  * ${card}${p} será ''%%/dev/sdb1%%'' o ''%%/dev/mmcblk0p1%%''+  * ${card}${p} será ''<nowiki>/dev/sdb1</nowiki>''  o ''<nowiki>/dev/mmcblk0p1</nowiki>''
  
 Antes de seguir adelante hay que estar completamente seguro del dispositivo asociado a nuestra memoria SD para no armar ningún estropicio. Antes de seguir adelante hay que estar completamente seguro del dispositivo asociado a nuestra memoria SD para no armar ningún estropicio.
Línea 24: Línea 24:
 Hay varias comprobaciones que se pueden hacer: Hay varias comprobaciones que se pueden hacer:
  
-''%%dmesg |tail%%'' nos permitirá echar un ojo a los últimos mensajes en el log del sistema. Si acabamos de insertar la memoria veremos el dispositivo usado. +''<nowiki>dmesg |tail</nowiki>''  nos permitirá echar un ojo a los últimos mensajes en el log del sistema. Si acabamos de insertar la memoria veremos el dispositivo usado.
- +
-''%%sudo fdisk -l%%'' nos permite ver las particiones montadas en nuestro linux, por ejemplo con mi SD en la ranura SD de mi portatil la salida es (entre otras cosas, he obviado las particiones de los discos duros):+
  
 +''<nowiki>sudo fdisk -l</nowiki>''  nos permite ver las particiones montadas en nuestro linux, por ejemplo con mi SD en la ranura SD de mi portatil la salida es (entre otras cosas, he obviado las particiones de los discos duros):
 <code> <code>
 +
 Disk /dev/mmcblk0: 7.4 GiB, 7948206080 bytes, 15523840 sectors Disk /dev/mmcblk0: 7.4 GiB, 7948206080 bytes, 15523840 sectors
 Units: sectors of 1 * 512 = 512 bytes Units: sectors of 1 * 512 = 512 bytes
Línea 35: Línea 35:
 Disklabel type: dos Disklabel type: dos
 Disk identifier: 0x00000000 Disk identifier: 0x00000000
 +
 </code> </code>
-''%%cat /proc/partitions%%'' también nos dará una lista de particiones, en mi portátil las que interesan son:+ 
 +''<nowiki>cat /proc/partitions</nowiki>''  también nos dará una lista de particiones, en mi portátil las que interesan son:
  
 <code> <code>
  179        0    7761920 mmcblk0  179        0    7761920 mmcblk0
  179        1    7757824 mmcblk0p1  179        1    7757824 mmcblk0p1
 +
 </code> </code>
-Descargamos la imagen de Jessie adaptada a la //Orange Pi Zero// desde la página https://www.armbian.com/download/ 
  
-Descomprimimos la imagen la grabamos en la tarjeta SD con el comando:+Descargamos la imagen de Jessie adaptada a la //Orange Pi Zero//  desde la página [[https://www.armbian.com/download/|https://www.armbian.com/download/]]
  
 +Descomprimimos la imagen y la grabamos en la tarjeta SD con el comando:
 <code> <code>
 +
 sudo dd if=./Armbian_5.24_Orangepizero_Debian_jessie_3.4.113.img of=/dev/mmcblk0 sudo dd if=./Armbian_5.24_Orangepizero_Debian_jessie_3.4.113.img of=/dev/mmcblk0
 +
 </code> </code>
-Insertamos la tarjeta en la //Orange Pi// y le damos alimentación. El primer arranque llevará alrededor de tres minutos, y tras ese tiempo aun hará falta un minuto más para poder hacer login. Este retardo es debido a que el sistema intentará actualizar la lista de paquetes y creará un area de swap de emergencia en la SD, y además cambiará el tamaño de la partición que hemos creado para ocupar todo el espacio libre en la SD.+ 
 +Insertamos la tarjeta en la //Orange Pi//  y le damos alimentación. El primer arranque llevará alrededor de tres minutos, y tras ese tiempo aun hará falta un minuto más para poder hacer login. Este retardo es debido a que el sistema intentará actualizar la lista de paquetes y creará un area de swap de emergencia en la SD, y además cambiará el tamaño de la partición que hemos creado para ocupar todo el espacio libre en la SD.
  
 De momento solo la he arrancado y efectivamente las particiones han cambiado tras el arranque así que tiene buena pinta. De momento solo la he arrancado y efectivamente las particiones han cambiado tras el arranque así que tiene buena pinta.
  
-Volvemos a insertar la SD en la //Orange Pi// y la conectamos con un cable ethernet al router de casa. El Armbian viene configurado por defecto para obtener su IP desde un servidor DHCP.+Volvemos a insertar la SD en la //Orange Pi//  y la conectamos con un cable ethernet al router de casa. El Armbian viene configurado por defecto para obtener su IP desde un servidor DHCP.
  
 Como mi cutre-router no me da información de las IP asignadas usamos //nmap//: Como mi cutre-router no me da información de las IP asignadas usamos //nmap//:
Línea 59: Línea 65:
 <code> <code>
 nmap -sP 192.168.0.0/24 nmap -sP 192.168.0.0/24
 +
 </code> </code>
-Con eso averiguamos la IP asignada a la //Orange Pi Zero// y ya podemos hacer login con el siguiente comando ((La password por defecto de Armbian es **1234**, nos pedirá cambiarla en el primer login. + 
-)):+Con eso averiguamos la IP asignada a la //Orange Pi Zero//  y ya podemos hacer login con el siguiente comando ((La password por defecto de Armbian es 1234 , nos pedirá cambiarla en el primer login.)) :
  
 <code> <code>
 ssh root@192.168.0.109 ssh root@192.168.0.109
 +
 </code> </code>
 +
 ¡Y ya estamos! ¡Y ya estamos!
  
-{{:src/img/OrangePiZero_FirstLogin.png| Primer login en //Orange Pi//}}+{{:guias:orangepizero_firstlogin.png}}
  
 Lo primero es poner al dia el sistema: Lo primero es poner al dia el sistema:
Línea 75: Línea 84:
 apt-get update apt-get update
 apt-get upgrade apt-get upgrade
 +
 </code> </code>
 +
 Si quieres puedes reconfigurar el //time zone//: Si quieres puedes reconfigurar el //time zone//:
  
 <code> <code>
 dpkg-reconfigure tzdata dpkg-reconfigure tzdata
 +
 </code> </code>
 +
 ===== Conexión WIFI ===== ===== Conexión WIFI =====
  
Línea 98: Línea 111:
  
 eth0      no wireless extensions. eth0      no wireless extensions.
 +
 </code> </code>
 +
 Todo tiene buena pinta, vamos a ver si detecta WIFIs: Todo tiene buena pinta, vamos a ver si detecta WIFIs:
  
Línea 115: Línea 130:
                     ESSID:""                     ESSID:""
                     ESSID:"mikasa"                     ESSID:"mikasa"
 +
 </code> </code>
-Para configurar el wifi echamos un ojo al fichero ''%%/etc/network/interfaces%%'' pero en ese mismo fichero encontramos el aviso: 
  
 +Para configurar el wifi echamos un ojo al fichero ''<nowiki>/etc/network/interfaces</nowiki>''  pero en ese mismo fichero encontramos el aviso:
 <code> <code>
 +
 # Armbian ships with network-manager installed by default. To save you time # Armbian ships with network-manager installed by default. To save you time
 # and hassles consider using 'sudo nmtui' instead of configuring Wi-Fi settings # and hassles consider using 'sudo nmtui' instead of configuring Wi-Fi settings
 # manually. # manually.
 +
 </code> </code>
-Así que basta con ejecutar ''%%sudo nmtui%%'' y ya podemos dar de alta nuestra wifi (yo la prefiero con IP estática). 
  
-{{:src/img/OrangePiZero_tmtui.png| Configuración WIFI}}+Así que basta con ejecutar ''<nowiki>sudo nmtui</nowiki>''  y ya podemos dar de alta nuestra wifi (yo la prefiero con IP estática).
  
-Ejecutamos ''%%ifconfig%%'' y ya vemos nuestro nuevo interface configurado:+{{  :guias:orangepizero_tmtui.png?600  | Configuración WIFI }}
  
 +Ejecutamos ''<nowiki>ifconfig</nowiki>''  y ya vemos nuestro nuevo interface configurado:
 <code> <code>
 +
 ifconfig ifconfig
  
Línea 140: Línea 159:
           collisions:0 txqueuelen:1000           collisions:0 txqueuelen:1000
           RX bytes:328 (328.0 B)  TX bytes:852 (852.0 B)           RX bytes:328 (328.0 B)  TX bytes:852 (852.0 B)
 +
 </code> </code>
 +
 ====== Orange Pi Zero, características técnicas ====== ====== Orange Pi Zero, características técnicas ======
  
Línea 163: Línea 184:
 Un excelente esquema de pines puede conseguirse en [[https://oshlab.com/orange-pi-zero-pinout/|OSHLab]] Un excelente esquema de pines puede conseguirse en [[https://oshlab.com/orange-pi-zero-pinout/|OSHLab]]
  
-{{:src/img/Orange-Pi-Zero-Pinout.jpg| Pineado Orange Pi}}+[[:src:img:orange-pi-zero-pinout.jpg?id=guias:orangepizero&media=src:img:orange-pi-zero-pinout.jpg|{{:src:img:orange-pi-zero-pinout.jpg?nolink&| Pineado Orange Pi}}]]
  
 El mapeado de los pines de la Orange (de los micros Allwinner en realidad) en el kernel de Linux viene dado por la formula: El mapeado de los pines de la Orange (de los micros Allwinner en realidad) en el kernel de Linux viene dado por la formula:
- 
 <code> <code>
 +
 (Position of letter in alphabet - 1) * 32 + Pin number (Position of letter in alphabet - 1) * 32 + Pin number
 +
 </code> </code>
-Para todos los pines PA de nuestra Orange Pi Zero, el número del kernel coincide con el del pin. Pero para los pines //PG06// y //PG07// se corresponden con los códigos //198// y //199//.+ 
 +Para todos los pines PA de nuestra Orange Pi Zero, el número del kernel coincide con el del pin. Pero para los pines //PG06//  y //PG07//  se corresponden con los códigos //198//  y //199//.
  
 ===== Esquemas eléctricos ===== ===== Esquemas eléctricos =====
Línea 179: Línea 202:
  
 La memoria es más que suficiente para correr programas. El Armbian consume únicamente 40Mb en funcionamiento. La memoria es más que suficiente para correr programas. El Armbian consume únicamente 40Mb en funcionamiento.
- 
 <code> <code>
 +
 root@orangepizero:~# free root@orangepizero:~# free
              total       used       free     shared    buffers     cached              total       used       free     shared    buffers     cached
Línea 186: Línea 209:
 -/+ buffers/cache:      44844     202224 -/+ buffers/cache:      44844     202224
 Swap:       131068          0     131068 Swap:       131068          0     131068
 +
 </code> </code>
 +
 Vamos a hacer algunas pruebas con el hardware. En Armbian, como todo Unix que se precie, todo es un fichero. Vamos a hacer algunas pruebas con el hardware. En Armbian, como todo Unix que se precie, todo es un fichero.
  
-En el directorio ''%%/sys/class%%'' encontraremos cosas interesantes:+En el directorio ''<nowiki>/sys/class</nowiki>''  encontraremos cosas interesantes:
  
 <code> <code>
Línea 198: Línea 223:
 bsg    dma      hwmon    leds       mmc_host  rfkill        scsi_host    sunxi_dump  usb_device bsg    dma      hwmon    leds       mmc_host  rfkill        scsi_host    sunxi_dump  usb_device
 cedar_dev  gpio     i2c-adapter  lirc       net       rtc       sound    sunxi_info  vc cedar_dev  gpio     i2c-adapter  lirc       net       rtc       sound    sunxi_info  vc
 +
 </code> </code>
 +
 ===== LEDs ===== ===== LEDs =====
  
-Si miramos dentro del directorio ''%%leds%%'' veremos que hay un directorio que representa cada uno de los leds de la placa:+Si miramos dentro del directorio ''<nowiki>leds</nowiki>''  veremos que hay un directorio que representa cada uno de los leds de la placa:
  
 <code> <code>
Línea 207: Línea 234:
 root@orangepizero:/sys/class/leds# ls root@orangepizero:/sys/class/leds# ls
 green_led  red_led green_led  red_led
 +
 </code> </code>
-Podemos ver, por ejemplo, a que evento está asociado cada led ejecutando ''%%cat green_led/trigger%%'' (tiene el valor ''%%default_on%%'') o ''%%cat red_led/trigger%%'' (tiene el valor ''%%none%%'').+ 
 +Podemos ver, por ejemplo, a que evento está asociado cada led ejecutando ''<nowiki>cat green_led/trigger</nowiki>''  (tiene el valor ''<nowiki>default_on</nowiki>'') o ''<nowiki>cat red_led/trigger</nowiki>''  (tiene el valor ''<nowiki>none</nowiki>'').
  
 <code> <code>
-root@orangepizero:/sys/class/leds# cat green_led/trigger  +root@orangepizero:/sys/class/leds# cat green_led/trigger 
-none mmc0 mmc1 timer heartbeat backlight [default-on] rfkill0 phy1rx phy1tx phy1assoc phy1radio  +none mmc0 mmc1 timer heartbeat backlight [default-on] rfkill0 phy1rx phy1tx phy1assoc phy1radio 
-root@orangepizero:/sys/class/leds# cat red_led/trigger  +root@orangepizero:/sys/class/leds# cat red_led/trigger 
-[none] mmc0 mmc1 timer heartbeat backlight default-on rfkill0 phy1rx phy1tx phy1assoc phy1radio +[none] mmc0 mmc1 timer heartbeat backlight default-on rfkill0 phy1rx phy1tx phy1assoc phy1radio 
 </code> </code>
-O podemos encender el led rojo ejecutando ''%%echo 1 > red_led/brightness%%'', y para apagarlo ya os podéis imaginar que es ''%%echo 0 > red_led/brightness%%''.+ 
 +O podemos encender el led rojo ejecutando ''<nowiki>echo 1 > red_led/brightness</nowiki>'', y para apagarlo ya os podéis imaginar que es ''<nowiki>echo 0 > red_led/brightness</nowiki>''.
  
 ===== GPIO ===== ===== GPIO =====
Línea 230: Línea 261:
  gpio-354 (?                   ) out hi  gpio-354 (?                   ) out hi
  gpio-362 (green_led           ) out hi  gpio-362 (green_led           ) out hi
 +
 </code> </code>
 +
 Podemos activar un nuevo puerto GPIO, digamos el 15: Podemos activar un nuevo puerto GPIO, digamos el 15:
  
 <code> <code>
-root@orangepizero:~# echo 15 >/sys/class/gpio/export+root@orangepizero:~# echo 15>/sys/class/gpio/export 
 </code> </code>
 +
 Ahora veremos el puerto activo: Ahora veremos el puerto activo:
  
 <code> <code>
-root@orangepizero:~# cat /sys/kernel/debug/gpio +root@orangepizero:~# cat /sys/kernel/debug/gpio
 GPIOs 0-383, platform/sunxi-pinctrl, sunxi-pinctrl: GPIOs 0-383, platform/sunxi-pinctrl, sunxi-pinctrl:
  gpio-10  (?                   ) out hi  gpio-10  (?                   ) out hi
Línea 247: Línea 282:
  gpio-354 (?                   ) out hi  gpio-354 (?                   ) out hi
  gpio-362 (green_led           ) out hi  gpio-362 (green_led           ) out hi
 +
 </code> </code>
-En el directorio ''%%/sys/class/gpio/gpio15/%%'' tendremos los interfaces usuales para puertos gpio definidos en el kernel de linux.+ 
 +En el directorio ''<nowiki>/sys/class/gpio/gpio15/</nowiki>''  tendremos los interfaces usuales para puertos gpio definidos en el kernel de linux.
  
 ====== Bibliotecas útiles ====== ====== Bibliotecas útiles ======
Línea 262: Línea 299:
 sudo aptitude install python-virtualenv sudo aptitude install python-virtualenv
 sudo aptitude install python-dev sudo aptitude install python-dev
 +
 </code> </code>
-El caso es que el //virtualenv// no me funciona después de ejecutar estos pasos. Finalmente he tenido que ejecutar, como //root//, los siguientes comandos:+ 
 +El caso es que el //virtualenv//  no me funciona después de ejecutar estos pasos. Finalmente he tenido que ejecutar, como //root//, los siguientes comandos:
  
 <code> <code>
 pip install --upgrade pip pip install --upgrade pip
 pip install --upgrade virtualenv pip install --upgrade virtualenv
 +
 </code> </code>
-Despues de eso ya he podido usar //virtualenv// sin problemas.+ 
 +Despues de eso ya he podido usar //virtualenv//  sin problemas.
  
 ==== orangepi_PC_gpio_pyH3 ==== ==== orangepi_PC_gpio_pyH3 ====
Línea 275: Línea 316:
 Tenemos dos repos disponibles: Tenemos dos repos disponibles:
  
-El repositorio original con las librerías //gpio// para H3:+El repositorio original con las librerías //gpio//  para H3:
  
 <code> <code>
 git clone https://github.com/duxingkei33/orangepi_PC_gpio_pyH3 git clone https://github.com/duxingkei33/orangepi_PC_gpio_pyH3
 +
 </code> </code>
-Y un fork del repositorio original **ya adaptado** a la Orange Pi Zero (que es el que usaremos):+ 
 +Y un fork del repositorio original **ya adaptado**  a la Orange Pi Zero (que es el que usaremos):
  
 <code> <code>
 git clone https://github.com/nvl1109/orangepi_PC_gpio_pyH3 git clone https://github.com/nvl1109/orangepi_PC_gpio_pyH3
 +
 </code> </code>
-**IMPORTANTE:** Si usamos el repositorio original tenemos que revisar el fichero ''%%orangepi_PC_gpio_pyH3/pyA20/gpio/mapping.h%%'' 
  
-Por ejemplo: la definicion de //STATUS_LED// debe quedar en el //GPA17// en lugar de //GPA15//:+**IMPORTANTE:**  Si usamos el repositorio original tenemos que revisar el fichero ''<nowiki>orangepi_PC_gpio_pyH3/pyA20/gpio/mapping.h</nowiki>'' 
 + 
 +Por ejemplo: la definicion de //STATUS_LED//  debe quedar en el //GPA17//  en lugar de //GPA15//:
  
 <code> <code>
 {   "STATUS_LED",  SUNXI_GPA(17),  2   }, {   "STATUS_LED",  SUNXI_GPA(17),  2   },
 +
 </code> </code>
 +
 Nos clonamos el repo. Vamos a hacer todas las pruebas desde la cuenta de **root**. Nos clonamos el repo. Vamos a hacer todas las pruebas desde la cuenta de **root**.
  
Línea 299: Línea 346:
 virtualenv test_pyH3_zero virtualenv test_pyH3_zero
 source test_pyH3_zero/bin/activate source test_pyH3_zero/bin/activate
 +
 </code> </code>
 +
 Compilamos la biblioteca: Compilamos la biblioteca:
  
Línea 305: Línea 354:
 cd orangepi_PC_gpio_pyH3 cd orangepi_PC_gpio_pyH3
 python setup.py install python setup.py install
 +
 </code> </code>
 +
 Y ya podemos probar los ficheros de ejemplo: Y ya podemos probar los ficheros de ejemplo:
  
Línea 311: Línea 362:
 examples/blink_led.py examples/blink_led.py
 examples/blink_POWER_STATUS_PL10.py examples/blink_POWER_STATUS_PL10.py
 +
 </code> </code>
 +
 El resto de ejemplos no van a funcionar, están escritos para la //A20-OLinuXino-MICRO// El resto de ejemplos no van a funcionar, están escritos para la //A20-OLinuXino-MICRO//
  
Línea 324: Línea 377:
 ls ls
 gpio/  i2c/  __init__.py  spi/  utilities/ gpio/  i2c/  __init__.py  spi/  utilities/
 +
 </code> </code>
-Nos interesa probar las bibliotecas en los directorios //gpio// e //i2c//, al menos de momento. Serían //gpio_lib// e //i2c_lib// respectivamente. 
  
-Probamos el acceso al //gpio// desde C con un programa sencillo que nos haga encender y apagar el led de la OPI.+Nos interesa probar las bibliotecas en los directorios //gpio//  e //i2c//, al menos de momento. Serían //gpio_lib//  e //i2c_lib//  respectivamente. 
 + 
 +Probamos el acceso al //gpio//  desde C con un programa sencillo que nos haga encender y apagar el led de la OPI.
  
 <code> <code>
Línea 339: Línea 394:
     sleep(1);     sleep(1);
 } }
 +
 </code> </code>
 +
 ==== WiringOP-Zero ==== ==== WiringOP-Zero ====
  
-Esta biblioteca imita a la //WiringPI// que se usa con //Raspberry Pi//.+Esta biblioteca imita a la //WiringPI//  que se usa con //Raspberry Pi//.
  
 Tenemos un fork que viene preparado para la Orange Pi Zero disponible aquí: Tenemos un fork que viene preparado para la Orange Pi Zero disponible aquí:
Línea 348: Línea 405:
 <code> <code>
 https://github.com/xpertsavenue/WiringOP-Zero https://github.com/xpertsavenue/WiringOP-Zero
 +
 </code> </code>
 +
 GPIO funciona completamente y al parecer aun no han testeado el i2c (tiene mala pinta) GPIO funciona completamente y al parecer aun no han testeado el i2c (tiene mala pinta)
  
Línea 358: Línea 417:
 chmod +x ./build chmod +x ./build
 sudo ./build sudo ./build
 +
 </code> </code>
 +
 Podemos comprobar que todo se ha instalado correctamente: Podemos comprobar que todo se ha instalado correctamente:
  
Línea 366: Línea 427:
  | H2+ | wPi |   Name   | Mode | V | Physical | V | Mode | Name     | wPi | H2+ |  | H2+ | wPi |   Name   | Mode | V | Physical | V | Mode | Name     | wPi | H2+ |
  +-----+-----+----------+------+---+----++----+---+------+----------+-----+-----+  +-----+-----+----------+------+---+----++----+---+------+----------+-----+-----+
-     |         3.3v |      |    1 || 2  |        | 5v           |     | +   |         3.3v |   |    1 || 2  |        | 5v         |     | 
-  12 |   8 |    SDA.0 | ALT5 | 0 |  3 || 4  |        | 5V           |     | +  12 |   8 |    SDA.0 | ALT5 | 0 |  3 || 4  |        | 5V         |     | 
-  11 |   9 |    SCL.0 | ALT5 | 0 |  5 || 6  |        | 0v           |     |+  11 |   9 |    SCL.0 | ALT5 | 0 |  5 || 6  |        | 0v         |     |
    6 |   7 |   GPIO.7 | ALT3 | 0 |  7 || 8  | 1 | OUT  | TxD3     | 15  | 198 |    6 |   7 |   GPIO.7 | ALT3 | 0 |  7 || 8  | 1 | OUT  | TxD3     | 15  | 198 |
-     |           0v |      |    9 || 10 | 0 | ALT5 | RxD3     | 16  | 199 |+   |           0v |   |    9 || 10 | 0 | ALT5 | RxD3     | 16  | 199 |
    1 |   0 |     RxD2 | ALT5 | 0 | 11 || 12 | 0 | ALT3 | GPIO.1   | 1   | 7   |    1 |   0 |     RxD2 | ALT5 | 0 | 11 || 12 | 0 | ALT3 | GPIO.1   | 1   | 7   |
-   0 |   2 |     TxD2 | ALT5 | 0 | 13 || 14 |        | 0v           |     |+   0 |   2 |     TxD2 | ALT5 | 0 | 13 || 14 |        | 0v         |     |
    3 |   3 |     CTS2 | ALT3 | 0 | 15 || 16 | 0 | ALT4 | GPIO.4   | 4   | 19  |    3 |   3 |     CTS2 | ALT3 | 0 | 15 || 16 | 0 | ALT4 | GPIO.4   | 4   | 19  |
-     |         3.3v |      |   | 17 || 18 | 0 | ALT4 | GPIO.5   | 5   | 18  | +   |         3.3v |   |   | 17 || 18 | 0 | ALT4 | GPIO.5   | 5   | 18  | 
-  15 |  12 |     MOSI | ALT5 | 0 | 19 || 20 |        | 0v           |     |+  15 |  12 |     MOSI | ALT5 | 0 | 19 || 20 |        | 0v         |     |
   16 |  13 |     MISO | ALT5 | 0 | 21 || 22 | 0 | ALT3 | RTS2     | 6   | 2   |   16 |  13 |     MISO | ALT5 | 0 | 21 || 22 | 0 | ALT3 | RTS2     | 6   | 2   |
   14 |  14 |     SCLK | ALT5 | 0 | 23 || 24 | 0 | ALT5 | CE0      | 10  | 13  |   14 |  14 |     SCLK | ALT5 | 0 | 23 || 24 | 0 | ALT5 | CE0      | 10  | 13  |
-     |           0v |      |   | 25 || 26 | 0 | ALT3 | GPIO.11  | 11  | 10  |+   |           0v |   |   | 25 || 26 | 0 | ALT3 | GPIO.11  | 11  | 10  |
  +-----+-----+----------+------+---+---LEDs---+---+------+----------+-----+-----+  +-----+-----+----------+------+---+---LEDs---+---+------+----------+-----+-----+
-  17 |  30 | STAT-LED |  OUT | 1 | 27 || 28 |        | PWR-LED     |     |+  17 |  30 | STAT-LED |  OUT | 1 | 27 || 28 |        | PWR-LED   |     |
  +-----+-----+----------+------+---+-----+----+---+------+----------+-----+-----+  +-----+-----+----------+------+---+-----+----+---+------+----------+-----+-----+
  | H2+ | wPi |   Name   | Mode | V | Physical | V | Mode | Name     | wPi | H2+ |  | H2+ | wPi |   Name   | Mode | V | Physical | V | Mode | Name     | wPi | H2+ |
  +-----+-----+----------+------+--Orange Pi Zero--+---+------+---------+-----+--+  +-----+-----+----------+------+--Orange Pi Zero--+---+------+---------+-----+--+
 +
 </code> </code>
-Instalamos las i2c-tools ''%%aptitude install i2c-tools%%'', después de eso ya funciona el comando ''%%gpio i2cd%%''.+ 
 +Instalamos las i2c-tools ''<nowiki>aptitude install i2c-tools</nowiki>'', después de eso ya funciona el comando ''<nowiki>gpio i2cd</nowiki>''.
  
 ==== WiringPI-Python-OP ==== ==== WiringPI-Python-OP ====
Línea 399: Línea 462:
 1.Download [WiringOP libary for the Orange Pi Zero] from here. 1.Download [WiringOP libary for the Orange Pi Zero] from here.
  
-https:%%//%%github.com/xpertsavenue/WiringOP-Zero+https:<nowiki>//</nowiki>github.com/xpertsavenue/WiringOP-Zero
  
 2.Download [[#wiringpi-python-op|WiringPi-Python-OP]] from here.(But not Install) 2.Download [[#wiringpi-python-op|WiringPi-Python-OP]] from here.(But not Install)
  
-https:%%//%%github.com/lanefu/WiringPi-Python-OP+https:<nowiki>//</nowiki>github.com/lanefu/WiringPi-Python-OP
  
 3.Replace base library 3.Replace base library
Línea 456: Línea 519:
  
 Podemos ver estadísticas de nuestra OPI con: Podemos ver estadísticas de nuestra OPI con:
- 
 <code> <code>
 +
 sudo armbianmonitor -m sudo armbianmonitor -m
  
Línea 477: Línea 540:
 21:05:25:  240MHz  0.05   2%   1%   0%   0%   0%   0%   37°C 21:05:25:  240MHz  0.05   2%   1%   0%   0%   0%   0%   37°C
 21:05:30:  240MHz  0.05   2%   1%   0%   0%   0%   0%   39°C 21:05:30:  240MHz  0.05   2%   1%   0%   0%   0%   0%   39°C
 +
 </code> </code>
 +
 También podemos instalar RPi-Monitor con el comando: También podemos instalar RPi-Monitor con el comando:
  
 <code> <code>
 sudo armbianmonitor -r sudo armbianmonitor -r
 +
 </code> </code>
-Una vez instalado podemos visitar desde nuestro navegador la dirección ip de nuestra OPI Zero //http:%%//%%opi-adress:8888// para ver las estadísticas. 
  
-{{:src/img/rpimonitor.png| Estadísticas en RPi-Monitor}}+Una vez instalado podemos visitar desde nuestro navegador la dirección ip de nuestra OPI Zero //http:<nowiki>//</nowiki>opi-adress:8888//  para ver las estadísticas. 
 + 
 +{{  :guias:rpimonitor.png  | Estadísticas en RPi-Monitor }}
  
 ¡Ojo! Las gráficas no se refrescan automáticamente hay que recargar la página. ¡Ojo! Las gráficas no se refrescan automáticamente hay que recargar la página.
  
 Para desinstalar el RPi-Monitor basta con: Para desinstalar el RPi-Monitor basta con:
- 
 <code> <code>
 +
 sudo aptitude uninstall rpimonitor sudo aptitude uninstall rpimonitor
 +
 </code> </code>
 +
 ====== Referencias ====== ====== Referencias ======
  
Línea 499: Línea 568:
   * [[http://www.orangepi.org/downloadresources/|Recursos oficiales]] aquí hay imágenes y los esquemáticos   * [[http://www.orangepi.org/downloadresources/|Recursos oficiales]] aquí hay imágenes y los esquemáticos
   * [[https://www.aliexpress.com/store/1553371?spm=2114.8147860.0.0.F1q43C|Tienda en Aliexpress]]   * [[https://www.aliexpress.com/store/1553371?spm=2114.8147860.0.0.F1q43C|Tienda en Aliexpress]]
-  * http://linux-sunxi.org/Bootable_SD_card +  * [[http://linux-sunxi.org/Bootable_SD_card|http://linux-sunxi.org/Bootable_SD_card]] 
-  * https://www.armbian.com/orange-pi-zero/ +  * [[https://www.armbian.com/orange-pi-zero/|https://www.armbian.com/orange-pi-zero/]] 
-  * https://docs.armbian.com/User-Guide_Getting-Started/ +  * [[https://docs.armbian.com/User-Guide_Getting-Started/|https://docs.armbian.com/User-Guide_Getting-Started/]] 
-  * https://docs.armbian.com/Hardware_Allwinner/+  * [[https://docs.armbian.com/Hardware_Allwinner/|https://docs.armbian.com/Hardware_Allwinner/]]
   * [[https://linux-sunxi.org/GPIO|GPIO]] Una explicación de como acceder al gpio desde terminal   * [[https://linux-sunxi.org/GPIO|GPIO]] Una explicación de como acceder al gpio desde terminal
   * [[https://linux-sunxi.org/Orange_Pi_Zero|Info variada]] Aquí tenemos el esquema de pines   * [[https://linux-sunxi.org/Orange_Pi_Zero|Info variada]] Aquí tenemos el esquema de pines
Línea 510: Línea 579:
   * [[https://www.amedeobaragiola.me/blog/2016/06/04/archlinux-arm-on-orange-pi-one/|ArchLinux ARM on Orange Pi]]   * [[https://www.amedeobaragiola.me/blog/2016/06/04/archlinux-arm-on-orange-pi-one/|ArchLinux ARM on Orange Pi]]
   * [[http://mirror.lakka.tv/nightly/|Lakka Nightly Builds]] Lakka is the official Linux distribution of RetroArch and the libretro ecosystem. Each game system is implemented as a libretro core, while the frontend RetroArch takes care of inputs and display. This clear separation ensures modularity and centralized configuration. Also nightly build for H3 is supported   * [[http://mirror.lakka.tv/nightly/|Lakka Nightly Builds]] Lakka is the official Linux distribution of RetroArch and the libretro ecosystem. Each game system is implemented as a libretro core, while the frontend RetroArch takes care of inputs and display. This clear separation ensures modularity and centralized configuration. Also nightly build for H3 is supported
 +
 +**
 +
  
guias/orangepizero.1517441706.txt.gz · Última modificación: 2021/04/16 20:38 (editor externo)