mirror of https://github.com/OpenIPC/wiki.git
amendments to old articles. adding a brief introduction on contributing.
parent
37a32f8dce
commit
dd09200406
|
@ -1,14 +1,15 @@
|
|||

|
||||
|
||||
## Supported devices
|
||||
Supported devices
|
||||
=================
|
||||
|
||||
Unfortunately, we cannot provide you a long list of devices that are undoubtedly
|
||||
compatible with our firmware. Camera manufacturers tend to change hardware
|
||||
design and swap components even within the same model line, without any notice.
|
||||
|
||||
Below, we listed some of the cameras we had in our possession, but again, there
|
||||
is no guarantee that if you buy one of those cameras today you won't end up with
|
||||
unsupported hardware on your hands.
|
||||
is no guarantee that if you'll buy one of those cameras today you won't end up
|
||||
with an unsupported hardware on your hands.
|
||||
|
||||
Somewhat working method to determine if your camera is supported by the recent
|
||||
version of our firmware is to open[^1] the camera case and take a look at the
|
||||
|
|
13
en/index.md
13
en/index.md
|
@ -1,6 +1,7 @@
|
|||

|
||||
![OpenIPC logo][logo]
|
||||
|
||||
# English version
|
||||
Wiki
|
||||
====
|
||||
|
||||
## Introduction
|
||||
* [About project](transfer-menu-index)
|
||||
|
@ -12,7 +13,7 @@
|
|||
* [firmware](https://openipc.org/firmware)
|
||||
* [ipctool](https://openipc.org/ipctool)
|
||||
* [telemetry](https://openipc.org/telemetry)
|
||||
* [Firmware Partitions Calculation by themactep](https://themactep.com/tools/firmware-partitions-calculation)
|
||||
* [Firmware Partitions Calculation](https://themactep.com/tools/firmware-partitions-calculation)
|
||||
|
||||
## Installation
|
||||
* [Goke based boards](transfer-install-goke)
|
||||
|
@ -56,5 +57,7 @@
|
|||
* [Notes from old sources](transfer-notes-for-resorting)
|
||||
|
||||
## Resources for recycling and integration
|
||||
* [https://github.com/OpenIPC/camerasrnd](https://github.com/OpenIPC/camerasrnd)
|
||||
* [https://openwrt.org/docs/techref/hardware/soc/soc.hisilicon.hi35xx](https://openwrt.org/docs/techref/hardware/soc/soc.hisilicon.hi35xx)
|
||||
* <https://github.com/OpenIPC/camerasrnd>
|
||||
* <https://openwrt.org/docs/techref/hardware/soc/soc.hisilicon.hi35xx>
|
||||
|
||||
[logo]: ../images/logo_openipc.png
|
||||
|
|
|
@ -1,6 +1,9 @@
|
|||
# How to setup HTTPS certificates on your camera
|
||||
How to install HTTPS certificates on your camera
|
||||
------------------------------------------------
|
||||
|
||||
Make sure your camera is accessible from the Internet and both 80 (HTTP) and 443 (HTTPS) ports are redirected on your router to the camera.
|
||||
Make sure your camera is accessible from the Internet on both port 80 (HTTP)
|
||||
and port 443 (HTTPS). You might need to set up port forwarding on your router
|
||||
for that.
|
||||
|
||||
Create an ACME account:
|
||||
|
||||
|
@ -8,17 +11,17 @@ Create an ACME account:
|
|||
$ uacme -y -v new
|
||||
```
|
||||
|
||||
then issue a certificate for your domain by doing
|
||||
Issue a certificate for your domain:
|
||||
|
||||
```console
|
||||
$ uacme -y -v -h /usr/share/uacme/uacme.sh -t EC issue www.your.domain.com
|
||||
```
|
||||
|
||||
If everything goes well uacme asks you to set up a challenge, for example
|
||||
If everything goes well, uacme will ask you to set up a challenge, e.g.:
|
||||
|
||||
```
|
||||
uacme: challenge=http-01 ident=www.your.domain.com token=kZjqYgAss_sl4XXDfFq-jeQV1_lqsE76v2BoCGegFk4
|
||||
key_auth=kZjqYgAss_sl4XXDfFq-jeQV1_lqsE76v2BoCGegFk4.2evcXalKLhAybRuxxE-HkSUihdzQ7ZDAKA9EZYrTXwU
|
||||
```
|
||||
|
||||
Then restart majestic and test access to https://www.your.domain.com
|
||||
Restart majestic and test access to https://www.your.domain.com/
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
## FFMPEG, RTSP and SRT examples
|
||||
FFMPEG, RTSP and SRT examples
|
||||
-----------------------------
|
||||
|
||||
```
|
||||
# Copy from file to file
|
||||
|
@ -35,4 +36,4 @@
|
|||
|
||||
# Receiver, untested
|
||||
ffplay 'srt://172.17.32.18:12345'
|
||||
```
|
||||
```
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
## Boot device with NFS
|
||||
Boot device with NFS
|
||||
--------------------
|
||||
|
||||
Example for HI3516EV200 device
|
||||
|
||||
|
@ -8,4 +9,4 @@ bootargsnfs=mem=${osmem:-32M} console=ttyAMA0,115200 panic=20 root=/dev/nfs root
|
|||
nfsboot=tftp 0x42000000 uImage;setenv setargs setenv bootargs ${bootargsnfs};run setargs;bootm 0x42000000
|
||||
|
||||
run nfsboot
|
||||
```
|
||||
```
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
## Interesting tricks
|
||||
Interesting tricks
|
||||
------------------
|
||||
|
||||
### Sharing output of a command via web
|
||||
|
||||
`<command> | nc seashells.io 1337`
|
||||
```
|
||||
<command> | nc seashells.io 1337
|
||||
```
|
||||
|
|
|
@ -1,5 +1,10 @@
|
|||
## Developers
|
||||
OpenIPC Developers
|
||||
==================
|
||||
|
||||
[](https://github.com/widgetii) [](https://github.com/dimerr)
|
||||
[](https://github.com/widgetii)
|
||||
|
||||
[](https://github.com/zigfisher) [](https://github.com/themactep)
|
||||
[](https://github.com/dimerr)
|
||||
|
||||
[](https://github.com/zigfisher)
|
||||
|
||||
[](https://github.com/themactep)
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
|
||||
## Run ipctool
|
||||
Run ipctool
|
||||
-----------
|
||||
|
||||
```
|
||||
root@ipcam:/# ipctool
|
||||
root@ipcam:/# ipctool
|
||||
---
|
||||
board:
|
||||
vendor: OpenIPC
|
||||
|
@ -41,7 +41,7 @@ ram:
|
|||
media: 32M
|
||||
firmware:
|
||||
kernel: "3.10.103+ (SMP Fri Apr 23 21:29:40 UTC 2021)"
|
||||
toolchain: gcc version 7.5.0 (Buildroot 2020.02-gb5b7c71)
|
||||
toolchain: gcc version 7.5.0 (Buildroot 2020.02-gb5b7c71)
|
||||
god-app: ipctool
|
||||
sensors:
|
||||
- vendor: SmartSens
|
||||
|
@ -50,5 +50,5 @@ sensors:
|
|||
bus: 0
|
||||
type: i2c
|
||||
addr: 0x30
|
||||
root@ipcam:/#
|
||||
```
|
||||
root@ipcam:/#
|
||||
```
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
## GPIO Settings
|
||||
GPIO Settings
|
||||
-------------
|
||||
|
||||
### Anjoy boards
|
||||
|
||||
|
@ -8,24 +9,22 @@
|
|||
| SSC337 | 78 | 79 | 61 | MC-F40, YM-J10D |
|
||||
| SSC337DE | 78 | 79 | 61 | MC500L8 |
|
||||
|
||||
-----
|
||||
|
||||
### CamHi/Xin boards
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | LIGHT | USB_ENA |
|
||||
|-------------|--------|--------|-------|---------|
|
||||
| Gk7205v200 | | | | 9 (invert value) |
|
||||
| Gk7205v300 | 10 | 11 | | 7 (invert value) |
|
||||
| Gk7205v200 | | | | 9i |
|
||||
| Gk7205v300 | 10 | 11 | | 7i |
|
||||
| | | | | |
|
||||
| Hi3516Cv100 |
|
||||
| Hi3516Cv200 |
|
||||
| Hi3516Cv300 |
|
||||
| Hi3516Ev200 | | | | 9 (invert value) |
|
||||
| Hi3516Ev300 | 10 | 11 | | 7 (invert value) |
|
||||
| Hi3518Ev200 | 1 | 2 | 48 |
|
||||
| Hi3518Ev300 | | | |
|
||||
| Hi3516Cv100 | | | | |
|
||||
| Hi3516Cv200 | | | | |
|
||||
| Hi3516Cv300 | | | | |
|
||||
| Hi3516Ev200 | | | | 9i |
|
||||
| Hi3516Ev300 | 10 | 11 | | 7i |
|
||||
| Hi3518Ev200 | 1 | 2 | 48 | |
|
||||
| Hi3518Ev300 | | | | |
|
||||
|
||||
-----
|
||||
_i - inverted value_
|
||||
|
||||
### Herospeed/Longse/Cantonk boards
|
||||
|
||||
|
@ -40,16 +39,12 @@
|
|||
| Hi3516Ev200 |
|
||||
| Hi3516Av300 | 5 | 6 |
|
||||
|
||||
-----
|
||||
|
||||
### Jabsco boards
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | IRSTATUS |
|
||||
|-------------|--------|--------|----------|
|
||||
| Hi3516Ev200 | 52 | 53 | 9 |
|
||||
|
||||
-----
|
||||
|
||||
### JVT boards
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | LIGHT |
|
||||
|
@ -60,51 +55,41 @@
|
|||
| Hi3516Ev200 |
|
||||
| Hi3518Ev200 | 64 | 65 | 47 |
|
||||
|
||||
-----
|
||||
|
||||
### JUAN boards (Sannce)
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | IRSTATUS | TESTED BOARDS | DEVICE ID |
|
||||
|-------------|--------|--------|---------------|---------------|-----------|
|
||||
| Hi3518Ev200 | 65 | 64 | 62 (inverted) | 18EV200_V205P | N18EV2W |
|
||||
|
||||
------
|
||||
|
||||
### Tiandy boards
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | IRSTATUS | IRCTL | RESET |
|
||||
|-------------|--------|--------|----------|-------|-------|
|
||||
| SSC335 | 78 | 79 | --- | 37 | |
|
||||
|
||||
-----
|
||||
|
||||
### Uniview boards
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | RESET | DEVICE ID |
|
||||
|-------------|--------|--------|-------|--------------------------|
|
||||
| Hi3516Ev300 | 63 | 67 | 64 | Rostelecom IPC8232SWC-WE |
|
||||
|
||||
-----
|
||||
|
||||
### XM boards
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | IRSTATUS | IRCTL | ALM_IN | ALM_OUT | ETH_ACT | ETH_STA | RESET | USB_ENA |
|
||||
|-------------|--------|--------|----------|-------|--------|---------|---------|---------|-------|---------|
|
||||
| GK7205V200 | 8 | 9 | 15 | 16 | 4 и 53 | 55 | 14 | 12 | 0 |
|
||||
| GK7205V300 | 10 | 11 | 66 | 52 | 4 | | 30 | 31 | | |
|
||||
| | | | | | | | | | | |
|
||||
| Hi3516Cv100 |
|
||||
| Hi3516Dv100* | 14 | 15
|
||||
| Hi3516Cv200 |
|
||||
| Hi3516Cv300 | 53 | 54 | 64 | 66 | 55 | 1 | | | 2 | 63 |
|
||||
| Hi3516Ev200 | 8 | 9 | 15 | 16 | 4 и 53 | 55 | 14 | 12 | 0 |
|
||||
| Hi3516Ev300 | 10 | 11 | 66 | 52 | 4 и 67 | 65 | 30 | 31 | 0 |
|
||||
| Hi3518Ev200 | 33 | 34 | | | 61 | 35 |
|
||||
| Processor | IRCUT1 | IRCUT2 | IRSTATUS | IRCTL | ALM_IN | ALM_OUT | ETH_ACT | ETH_STA | RESET | USB_ENA |
|
||||
|--------------|--------|--------|----------|-------|--------|---------|---------|---------|-------|---------|
|
||||
| GK7205V200 | 8 | 9 | 15 | 16 | 4, 53 | 55 | 14 | 12 | 0 | |
|
||||
| GK7205V300 | 10 | 11 | 66 | 52 | 4 | | 30 | 31 | | |
|
||||
| | | | | | | | | | | |
|
||||
| Hi3516Cv100 | | | | | | | | | | |
|
||||
| Hi3516Dv100* | 14 | 15 | | | | | | | | |
|
||||
| Hi3516Cv200 | | | | | | | | | | |
|
||||
| Hi3516Cv300 | 53 | 54 | 64 | 66 | 55 | 1 | | | 2 | 63 |
|
||||
| Hi3516Ev200 | 8 | 9 | 15 | 16 | 4, 53 | 55 | 14 | 12 | 0 | |
|
||||
| Hi3516Ev300 | 10 | 11 | 66 | 52 | 4, 67 | 65 | 30 | 31 | 0 | |
|
||||
| Hi3518Ev200 | 33 | 34 | | | 61 | 35 | | | | |
|
||||
|
||||
* HI3516D_N81820, 00014914 firmware
|
||||
|
||||
-----
|
||||
|
||||
### Zenotech/Videopark
|
||||
|
||||
| Processor | IRCUT1 | IRCUT2 | IRLED | DEVICE ID |
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
## Overview
|
||||
Overview
|
||||
--------
|
||||
|
||||
Each SoC manufacturer has its own software to adjust picture quality:
|
||||
|
||||
|
@ -44,8 +45,15 @@ pqtools:Waiting for connection from client!
|
|||
|
||||
#### Run client software on Windows
|
||||
|
||||
* [Download](https://ssd.mathworks.com/supportfiles/MCR_Runtime/R2012a/MCR_R2012a_win32_installer.exe) and install MATLAB Compiler Runtime.
|
||||
Download and install [MATLAB Compiler Runtime][mcr].
|
||||
|
||||
* [Download PQTools](https://drive.google.com/file/d/1c4XZRbJKXjMBwfMJaLl5jUPcVqMbO936/view?usp=sharing) and extract a zip archive somewhere on your desktop. Launch `HiPQTools.exe`, select `Hi3516EV200_V1.0.1.2`, type IP address of your camera and click `OK`
|
||||
Download [PQTools][pqt] and extract a zip archive somewhere on your PC.
|
||||
|
||||
Use [the manual](https://drive.google.com/file/d/1mY1lXMZVNz2Ia5CPvTF-K-907eIioSYU/view?usp=sharing) as a reference.
|
||||
Launch `HiPQTools.exe`, select `Hi3516EV200_V1.0.1.2`, type IP address of your
|
||||
camera and click `OK`.
|
||||
|
||||
Use [this manual][man] as a reference.
|
||||
|
||||
[mcr]: https://ssd.mathworks.com/supportfiles/MCR_Runtime/R2012a/MCR_R2012a_win32_installer.exe
|
||||
[pqt]: https://drive.google.com/file/d/1c4XZRbJKXjMBwfMJaLl5jUPcVqMbO936/view?usp=sharing
|
||||
[man]: https://drive.google.com/file/d/1mY1lXMZVNz2Ia5CPvTF-K-907eIioSYU/view?usp=sharing
|
||||
|
|
|
@ -1,30 +1,27 @@
|
|||
## For XM boards ONLY with SoC GK7202V300, GK7205V200, GK7205V300 !!!
|
||||
For XM boards with SoC GK7202V300, GK7205V200, GK7205V300 ONLY!!!
|
||||
-----------------------------------------------------------------
|
||||
|
||||
### Supported sensors
|
||||
|
||||
Please read this [info](https://github.com/OpenIPC/openipc-2.1/wiki/supported_devices).
|
||||
|
||||
-----
|
||||
Please look up your sensor in [the list of supported devices][1].
|
||||
|
||||
### Initial device firmware updates
|
||||
|
||||
```
|
||||
#
|
||||
|
||||
setenv bootargs 'mem=${osmem:-32M} console=ttyAMA0,115200 panic=20 root=/dev/mtdblock3 rootfstype=squashfs init=/init mtdparts=sfc:256k(boot),64k(env),2048k(kernel),5120k(rootfs),-(rootfs_data)'
|
||||
setenv bootcmd 'setenv setargs setenv bootargs ${bootargs}; run setargs; sf probe 0; sf read 0x42000000 0x50000 0x200000; bootm 0x42000000'
|
||||
setenv uk 'mw.b 0x42000000 ff 1000000; tftp 0x42000000 uImage.${soc} && sf probe 0; sf erase 0x50000 0x200000; sf write 0x42000000 0x50000 ${filesize}'
|
||||
setenv ur 'mw.b 0x42000000 ff 1000000; tftp 0x42000000 rootfs.squashfs.${soc} && sf probe 0; sf erase 0x250000 0x500000; sf write 0x42000000 0x250000 ${filesize}'
|
||||
saveenv
|
||||
|
||||
setenv soc gk7xxxxxxx <= Set you SoC as gk7202v300 or gk7205v200 or gk7205v300
|
||||
setenv soc gk7xxxxxxx # Set your SoC. gk7202v300, gk7205v200, or gk7205v300.
|
||||
setenv osmem 32M
|
||||
setenv totalmem 64M <= 64M for gk7202v300 or gk7205v200 and 128M for gk7205v300
|
||||
setenv totalmem 64M # 64M for gk7202v300, gk7205v200, 128M for gk7205v300.
|
||||
setenv ipaddr 192.168.1.10
|
||||
setenv serverip 192.168.1.254 <= Set you TFTP server IP
|
||||
setenv serverip 192.168.1.254 # Your TFTP server IP address.
|
||||
saveenv
|
||||
|
||||
run uk; run ur; reset <= Flash kernel, rootfs and reboot device
|
||||
run uk; run ur; reset # Flash kernel, rootfs and reboot device
|
||||
```
|
||||
|
||||
### Follow-up quick updates
|
||||
|
@ -36,20 +33,27 @@ run uk; run ur; reset
|
|||
### A trick for GK7205V300+IMX335 users
|
||||
|
||||
```
|
||||
echo -e "!/bin/sh\n\ndevmem 0x120100f0 32 0x19\n" >/etc/init.d/S96trick; chmod +x /etc/init.d/S96trick
|
||||
echo -e "!/bin/sh\n\ndevmem 0x120100f0 32 0x19\n" >/etc/init.d/S96trick
|
||||
chmod +x /etc/init.d/S96trick
|
||||
```
|
||||
Alternative way [here](https://github.com/OpenIPC/firmware/pull/117/files)
|
||||
|
||||
-----
|
||||
Alternative way [here](https://github.com/OpenIPC/firmware/pull/117/files)
|
||||
|
||||
### Danger zone
|
||||
|
||||
You have the option to always update the bootloader.
|
||||
You always have an option to update the bootloader. However, you need to
|
||||
understand what you do.
|
||||
|
||||
However, you should have the knowledge and replace the bootloader [file](https://github.com/OpenIPC/firmware/releases/tag/latest) name.
|
||||
NB! Replace bootloader filename with the one matching your SoC.
|
||||
Full list is [here](https://github.com/OpenIPC/firmware/releases/tag/latest).
|
||||
|
||||
```
|
||||
mw.b 0x42000000 ff 1000000; tftp 0x42000000 u-boot-gk7xxxxxxxx-beta.bin; sf probe 0
|
||||
sf erase 0x0 0x50000; sf write 0x42000000 0x0 ${filesize}
|
||||
mw.b 0x42000000 ff 1000000
|
||||
tftp 0x42000000 u-boot-gk7xxxxxxxx-beta.bin
|
||||
sf probe 0
|
||||
sf erase 0x0 0x50000
|
||||
sf write 0x42000000 0x0 ${filesize}
|
||||
reset
|
||||
```
|
||||
|
||||
[1]: https://github.com/OpenIPC/firmware/wiki/supported_devices
|
||||
|
|
|
@ -1,30 +1,27 @@
|
|||
## For XM boards ONLY with SoC Hi35{16Ev200,16Ev300,18Ev300} !!!
|
||||
For XM boards with Hi35{16Ev200,16Ev300,18Ev300} SoC ONLY!!!
|
||||
------------------------------------------------------------
|
||||
|
||||
### Supported sensors
|
||||
|
||||
Please read this [info](https://github.com/OpenIPC/openipc-2.1/wiki/supported_devices).
|
||||
|
||||
-----
|
||||
Please look up your sensor in [the list of supported devices][1].
|
||||
|
||||
### Initial device firmware updates
|
||||
|
||||
```
|
||||
#
|
||||
|
||||
setenv bootargs 'mem=${osmem:-32M} console=ttyAMA0,115200 panic=20 root=/dev/mtdblock3 rootfstype=squashfs init=/init mtdparts=hi_sfc:256k(boot),64k(env),2048k(kernel),5120k(rootfs),-(rootfs_data)'
|
||||
setenv bootcmd 'setenv setargs setenv bootargs ${bootargs}; run setargs; sf probe 0; sf read 0x42000000 0x50000 0x200000; bootm 0x42000000'
|
||||
setenv uk 'mw.b 0x42000000 ff 1000000; tftp 0x42000000 uImage.${soc} && sf probe 0; sf erase 0x50000 0x200000; sf write 0x42000000 0x50000 ${filesize}'
|
||||
setenv ur 'mw.b 0x42000000 ff 1000000; tftp 0x42000000 rootfs.squashfs.${soc} && sf probe 0; sf erase 0x250000 0x500000; sf write 0x42000000 0x250000 ${filesize}'
|
||||
saveenv
|
||||
|
||||
setenv soc hi351xxxxxxx <= Set you SoC as hi3516ev200 or hi3516ev300 or hi3518ev300
|
||||
setenv soc hi351xxxxxxx # Set your SoC. hi3516ev200, hi3516ev300, or hi3518ev300.
|
||||
setenv osmem 32M
|
||||
setenv totalmem 64M <= 64M for hi3516ev200 or hi3518ev300 and 128M for hi3516ev300
|
||||
setenv totalmem 64M # 64M for hi3516ev200, hi3518ev300, 128M for hi3516ev300.
|
||||
setenv ipaddr 192.168.1.10
|
||||
setenv serverip 192.168.1.254 <= Set you TFTP server IP
|
||||
setenv serverip 192.168.1.254 # Your TFTP server IP address.
|
||||
saveenv
|
||||
|
||||
run uk; run ur; reset <= Flash kernel, rootfs and reboot device
|
||||
run uk; run ur; reset # Flash kernel, rootfs and reboot device
|
||||
```
|
||||
|
||||
### Follow-up quick updates
|
||||
|
@ -33,34 +30,35 @@ run uk; run ur; reset <= Flash kernel, rootfs and reboot device
|
|||
run uk; run ur; reset
|
||||
```
|
||||
|
||||
-----
|
||||
|
||||
### Executing a command after the first run
|
||||
|
||||
If you have Hi3516Ev300 based board run this command:
|
||||
|
||||
For a Hi3516Ev300 board:
|
||||
```
|
||||
set_allocator cma
|
||||
firstboot
|
||||
```
|
||||
|
||||
If you have Hi3516Ev200 or Hi3518Ev300 based board run this command:
|
||||
|
||||
For a Hi3516Ev200 or Hi3518Ev300 board:
|
||||
```
|
||||
set_allocator hisi
|
||||
firstboot
|
||||
```
|
||||
|
||||
-----
|
||||
|
||||
### Danger zone
|
||||
|
||||
You have the option to always update the bootloader.
|
||||
You always have an option to update the bootloader. However, you need to
|
||||
understand what you do.
|
||||
|
||||
However, you should have the knowledge and replace the bootloader [file](https://github.com/OpenIPC/firmware/releases/tag/latest) name.
|
||||
NB! Replace bootloader filename with the one matching your SoC.
|
||||
Full list is [here](https://github.com/OpenIPC/firmware/releases/tag/latest).
|
||||
|
||||
```
|
||||
mw.b 0x42000000 ff 1000000; tftp 0x42000000 u-boot-hi3516xxxxx-beta.bin; sf probe 0
|
||||
sf erase 0x0 0x50000; sf write 0x42000000 0x0 ${filesize}
|
||||
mw.b 0x42000000 ff 1000000
|
||||
tftp 0x42000000 u-boot-hi3516xxxxx-beta.bin
|
||||
sf probe 0
|
||||
sf erase 0x0 0x50000
|
||||
sf write 0x42000000 0x0 ${filesize}
|
||||
reset
|
||||
```
|
||||
|
||||
[1]: https://github.com/OpenIPC/firmware/wiki/supported_devices
|
||||
|
|
|
@ -1,11 +1,12 @@
|
|||
## For XM vendor boards ONLY with SoC NT98562 and NT98566 !!!
|
||||
For XM vendor boards with NT98562 and NT98566 SoC ONLY!!!
|
||||
---------------------------------------------------------
|
||||
|
||||
### Initial device firmware update
|
||||
|
||||
**This section will be completed at the end of the research**
|
||||
|
||||
```
|
||||
run uk; run ur; reset <= Flash kernel, rootfs and reboot device
|
||||
run uk; run ur; reset # Flash kernel, rootfs and reboot device
|
||||
```
|
||||
|
||||
### Follow-up quick updates
|
||||
|
@ -16,14 +17,14 @@ run uk; run ur; reset
|
|||
|
||||
### Notes
|
||||
|
||||
After the first flash firmware of the device, please run the **firstboot** command to format the jffs2 partition of the settings.
|
||||
|
||||
-----
|
||||
After you have finished flashing new firmware, please run `firstboot` command
|
||||
to format jffs2 partition used to store settings.
|
||||
|
||||
### Known issues
|
||||
|
||||
Change memory address for some tests
|
||||
Change memory address for some tests.
|
||||
|
||||
```
|
||||
setenv bootcmd 'setenv setargs setenv bootargs ${bootargs}; run setargs; sf probe 0; sf read 0x03100000 0x50000 0x200000; nvt_boot'; saveenv
|
||||
```
|
||||
setenv bootcmd 'setenv setargs setenv bootargs ${bootargs};run setargs;sf probe 0;sf read 0x03100000 0x50000 0x200000;nvt_boot'
|
||||
saveenv
|
||||
```
|
||||
|
|
|
@ -1,25 +1,24 @@
|
|||
## For Anjoy/Brovotech/Gospell/Uniview boards ONLY with SoC SSC335 !!!
|
||||
For Anjoy/Brovotech/Gospell/Uniview boards with SSC335 Soc ONLY!!!
|
||||
------------------------------------------------------------------
|
||||
|
||||
### Initial device firmware update
|
||||
|
||||
```
|
||||
#
|
||||
|
||||
setenv bootargs 'mem=${osmem:-32M} console=ttyS0,115200 panic=20 root=/dev/mtdblock3 rootfstype=squashfs init=/init LX_MEM=0x3fe0000 mma_heap=mma_heap_name0,miu=0,sz=0x1C00000 mma_memblock_remove=1 mtdparts=NOR_FLASH:256k(boot),64k(tech),2048k(kernel),5120k(rootfs),-(rootfs_data)'
|
||||
setenv bootcmd 'setenv setargs setenv bootargs ${bootargs}; run setargs; sf probe 0; sf read 0x21000000 0x50000 0x200000; bootm 0x21000000'
|
||||
setenv uk 'mw.b 0x21000000 ff 1000000; tftpboot 0x21000000 uImage.${soc}; sf probe 0; sf erase 0x50000 0x200000; sf write 0x21000000 0x50000 ${filesize}'
|
||||
setenv ur 'mw.b 0x21000000 ff 1000000; tftpboot 0x21000000 rootfs.squashfs.${soc}; sf probe 0; sf erase 0x250000 0x500000; sf write 0x21000000 0x250000 ${filesize}'
|
||||
saveenv
|
||||
|
||||
setenv soc ssc335 <= Set you SoC - ssc325, ssc335, ssc337
|
||||
setenv sensor none <= Set you sensor - gc2053, imx307, sc3335
|
||||
setenv soc ssc335 # Your SoC. ssc325, ssc335, or ssc337.
|
||||
setenv sensor none # Your sensor. gc2053, imx307, or sc3335.
|
||||
setenv osmem 32M
|
||||
setenv totalmem 64M <= 64M for ssc335
|
||||
setenv ipaddr 192.168.1.10
|
||||
setenv serverip 192.168.1.254 <= Set you TFTP server IP
|
||||
setenv totalmem 64M # 64M for ssc335.
|
||||
setenv ipaddr 192.168.1.10 # Your camera IP address.
|
||||
setenv serverip 192.168.1.254 # Your TFTP server IP address.
|
||||
saveenv
|
||||
|
||||
run uk; run ur; reset <= Flash kernel, rootfs and reboot device
|
||||
run uk; run ur; reset # Flash kernel, rootfs and reboot device
|
||||
```
|
||||
|
||||
### Follow-up quick updates
|
||||
|
@ -30,20 +29,19 @@ run uk; run ur; reset
|
|||
|
||||
### Notes
|
||||
|
||||
After the first flash firmware of the device, please run the **firstboot** command to format the jffs2 partition of the settings.
|
||||
After you have finished flashing new firmware, please run `firstboot` command
|
||||
to format jffs2 partition used to store settings.
|
||||
|
||||
|
||||
### Other info
|
||||
|
||||
**Human-readable processor names for SigmaStar devices, the data is obtained on the original firmware**
|
||||
|
||||
| Engraving |/sys/class/mstar/msys/CHIP_ID|/sys/devices/soc0/soc_id |/sys/devices/soc0/machine |
|
||||
|--- |--- |--- |--- |
|
||||
| SSC325DE | not found | 239 | INFINITY6 SSC009B-S01A QFN128 |
|
||||
| | | | |
|
||||
| SSC335 | 0xF2 | 242 | INFINITY6B0 SSC009A-S01A QFN88 |
|
||||
| SSC337 | 0xF2 | 242 | INFINITY6B0 SSC009A-S01A QFN88 |
|
||||
| SSC337DE | 0xF2 | 242 | INFINITY6B0 SSC009B-S01A QFN128 |
|
||||
|
||||
|
||||
#### Human-readable processor names for SigmaStar devices.
|
||||
The data is obtained from the original firmware.
|
||||
|
||||
| Engraving | /sys/class/mstar/msys/CHIP_ID | /sys/devices/soc0/soc_id | /sys/devices/soc0/machine |
|
||||
|-----------|-------------------------------|--------------------------|----------------------------------|
|
||||
| SSC325DE | not found | 239 | INFINITY6 SSC009B-S01A QFN128 |
|
||||
| | | | |
|
||||
| SSC335 | 0xF2 | 242 | INFINITY6B0 SSC009A-S01A QFN88 |
|
||||
| SSC337 | 0xF2 | 242 | INFINITY6B0 SSC009A-S01A QFN88 |
|
||||
| SSC337DE | 0xF2 | 242 | INFINITY6B0 SSC009B-S01A QFN128 |
|
||||
|
|
|
@ -1,10 +1,9 @@
|
|||
## For XM vendor boards ONLY with SoC XM510 !!!
|
||||
For XM vendor boards with XM510 SoC ONLY!!!
|
||||
-------------------------------------------
|
||||
|
||||
### Initial device firmware update
|
||||
|
||||
```
|
||||
#
|
||||
|
||||
setenv bootargs 'mem=18M console=ttyAMA0,115200 panic=20 root=/dev/mtdblock3 rootfstype=squashfs init=/init mtdparts=xm_sfc:256k(boot),64k(env),2048k(kernel),5120k(rootfs),-(rootfs_data)'
|
||||
setenv bootcmd 'sf probe 0; sf read 0x80007fc0 0x50000 0x200000; bootm 0x80007fc0'
|
||||
setenv uk1 'mw.b 0x80007fc0 ff 1000000; tftp 0x80007fc0 uImage.${soc}'
|
||||
|
@ -15,14 +14,14 @@ setenv ur2 'sf probe 0; sf erase 0x250000 0x500000; sf write 0x80007fc 0x250000
|
|||
setenv ur 'run ur1 ; run ur2'
|
||||
saveenv
|
||||
|
||||
setenv soc xm510 <= Set you SoC as xm510
|
||||
setenv osmem 18M <= xm510 has 32M ram only
|
||||
setenv totalmem 32M <= xm510 has 32M ram only
|
||||
setenv ipaddr 192.168.1.10 <= Set your camera IP address
|
||||
setenv serverip 192.168.1.254 <= Set your TFTP server IP
|
||||
setenv soc xm510 # Your SoC. xm510.
|
||||
setenv osmem 18M # 18M for xm510.
|
||||
setenv totalmem 32M # 32M for xm510.
|
||||
setenv ipaddr 192.168.1.10 # Your camera IP address.
|
||||
setenv serverip 192.168.1.254 # Your TFTP server IP address.
|
||||
saveenv
|
||||
|
||||
run uk; run ur; reset <= Flash kernel, rootfs and reboot device
|
||||
run uk; run ur; reset # Flash kernel, rootfs and reboot device
|
||||
```
|
||||
|
||||
### Follow-up quick updates
|
||||
|
@ -33,9 +32,8 @@ run uk; run ur; reset
|
|||
|
||||
### Notes
|
||||
|
||||
After the first flash firmware of the device, please run the **firstboot** command to format the jffs2 partition of the settings.
|
||||
|
||||
-----
|
||||
After you have finished flashing new firmware, please run `firstboot` command
|
||||
to format jffs2 partition used to store settings.
|
||||
|
||||
### Load kernel modules
|
||||
|
||||
|
@ -46,5 +44,7 @@ cd /lib/modules/3.0.101\+/xiongmai/
|
|||
|
||||
### Known issues
|
||||
|
||||
For Linux kernel built with original toolchain (gcc 4.9.2) everything works as expected, but with the same config with OpenIPC toolchain (gcc 7.5.0) pty (and only pty) doesn’t work, weird and also ran out of ideas how to fix it
|
||||
https://t.me/openipc/20225
|
||||
For Linux kernel built with the original toolchain (gcc 4.9.2) everything works
|
||||
as expected, but for the same .config built with OpenIPC toolchain (gcc 7.5.0)
|
||||
pty (and only pty) doesn't work. That is weird, and we also ran out of ideas how
|
||||
to fix that. https://t.me/openipc/20225
|
||||
|
|
|
@ -1,24 +1,23 @@
|
|||
## For XM vendor boards ONLY with SoC XM530/XM550 !!!
|
||||
For XM vendor boards with XM530/XM550 SoC ONLY !!!
|
||||
--------------------------------------------------
|
||||
|
||||
### Initial device firmware update
|
||||
|
||||
```
|
||||
#
|
||||
|
||||
setenv bootargs 'mem=35M console=ttyAMA0,115200 panic=20 root=/dev/mtdblock3 rootfstype=squashfs init=/init mtdparts=xm_sfc:256k(boot),64k(env),2048k(kernel),5120k(rootfs),-(rootfs_data)'
|
||||
setenv bootcmd 'sf probe 0; sf read 0x80007fc0 0x50000 0x200000; bootm 0x80007fc0'
|
||||
setenv uk 'mw.b 0x80007fc0 ff 1000000; tftp 0x80007fc0 uImage.${soc} && sf probe 0; sf erase 0x50000 0x200000; sf write 0x80007fc0 0x50000 ${filesize}'
|
||||
setenv ur 'mw.b 0x80007fc0 ff 1000000; tftp 0x80007fc0 rootfs.squashfs.${soc} && sf probe 0; sf erase 0x250000 0x500000; sf write 0x80007fc0 0x250000 ${filesize}'
|
||||
saveenv
|
||||
|
||||
setenv soc xm530 <= Set you SoC as xm530 for xm530 and xm550
|
||||
setenv osmem 35M <= 35M for xm530 and 64M for xm550
|
||||
setenv totalmem 64M <= 64M for xm530 and 128M for xm550
|
||||
setenv ipaddr 192.168.1.10
|
||||
setenv serverip 192.168.1.254 <= Set you TFTP server IP
|
||||
setenv soc xm530 # Your SoC. xm530 for both xm530 and xm550.
|
||||
setenv osmem 35M # 35M for xm530, 64M for xm550.
|
||||
setenv totalmem 64M # 64M for xm530, 128M for xm550.
|
||||
setenv ipaddr 192.168.1.10 # Your camera IP address.
|
||||
setenv serverip 192.168.1.254 # Your TFTP server IP address.
|
||||
saveenv
|
||||
|
||||
run uk; run ur; reset <= Flash kernel, rootfs and reboot device
|
||||
run uk; run ur; reset # Flash kernel, rootfs and reboot device
|
||||
```
|
||||
|
||||
### Follow-up quick updates
|
||||
|
@ -29,9 +28,8 @@ run uk; run ur; reset
|
|||
|
||||
### Notes
|
||||
|
||||
After the first flash firmware of the device, please run the **firstboot** command to format the jffs2 partition of the settings.
|
||||
|
||||
-----
|
||||
After you have finished flashing new firmware, please run `firstboot` command
|
||||
to format jffs2 partition used to store settings.
|
||||
|
||||
### Load kernel modules
|
||||
|
||||
|
@ -40,4 +38,4 @@ cd /lib/modules/3.10.103\+/xiongmai/
|
|||
/usr/bin/load_xiongmai
|
||||
```
|
||||
|
||||
P.S. At the moment, video support is in development
|
||||
NB! As of today, video support is still in development.
|
||||
|
|
|
@ -1,73 +1,116 @@
|
|||
## Preamble
|
||||
Majestic streamer
|
||||
-----------------
|
||||
|
||||
Majestic is a video streaming application, the heart of our firmware (in relation to camera/video surveillance functionality). It's configurable via file /etc/majestic.yaml and by default has many features/services enabled. Unneeded options can be turned off for better security and performance.
|
||||
### Preamble
|
||||
|
||||
## Camera related URLs in firmware
|
||||
Majestic is a video streaming application, the heart of our firmware (in
|
||||
relation to camera/video surveillance functionality). Majestic is configurable
|
||||
via /etc/majestic.yaml file, and has many features/services enabled by default.
|
||||
Unneeded options can be switched off for better security and performance.
|
||||
|
||||
With firmware running, you can access the camera using URLs below (192.168.1.10 is an example of camera IP address):
|
||||
### Camera related URLs in firmware
|
||||
|
||||
### Live video
|
||||
With firmware running, you can access the camera using URLs below
|
||||
(192.168.1.10 is an example of camera IP address):
|
||||
|
||||
* http://192.168.1.10/ - [HLS](https://en.wikipedia.org/wiki/HTTP_Live_Streaming) live streaming is web browser
|
||||
* http://192.168.1.10/mjpeg.html - [MJPEG](https://en.wikipedia.org/wiki/Motion_JPEG) & [MP3](https://en.wikipedia.org/wiki/MP3) streaming in web browser
|
||||
* http://192.168.1.10/video.mp4 - [MP4](https://en.wikipedia.org/wiki/MPEG-4_Part_14) video (Fragmented MP4)
|
||||
* rtsp://192.168.1.10 - Main channel of [RTSP](https://en.wikipedia.org/wiki/RTSP) stream (section "video0:" in config )
|
||||
* rtsp://192.168.1.10/stream=1 - Second channel RTSP streamer (section "video1:" in config )
|
||||
#### Live video
|
||||
|
||||
### Still image
|
||||
* http://192.168.1.10/ - [HLS][hls] live streaming is web browser.
|
||||
* http://192.168.1.10/mjpeg.html - [MJPEG][mjpeg] & [MP3][mp3] streaming in web browser.
|
||||
* http://192.168.1.10/video.mp4 - [MP4][mp4] video (Fragmented MP4).
|
||||
* rtsp://192.168.1.10 - Main channel of [RTSP][rtsp] streamer (video0 in config).
|
||||
* rtsp://192.168.1.10/stream=1 - Second channel of RTSP streamer (video1 in config)
|
||||
|
||||
* http://192.168.1.10/image.jpg - image snapshot in [JPEG](https://en.wikipedia.org/wiki/JPEG) format
|
||||
#### Still image
|
||||
|
||||
Supports specific image parameters in URL like `/image.jpg?width=640&height=360&qfactor=73&color2gray=1`:
|
||||
1) `width` and `height` - size of picture to scale original image
|
||||
2) `qfactor` - JPEG quality factor between 1 and 99
|
||||
3) `color2gray` - force to grayscale convertion
|
||||
4) `crop` - crop image in format `16x16x320x320`, where first numbers are left and top image coordinates and others are image width and height
|
||||
* http://192.168.1.10/image.jpg - image snapshot in [JPEG][jpeg] format.
|
||||
Supports specific image parameters in URL, e.g. `/image.jpg?width=640&height=360&qfactor=73&color2gray=1`:
|
||||
-`width` and `height` - size of picture to scale original image.
|
||||
- `qfactor` - JPEG quality factor between 1 and 99.
|
||||
- `color2gray` - force to grayscale conversion.
|
||||
- `crop` - crop image in format `16x16x320x320`,
|
||||
where first numbers are left and top image coordinates
|
||||
and others are image width and height.
|
||||
* http://192.168.1.10/image.heif - image snapshot in [HEIF][heif] format,
|
||||
use `stream` parameter to specify channel (the same approach as for RTSP channels)
|
||||
* http://192.168.1.10/image.yuv - image snapshot in [YUV420][yuv] format.
|
||||
* http://192.168.1.10/image.dng - [raw image][raw] snapshot from the sensor in
|
||||
[Adobe DNG][dng] format (only for v>=2 HiSilicon processors).
|
||||
|
||||
* http://192.168.1.10/image.heif - image snapshot in [HEIF](https://en.wikipedia.org/wiki/High_Efficiency_Image_File_Format) format, use `stream` parameter to specify channel (the same approach as for RTSP channels)
|
||||
* http://192.168.1.10/image.yuv - image snapshot in [YUV420](https://en.wikipedia.org/wiki/YUV) format
|
||||
##### Tips:
|
||||
|
||||
Use `convert -verbose -sampling-factor 4:2:0 -size 1920x1080 -depth 8 image.yuv image.png` to convert to usable format, where `1920x1080` is picture resolution from video0 and `.png` is a target format.
|
||||
|
||||
* http://192.168.1.10/image.dng - [raw image](https://en.wikipedia.org/wiki/Raw_image_format) snapshot from sensor in [Adobe DNG](https://en.wikipedia.org/wiki/Digital_Negative) format (only for v>=2 HiSilicon processors)
|
||||
To convert YUV image to a more common image format, use `convert` command from
|
||||
ImageMagick software. Run it like this:
|
||||
```
|
||||
convert -verbose -sampling-factor 4:2:0 -size 1920x1080 -depth 8 image.yuv image.png
|
||||
```
|
||||
where `1920x1080` is the picture resolution of video0, and `.png` is the target
|
||||
image format.
|
||||
|
||||
### Audio input
|
||||
|
||||
* http://192.168.1.10/audio.opus - [Opus](https://en.wikipedia.org/wiki/Opus_(audio_format)) audio stream
|
||||
* http://192.168.1.10/audio.m4a - [AAC](https://en.wikipedia.org/wiki/Advanced_Audio_Coding) audio stream
|
||||
* http://192.168.1.10/audio.mp3 - [MP3](https://en.wikipedia.org/wiki/MP3) audio stream
|
||||
* http://192.168.1.10/audio.pcm - Raw [PCM](https://en.wikipedia.org/wiki/Pulse-code_modulation) audio stream
|
||||
* http://192.168.1.10/audio.opus - [Opus][opus] audio stream.
|
||||
* http://192.168.1.10/audio.m4a - [AAC][aac] audio stream.
|
||||
* http://192.168.1.10/audio.mp3 - [MP3][mp3] audio stream.
|
||||
* http://192.168.1.10/audio.pcm - Raw [PCM][pcm] audio stream.
|
||||
* http://192.168.1.10/audio.alaw - [A-law][alaw] compressed audio stream.
|
||||
* http://192.168.1.10/audio.ulaw - [μ-law][ulaw] compressed audio stream.
|
||||
* http://192.168.1.10/audio.g711a - [G.711][g711] A-law audio stream.
|
||||
|
||||
Use `ffplay -f s16le -ac 1 -ar 48k http://192.168.1.10/audio.pcm`, where `48k` is sample rate
|
||||
##### Tips:
|
||||
|
||||
* http://192.168.1.10/audio.alaw - [A-law](https://en.wikipedia.org/wiki/A-law_algorithm) compressed audio stream
|
||||
To play audio stream use [ffplay][ffplay] utility from [ffmpeg][ffmpeg] package.
|
||||
|
||||
Use `ffplay -ar 48000 -ac 1 -f alaw http://192.168.1.10/audio.alaw`, where `48000` is sample rate
|
||||
```
|
||||
ffplay -ar 48000 -ac 1 -f s16le http://192.168.1.10/audio.pcm
|
||||
ffplay -ar 48000 -ac 1 -f alaw http://192.168.1.10/audio.alaw
|
||||
ffplay -ar 48000 -ac 1 -f mulaw http://192.168.1.10/audio.ulaw
|
||||
ffplay -ar 8000 -ac 1 -f alaw http://192.168.1.10/audio.g711a
|
||||
```
|
||||
|
||||
* http://192.168.1.10/audio.ulaw - [μ-law](https://en.wikipedia.org/wiki/%CE%9C-law_algorithm) compressed audio stream
|
||||
To play audio on camera speaker over network (Hisilicon/Goke only):
|
||||
|
||||
Use `ffplay -ar 48000 -ac 1 -f mulaw http://192.168.1.10/audio.ulaw`, where `48000` is sample rate
|
||||
```
|
||||
curl -T test.pcm http://10.216.128.66:8888/play_audio
|
||||
```
|
||||
|
||||
* http://192.168.1.10/audio.g711a - [G.711](https://en.wikipedia.org/wiki/G.711) A-law audio stream
|
||||
[PCM][pcm] file can be prepared using [sox][sox] program:
|
||||
|
||||
Use `ffplay -ar 8000 -ac 1 -f alaw http://192.168.1.10/audio.g711a`
|
||||
|
||||
### Playing audio on camera via network (Hisilicon/Goke only)
|
||||
|
||||
`curl -T test.pcm http://10.216.128.66:8888/play_audio`
|
||||
|
||||
[pcm](https://en.wikipedia.org/wiki/Pulse-code_modulation) file format can be prepared using [sox] program(https://en.wikipedia.org/wiki/SoX):
|
||||
|
||||
`sox speech.mp3 -t raw -r 8000 -e signed -b 16 -c 1 test.pcm`
|
||||
```
|
||||
sox speech.mp3 -t raw -r 8000 -e signed -b 16 -c 1 test.pcm
|
||||
```
|
||||
|
||||
### API
|
||||
|
||||
Night API endpoint (make sure `nightAPI` in `nightMode` is enabled or use it from a camera without restrictions):
|
||||
Night API endpoint (make sure `nightMode` is enabled in Majestic config,
|
||||
or use it from the camera without restrictions):
|
||||
|
||||
* http://192.168.1.10/night/on - Turn on night mode
|
||||
* http://192.168.1.10/night/off - Turn off night mode (set to day)
|
||||
* http://192.168.1.10/night/toggle - Toggle current mode
|
||||
* http://192.168.1.10/night/on - Turn on night mode.
|
||||
* http://192.168.1.10/night/off - Turn off night mode (set to day).
|
||||
* http://192.168.1.10/night/toggle - Toggle current mode.
|
||||
|
||||
### Monitoring
|
||||
|
||||
* http://192.168.1.10/metrics - Standard Node exporter compatible and application-specific metrics for [Prometheus](https://prometheus.io/)
|
||||
* http://192.168.1.10/metrics - Standard Node exporter compatible
|
||||
and application-specific metrics for [Prometheus](https://prometheus.io/).
|
||||
|
||||
|
||||
[aac]: https://en.wikipedia.org/wiki/Advanced_Audio_Coding
|
||||
[alaw]: https://en.wikipedia.org/wiki/A-law_algorithm
|
||||
[dng]: https://en.wikipedia.org/wiki/Digital_Negative
|
||||
[g711]: https://en.wikipedia.org/wiki/G.711
|
||||
[heif]: https://en.wikipedia.org/wiki/High_Efficiency_Image_File_Format
|
||||
[hls]: https://en.wikipedia.org/wiki/HTTP_Live_Streaming
|
||||
[jpeg]: https://en.wikipedia.org/wiki/JPEG
|
||||
[mjpeg]: https://en.wikipedia.org/wiki/Motion_JPEG
|
||||
[mp3]: https://en.wikipedia.org/wiki/MP3
|
||||
[mp4]: https://en.wikipedia.org/wiki/MPEG-4_Part_14
|
||||
[opus]: https://en.wikipedia.org/wiki/Opus_(audio_format)
|
||||
[pcm]: https://en.wikipedia.org/wiki/Pulse-code_modulation
|
||||
[raw]: https://en.wikipedia.org/wiki/Raw_image_format
|
||||
[rtsp]: https://en.wikipedia.org/wiki/RTSP
|
||||
[ulaw]: https://en.wikipedia.org/wiki/%CE%9C-law_algorithm
|
||||
[yuv]: https://en.wikipedia.org/wiki/YUV
|
||||
[ffplay]: https://ffmpeg.org/ffplay.html
|
||||
[ffmpeg]: https://ffmpeg.org/
|
||||
[sox]: https://en.wikipedia.org/wiki/SoX
|
||||
|
|
|
@ -1,19 +1,22 @@
|
|||
## HiSilicon boards
|
||||
HiSilicon boards
|
||||
----------------
|
||||
|
||||
### Disable subsystems you don't use
|
||||
|
||||
Vendor kernel memory modules take around 5 megabytes of RAM (code with dynamic memory for buffers) and some of them are useless if you don't need specific functions like (OSD, motion detection, audio, H264/265/JPEG codecs)
|
||||
Vendor kernel modules take about 5 megabytes of RAM (code with dynamic memory
|
||||
for buffers) and some of them are pretty useless you need specific functionality
|
||||
like OSD, motion detection, support of audio, or H264/265/JPEG codecs.
|
||||
|
||||
| Feature | Modules | Size |
|
||||
|---------------------------------------|----------------------------------------------------------------------------------------------------|------|
|
||||
| Audio output | hi3516ev200_ao hi3516ev200_adec | |
|
||||
| Audio input | hi3516ev200_ai hi3516ev200_aenc | |
|
||||
| Audio support (both input and output) | hi3516ev200_acodec hi3516ev200_adec hi3516ev200_aenc hi3516ev200_ao hi3516ev200_ai hi3516ev200_aio | |
|
||||
| I2C sensor support | hi_sensor_i2c | |
|
||||
| SPI sensor support | hi_sensor_spi | |
|
||||
| PWM support | hi_pwm | |
|
||||
| Motion detection | hi3516ev200_ive | |
|
||||
| JPEG snapshots | hi3516ev200_jpege | |
|
||||
| H.264 codec support | hi3516ev200_h264e | |
|
||||
| H.265 codec support | hi3516ev200_h265e | |
|
||||
| OSD support | hi3516ev200_rgn
|
||||
| Feature | Modules | Size |
|
||||
|---------------------------------------|---------------------------------------------------------------------------------------------------------|------|
|
||||
| Audio output | hi3516ev200_ao, hi3516ev200_adec | |
|
||||
| Audio input | hi3516ev200_ai, hi3516ev200_aenc | |
|
||||
| Audio support (both input and output) | hi3516ev200_acodec, hi3516ev200_adec, hi3516ev200_aenc, hi3516ev200_ao, hi3516ev200_ai, hi3516ev200_aio | |
|
||||
| I2C sensor support | hi_sensor_i2c | |
|
||||
| SPI sensor support | hi_sensor_spi | |
|
||||
| PWM support | hi_pwm | |
|
||||
| Motion detection | hi3516ev200_ive | |
|
||||
| JPEG snapshots | hi3516ev200_jpege | |
|
||||
| H.264 codec support | hi3516ev200_h264e | |
|
||||
| H.265 codec support | hi3516ev200_h265e | |
|
||||
| OSD support | hi3516ev200_rgn | |
|
||||
|
|
|
@ -1,21 +1,25 @@
|
|||
## Basic information
|
||||
|
||||
The OpenIPC is an alternative [firmware](https://github.com/OpenIPC) for IP cameras and a kind of umbrella for other projects that are components of our system.
|
||||
The OpenIPC is an alternative [firmware](https://github.com/OpenIPC) for
|
||||
IP cameras and a kind of umbrella for other projects that are components of
|
||||
our system.
|
||||
|
||||
The OpenIPC is a Linux operating system based on Buildroot/OpenWrt projects and targeting IP cameras with chipsets from different vendors, starting with Goke GK72xx, HiSilicon Hi35xx, SigmaStar SSC33x, and XiongmaiTech XM5xx.
|
||||
The OpenIPC is a Linux operating system based on Buildroot/OpenWrt projects and
|
||||
targeting IP cameras with chipsets from different vendors, starting
|
||||
with Goke GK72xx, HiSilicon Hi35xx, SigmaStar SSC33x, and XiongmaiTech XM5xx.
|
||||
|
||||
Everyone is welcome and can use/contribute to the project in any way they find useful!
|
||||
Everyone is welcome to use/contribute to the project in any way they find useful!
|
||||
|
||||
We would be grateful for the feedback and suggestions.
|
||||
We would be grateful for any feedback and suggestions.
|
||||
|
||||
|
||||
## Official links
|
||||
|
||||
* [OpenIPC on Wiki](https://openipc.github.io/wiki) - Collection of various documentation and instructions
|
||||
* [OpenIPC on GitHub](https://github.com/OpenIPC/) - GitHub organization, most projects are hosted here
|
||||
* [OpenIPC on OpenCollective](https://opencollective.com/openipc) - OpenCollective community
|
||||
* [OpenIPC on Twitter](https://twitter.com/openipc) - Our main news
|
||||
* [OpenIPC on YouTube](https://www.youtube.com/channel/UCaXlbR2uGTRFh8jQ2lCFd2g) - Our instructions and streams (in the plans)
|
||||
* [OpenIPC on Wiki](https://openipc.github.io/wiki) - Collection of various documentation and instructions.
|
||||
* [OpenIPC on GitHub](https://github.com/OpenIPC/) - GitHub organization, most projects are hosted here.
|
||||
* [OpenIPC on OpenCollective](https://opencollective.com/openipc) - OpenCollective community.
|
||||
* [OpenIPC on Twitter](https://twitter.com/openipc) - Our main news.
|
||||
* [OpenIPC on YouTube](https://www.youtube.com/channel/UCaXlbR2uGTRFh8jQ2lCFd2g) - Our instructions and streams (in the plans).
|
||||
|
||||
|
||||
## Telegram chat groups
|
||||
|
@ -36,44 +40,43 @@ We would be grateful for the feedback and suggestions.
|
|||
|
||||
### Firmware
|
||||
|
||||
* [openipc-2.1](https://openipc.github.io/firmware) - Firmware development and creation system based on Buildroot
|
||||
* [openipc-1.0](https://github.com/OpenIPC/chaos_calmer) - Firmware development and creation system based on OpenWrt 15.05
|
||||
* [coupler](https://github.com/OpenIPC/coupler) - Seamless transition between video cameras firmware
|
||||
* [openipc-2.x](https://openipc.github.io/firmware) - Firmware development and creation system based on Buildroot.
|
||||
* [openipc-1.0][chaos_calmer] - Firmware development and creation system based on OpenWrt 15.05.
|
||||
* [coupler][coupler] - Seamless transition between video cameras firmware.
|
||||
|
||||
### Streamers
|
||||
|
||||
* [majestic](https://github.com/OpenIPC/firmware/wiki/majestic_streamer) - Universal IPCam streamer
|
||||
* [mini](https://github.com/OpenIPC/mini) - OpenSource Mini IP camera streamer
|
||||
* [majestic](https://github.com/OpenIPC/firmware/wiki/majestic_streamer) - Universal IPCam streamer.
|
||||
* [mini][mini] - OpenSource Mini IP camera streamer.
|
||||
|
||||
### Tools
|
||||
|
||||
* [ipctool](https://openipc.github.io/ipctool) - Tool (and library) for checking IP camera hardware
|
||||
* [yaml-cli](https://github.com/OpenIPC/yaml-cli) - Tool for change setting in CLI
|
||||
* [glutinium](https://github.com/ZigFisher/Glutinium) - Additional OpenWRT packages
|
||||
* [ipctool](https://openipc.github.io/ipctool) - Tool (and library) for checking IP camera hardware.
|
||||
* [yaml-cli][yaml-cli] - Tool for change setting in CLI.
|
||||
* [glutinium](https://github.com/ZigFisher/Glutinium) - Additional OpenWRT packages.
|
||||
|
||||
### Windows software
|
||||
|
||||
* [exipcam](http://team.openipc.org/exipcam) - Cool utility for repairing IPCam (For Windows, works in Linux via Wine)
|
||||
* [ipcam_dms](http://team.openipc.org/ipcam_dms) - IPCam Device Management System (For Windows, works in Linux via Wine)
|
||||
* [exipcam](http://team.openipc.org/exipcam) - Cool utility for repairing IPCam (For Windows, works in Linux via Wine).
|
||||
* [ipcam_dms](http://team.openipc.org/ipcam_dms) - IPCam Device Management System (For Windows, works in Linux via Wine).
|
||||
|
||||
|
||||
## Developers
|
||||
|
||||
| Name | Role | Participation |
|
||||
|------|------|---------------|
|
||||
| [Dmitry Ilyin](https://web.telegram.org/#/im?p=@widgetii) | co-founder and main participant of the OpenIPC project | [ipctool](https://github.com/OpenIPC/ipctool), [majestic](https://github.com/OpenIPC/majestic_issues), [mini](https://github.com/OpenIPC/mini), [motors](https://github.com/OpenIPC/motors) |
|
||||
| [Dmitry Ermakov](https://web.telegram.org/#/im?p=@dimerrr) | main participant | [coupler](https://github.com/OpenIPC/coupler), [firmware](https://github.com/OpenIPC/firmware), [ipctool](https://github.com/OpenIPC/ipctool) |
|
||||
| [Igor Zalatov](https://web.telegram.org/#/im?p=@FlyRouter) | **project founder and development coordinator** | [chaos_calmer](https://github.com/OpenIPC/chaos_calmer), [firmware](https://github.com/OpenIPC/firmware), [wiki](https://github.com/OpenIPC/firmware/wiki) |
|
||||
| [Ivan Pozdeev](https://web.telegram.org/#/im?p=@John) | developer | [microbe-web](https://github.com/OpenIPC/microbe-web), [yaml-cli](https://github.com/OpenIPC/yaml-cli) |
|
||||
| [Konstantin](#) | developer | [hisi-trace](https://github.com/OpenIPC/hisi-trace), [yaml-cli](https://github.com/OpenIPC/yaml-cli) |
|
||||
| [Maksim Patrushev](https://web.telegram.org/#/im?p=@maxi380) | developer | [motors](https://github.com/OpenIPC/motors) |
|
||||
| [Maxim Chertov](https://web.telegram.org/#/im?p=@mAX3773) | co-founder of the OpenIPC project | [chaos_calmer](https://github.com/OpenIPC/chaos_calmer), [ipctool](https://github.com/OpenIPC/ipctool), [mini](https://github.com/OpenIPC/mini) |
|
||||
| [Paul Philippov](https://web.telegram.org/#/im?p=@themactep) | main participant | [microbe-web](https://github.com/OpenIPC/microbe-web) |
|
||||
| [Sergey Sharshunov](https://web.telegram.org/#/im?p=@USSSSSH) | co-founder of the OpenIPC project | [chaos_calmer](https://github.com/OpenIPC/chaos_calmer), [burn](https://github.com/OpenIPC/burn) |
|
||||
| [Temirkhan Myrzamadi](https://web.telegram.org/#/im?p=@hirrolot) | main participant | [smolrtsp](https://github.com/OpenIPC/smolrtsp)
|
||||
| [Vasiliy Yakovlev](https://web.telegram.org/#/im?p=@#) | general facilitator | |
|
||||
| Name | Role | Participation |
|
||||
|------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------|
|
||||
| [Dmitry Ilyin](https://web.telegram.org/#/im?p=@widgetii) | co-founder and main participant of the OpenIPC project | [ipctool][ipctool], [majestic][majestic], [mini][mini], [motors][motors] |
|
||||
| [Dmitry Ermakov](https://web.telegram.org/#/im?p=@dimerrr) | main participant | [coupler][coupler], [firmware][firmware], [ipctool][ipctool] |
|
||||
| [Igor Zalatov](https://web.telegram.org/#/im?p=@FlyRouter) | **project founder and development coordinator** | [chaos_calmer][chaos_calmer], [firmware][firmware], [wiki][wiki] |
|
||||
| [Ivan Pozdeev](https://web.telegram.org/#/im?p=@John) | developer | [microbe-web][webui], [yaml-cli][yaml-cli] |
|
||||
| [Konstantin](#) | developer | [hisi-trace][hisi-trace], [yaml-cli][yaml-cli] |
|
||||
| [Maksim Patrushev](https://web.telegram.org/#/im?p=@maxi380) | developer | [motors][motors] |
|
||||
| [Maxim Chertov](https://web.telegram.org/#/im?p=@mAX3773) | co-founder of the OpenIPC project | [chaos_calmer][chaos_calmer], [ipctool][ipctool], [mini][mini] |
|
||||
| [Paul Philippov](https://web.telegram.org/#/im?p=@themactep) | main participant | [microbe-web][webui] |
|
||||
| [Sergey Sharshunov](https://web.telegram.org/#/im?p=@USSSSSH) | co-founder of the OpenIPC project | [chaos_calmer][chaos_calmer], [burn][burn] |
|
||||
| [Temirkhan Myrzamadi](https://web.telegram.org/#/im?p=@hirrolot) | main participant | [smolrtsp][smolrtsp] |
|
||||
| [Vasiliy Yakovlev](https://web.telegram.org/#/im?p=@#) | general facilitator | |
|
||||
|
||||
-----
|
||||
|
||||
### Support
|
||||
|
||||
|
@ -111,3 +114,18 @@ Thank you.
|
|||
<a href="https://opencollective.com/openipc/contribute/backer-14335/checkout" target="_blank"><img src="https://opencollective.com/webpack/donate/button@2x.png?color=blue" width="375" alt="Open Collective donate button"></a>
|
||||
<a href="https://www.paypal.com/donate/?hosted_button_id=C6F7UJLA58MBS"><img src="https://www.paypalobjects.com/en_US/IT/i/btn/btn_donateCC_LG.gif" alt="PayPal donate button"></a>
|
||||
<a href="https://openipc.org/donation/yoomoney.html"><img src="https://yoomoney.ru/transfer/balance-informer/balance?id=596194605&key=291C29A811B500D7" width="140" alt="YooMoney donate button"></a>
|
||||
|
||||
|
||||
[burn]: https://github.com/OpenIPC/burn
|
||||
[chaos_calmer]: https://github.com/OpenIPC/chaos_calmer
|
||||
[coupler]: https://github.com/OpenIPC/coupler
|
||||
[firmware]: https://github.com/OpenIPC/firmware
|
||||
[hisi-trace]: https://github.com/OpenIPC/hisi-trace
|
||||
[ipctool]: https://github.com/OpenIPC/ipctool
|
||||
[majestic]: https://github.com/OpenIPC/majestic_issues
|
||||
[mini]: https://github.com/OpenIPC/mini
|
||||
[motors]: https://github.com/OpenIPC/motors
|
||||
[smolrtsp]: https://github.com/OpenIPC/smolrtsp
|
||||
[webui]: https://github.com/OpenIPC/microbe-web
|
||||
[wiki]: https://github.com/OpenIPC/firmware/wiki
|
||||
[yaml-cli]: https://github.com/OpenIPC/yaml-cli
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
## Microbe WEB interface
|
||||
Microbe web interface
|
||||
---------------------
|
||||
|
||||
Default login/password - admin/12345
|
||||
Default login/password: admin/12345
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
## Installation: how to make OpenIPC running on certain HW
|
||||
Installation: how to make OpenIPC running on certain hardware
|
||||
-------------------------------------------------------------
|
||||
|
||||
Supported HW and installation procedures are given on [openipc.org](https://openipc.org/firmware/) site.
|
||||
Supported hardware and installation procedures are given on [openipc.org](https://openipc.org/firmware/) site.
|
||||
|
||||
Please follow on site instructions for your CPU and video chip!
|
||||
|
||||
|
|
|
@ -1,19 +1,19 @@
|
|||
## Source code
|
||||
Source code
|
||||
-----------
|
||||
|
||||
**At the moment, we are working on creating a high-quality repository with source code.**
|
||||
|
||||
**Please be patient because we want to provide a completely beautiful and ready-made project.**
|
||||
|
||||
-----
|
||||
|
||||
### Quick build from sources
|
||||
|
||||
Install some packages to system and clone OpenIPC repo
|
||||
|
||||
```
|
||||
sudo apt-get update -y ; sudo apt-get install -y bc build-essential git unzip
|
||||
sudo apt-get update -y
|
||||
sudo apt-get install -y bc build-essential git unzip
|
||||
git clone --depth=1 https://github.com/OpenIPC/firmware.git
|
||||
cd openipc-2.1
|
||||
cd firmware
|
||||
```
|
||||
Run the commands below for your board and your files will end up in the "output/images" directory
|
||||
|
||||
|
@ -101,5 +101,3 @@ PLATFORM=sigmastar make br-sigmastar-osdrv-ssc335-{dirclean,rebuild}
|
|||
#
|
||||
PLATFORM=xiongmai make br-xiongmai-osdrv-xm530-{dirclean,rebuild}
|
||||
```
|
||||
|
||||
|
||||
|
|
|
@ -1,22 +1,17 @@
|
|||
## System features
|
||||
System features
|
||||
---------------
|
||||
|
||||
* Supports for most TrueType (.ttf) and certain OpenType (.otf) fonts.
|
||||
|
||||
-----
|
||||
|
||||
### Random Number Generator
|
||||
|
||||
It WORKs now on Hi3516Ev200/Hi3516Ev300 devices
|
||||
|
||||
-----
|
||||
Works on Hi3516Ev200/Hi3516Ev300 devices.
|
||||
|
||||
### Watchdog
|
||||
|
||||
It WORKs now on Hi3516Ev200/Hi3516Ev300 devices
|
||||
|
||||
-----
|
||||
Works on Hi3516Ev200/Hi3516Ev300 devices.
|
||||
|
||||
### WiFi
|
||||
|
||||
* Realtek Semiconductor RTL8188ETV Wireless LAN 802.11n Network Adapter
|
||||
* [https://linux-hardware.org/index.php?id=usb:0bda-0179](https://linux-hardware.org/index.php?id=usb:0bda-0179)
|
||||
* [https://linux-hardware.org/index.php?id=usb:0bda-0179](https://linux-hardware.org/index.php?id=usb:0bda-0179)
|
||||
|
|
|
@ -1,22 +1,22 @@
|
|||
## Upgrade firmware
|
||||
Upgrading firmware
|
||||
------------------
|
||||
|
||||
`sysupgrade` for old firmware
|
||||
For old firmware `sysupgrade` without parameters is enough.
|
||||
|
||||
`sysupgrade -k -r` for new firmware
|
||||
For newer firmware, use it as `sysupgrade -k -r` to update both kernel and rootfs.
|
||||
|
||||
If you got this error:
|
||||
```
|
||||
losetup: /tmp/rootfs.squashfs.${soc}: No such file or directory
|
||||
Rootfs: Unable to get hostname, execution was interrupted...
|
||||
```
|
||||
Try first update kernel:
|
||||
then try to update only kernel first:
|
||||
`sysupgrade -k`
|
||||
|
||||
If it doesn't help use option --force:
|
||||
If it doesn't help, use `--force` option:
|
||||
`sysupgrade -r --force`
|
||||
|
||||
|
||||
If you caught a glitch:
|
||||
If you caught a glitch, retrieve the most recent version of the utility:
|
||||
```
|
||||
curl -k -L -o /usr/sbin/sysupgrade "https://raw.githubusercontent.com/OpenIPC/firmware/master/general/overlay/usr/sbin/sysupgrade"
|
||||
```
|
||||
```
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
# ToDo
|
||||
ToDo
|
||||
----
|
||||
|
||||
## Bugfix
|
||||
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
## WiFi for XM530 based devices
|
||||
WiFi for XM530 based devices
|
||||
----------------------------
|
||||
|
||||
Script /usr/sbin/wifi
|
||||
Save this script as `/usr/sbin/wifi`
|
||||
|
||||
```
|
||||
#!/bin/sh
|
||||
|
@ -18,7 +19,7 @@ if [ "$WIFI" = "xm711" ]; then
|
|||
fi
|
||||
```
|
||||
|
||||
Settings on /etc/network/interfaces
|
||||
Save these settings to `/etc/network/interfaces`
|
||||
|
||||
```
|
||||
auto eth2
|
||||
|
@ -28,4 +29,4 @@ iface eth2 inet dhcp
|
|||
pre-up sed -i '2i \\tscan_ssid=1' /tmp/wpa_supplicant.conf
|
||||
pre-up (sleep 3; wpa_supplicant -B -Dnl80211 -ieth2 -c/tmp/wpa_supplicant.conf)
|
||||
post-down killall -q wpa_supplicant
|
||||
```
|
||||
```
|
||||
|
|
|
@ -1,6 +1,10 @@
|
|||
## Configuration requirements
|
||||
Configuration requirements
|
||||
--------------------------
|
||||
|
||||
To prevent accidental stream termination on temporary connection drops schedule live streaming with a start date in the far future (e.g. 31 December of the current year). It will work smoothly when you go live, disconnect the camera and then continue streaming.
|
||||
To prevent accidental stream termination on temporary connection drops
|
||||
schedule live streaming with a start date in the far future (e.g. December 31st
|
||||
of the current year). It will work smoothly when you go live, disconnect the
|
||||
camera and then continue streaming.
|
||||
|
||||
### HLS + H.265
|
||||
|
||||
|
@ -8,92 +12,88 @@ Follow up [Delivering Content via HLS](https://developers.google.com/youtube/v3/
|
|||
|
||||
### Create new stream
|
||||
|
||||
- Navigate https://developers.google.com/youtube/v3/live/code_samples page
|
||||
- Navigate to <https://developers.google.com/youtube/v3/live/code_samples> page.
|
||||
|
||||
- Select Resource 'liveStreams' and Method 'insert'
|
||||
- Select 'liveStreams' as Resource and 'insert' as Method.
|
||||
|
||||
- In table below click on 'insert' use case
|
||||
- In table below, click on 'insert' use case.
|
||||
|
||||
- Fill on right side on the page:
|
||||
- in 'cdn' object change "frameRate" from "60fps" to "variable",
|
||||
- "resolution" from "1080p" to "variable"
|
||||
- and "ingestionType" from "rtmp" to "hls":
|
||||
- On the right side of the page:
|
||||
- in 'cdn' object, change "frameRate" from "60fps" to "variable";
|
||||
- switch "resolution" from "1080p" to "variable";
|
||||
- switch "ingestionType" from "rtmp" to "hls":
|
||||
|
||||
```
|
||||
"cdn": {
|
||||
"ingestionType": "hls",
|
||||
"frameRate": "variable",
|
||||
"resolution": "variable"
|
||||
}
|
||||
"cdn": {
|
||||
"ingestionType": "hls",
|
||||
"frameRate": "variable",
|
||||
"resolution": "variable"
|
||||
}
|
||||
```
|
||||
|
||||
- in Credentials section make sure you've selected 'Google OAuth 2.0' and 'https://www.googleapis.com/auth/youtube' scope (use 'Show scopes') and deselect 'API Key' option, then press 'Execute' button below
|
||||
- in Credentials section, make sure you've selected 'Google OAuth 2.0' and
|
||||
'https://www.googleapis.com/auth/youtube' scope (use 'Show scopes') and
|
||||
deselect 'API Key' option, then press 'Execute' button below.
|
||||
|
||||
- Authorize yourself using your YouТube connected account
|
||||
- Authorize yourself using your YouTube connected account.
|
||||
|
||||
- Make sure that you got 200 response otherwise check errors and repeat. Trivial error is when [live streaming](https://support.google.com/youtube/answer/2474026?hl=en was not priviosly enabled in your account.
|
||||
- Make sure that you got 200 response otherwise check errors and repeat.
|
||||
Trivial error is when [live streaming](https://support.google.com/youtube/answer/2474026?hl=en)
|
||||
was not previously enabled in your account.
|
||||
|
||||
- Save "channelId" from the response (it looks like "UCPJRjbxYlq6h2cCqy8RCRjg").
|
||||
|
||||
- Save "channelId" from the response (it looks like this "UCPJRjbxYlq6h2cCqy8RCRjg")
|
||||
|
||||
### Create new broadcast:
|
||||
|
||||
- Navigate https://developers.google.com/youtube/v3/live/code_samples page
|
||||
- Navigate to <https://developers.google.com/youtube/v3/live/code_samples> page.
|
||||
|
||||
- Select Resource 'liveBroadcast' and Method 'insert'
|
||||
- Select 'liveBroadcast' as Resource and 'insert' as Method.
|
||||
|
||||
- In table below click on 'insert' use case
|
||||
|
||||
- Fill on right side on the page:
|
||||
- In table below, click on 'insert' use case.
|
||||
|
||||
- On the right side of the page:
|
||||
- 'title' field for your broadcast like 'My Hometown Camera'
|
||||
|
||||
- 'scheduledStartTime' like '2020-04-21T00:00:00.000Z' (ensure that this time in the future),
|
||||
|
||||
- 'scheduledEndTime' like '2020-04-21T01:00:00.000Z' (scheduled end time should be after the scheduled start time)
|
||||
|
||||
- also press blue plus button inside "snippet" block and add "channelId" with given from stream step value
|
||||
|
||||
```
|
||||
"snippet": {`
|
||||
`"title": "My Hometown Camera",`
|
||||
`"scheduledStartTime": "2021-04-12T00:00:00.000Z",`
|
||||
`"scheduledEndTime": "2021-04-13T00:00:00.000Z",`
|
||||
`"channelId": "MCpZqkqqEZw806aGGHUdepIl"`
|
||||
`},
|
||||
"snippet": {`
|
||||
`"title": "My Hometown Camera",`
|
||||
`"scheduledStartTime": "2021-04-12T00:00:00.000Z",`
|
||||
`"scheduledEndTime": "2021-04-13T00:00:00.000Z",`
|
||||
`"channelId": "MCpZqkqqEZw806aGGHUdepIl"`
|
||||
`},
|
||||
```
|
||||
|
||||
- in Credentials section make sure you've selected 'Google OAuth 2.0' and 'https://www.googleapis.com/auth/youtube' scope (use 'Show scopes') and deselect 'API Key' option, then press 'Execute' button below
|
||||
- in Credentials section, make sure you've selected 'Google OAuth 2.0' and
|
||||
'https://www.googleapis.com/auth/youtube' scope (use 'Show scopes') and
|
||||
deselect 'API Key' option, then press 'Execute' button below.
|
||||
|
||||
- Authorize yourself using your YouTube connected account
|
||||
- Authorize yourself using your YouTube connected account.
|
||||
|
||||
- Make sure that you got 200 response otherwise check errors and repeat.
|
||||
|
||||
- Make sure that you got 200 response otherwise check errors and repeat
|
||||
|
||||
### Bind the broadcast to the stream:
|
||||
|
||||
- Navigate https://developers.google.com/youtube/v3/live/code_samples page
|
||||
|
||||
- Select Resource 'liveBroadcast' and Method 'bind'
|
||||
|
||||
- In table below click on 'Bind a broadcast to a stream' use case
|
||||
|
||||
- Fill on right side on the page:
|
||||
|
||||
- Navigate to <https://developers.google.com/youtube/v3/live/code_samples> page.
|
||||
- Select 'liveBroadcast' as Resource and 'bind' as Method.
|
||||
- In the table below, click on 'Bind a broadcast to a stream' use case.
|
||||
- On the right side of the page:
|
||||
- 'id' - ID of the broadcast (can be found in server response in step 'Create new broadcast', field 'id')
|
||||
|
||||
- 'streamId' - ID of the stream (can be found in server response in step 'Create new stream', field 'id')
|
||||
|
||||
- in Credentials section make sure you've selected 'Google OAuth 2.0' and 'https://www.googleapis.com/auth/youtube' scope (use 'Show scopes') and deselect 'API Key' option, then press 'Execute' button below
|
||||
- Authorize yourself using your YouTube connected account.
|
||||
- Make sure that you got 200 response otherwise check errors and repeat.
|
||||
|
||||
- Authorize yourself using your YouTube connected account
|
||||
|
||||
- Make sure that you got 200 response otherwise check errors and repeat
|
||||
|
||||
### Go live!
|
||||
|
||||
Navigate https://studio.youtube.com/
|
||||
Navigate to <https://studio.youtube.com/>.
|
||||
|
||||
On right side click on 'CREATE' button and then 'Go live'
|
||||
On the right side, click on 'CREATE' button and then 'Go live'.
|
||||
|
||||
credits (c) Victor
|
||||
Origin
|
||||
https://github.com/OpenIPC/camerasrnd/blob/master/streaming/youtube.md
|
||||
|
||||
(c) Victor, Origin: https://github.com/OpenIPC/camerasrnd/blob/master/streaming/youtube.md
|
||||
|
|
Binary file not shown.
After Width: | Height: | Size: 112 KiB |
Binary file not shown.
After Width: | Height: | Size: 109 KiB |
Binary file not shown.
After Width: | Height: | Size: 6.9 KiB |
40
index.md
40
index.md
|
@ -1,5 +1,39 @@
|
|||

|
||||

|
||||
|
||||
## [EN](en/index) - English
|
||||
OpenIPC Wiki
|
||||
============
|
||||
|
||||
## [RU](ru/index) - Русский
|
||||
[English](en/index) | [Русский](ru/index)
|
||||
|
||||
|
||||
> "Improving the world, one patch at a time."
|
||||
|
||||
|
||||
### This is an open project, so you can help, too.
|
||||
|
||||
We try to collect, organize and share as much information regarding different
|
||||
aspects of the project as we can. But sometimes we overlook things that seem
|
||||
obvious to us, developers, but are not so obvious to end-users, people who are
|
||||
less familiar with nuts and bolts behind the scene. That is why we set up this
|
||||
wiki and let anyone having a GitHub account to make additions and improvements
|
||||
to the knowledgebase.
|
||||
|
||||
### How to contribute.
|
||||
|
||||
Sign in into your GitHub account, or [get yourself one][gh-signup] if you don't
|
||||
have it yet. It's free.
|
||||
|
||||
Go to [the wiki repository](https://github.com/openIPC/wiki/) and fork it.
|
||||
|
||||

|
||||
|
||||
Make changes (correct a typo, add another record into a table, or write a new
|
||||
article) and commit them to your own fork of the repository.
|
||||
|
||||
From your repository, create a pull request, so we could review and incorporate
|
||||
your changes into our version of the wiki.
|
||||
|
||||

|
||||
|
||||
|
||||
[gh-signup]: https://github.com/signup
|
||||
|
|
|
@ -133,4 +133,4 @@ logging.
|
|||
[sysklogd: add -Z option to adjust message timezones](http://lists.busybox.net/pipermail/busybox/2017-May/085437.html)
|
||||
|
||||
|
||||
[logo]: https://cdn.themactep.com/images/logo_openipc.png
|
||||
[logo]: ../images/logo_openipc.png
|
||||
|
|
|
@ -1,7 +1,5 @@
|
|||
![OpenIPC logo][logo]
|
||||
|
||||
# Русская версия
|
||||
|
||||
## Прошивка OpenIPC -- что это?
|
||||
|
||||
Прошивка OpenIPC (OpenIPC firmware) -- это коллективный труд многих
|
||||
|
@ -126,7 +124,7 @@ OpenIPC -- это увлекательный эксперимент, в кото
|
|||
вам поможет [пошаговая инструкция](/wiki/ru/installation).
|
||||
|
||||
|
||||
[logo]: https://cdn.themactep.com/images/logo_openipc.png
|
||||
[logo]: ../images/logo_openipc.png
|
||||
[socs]: https://github.com/OpenIPC/firmware/wiki/supported_devices
|
||||
[faq1]: https://github.com/OpenIPC/camerasrnd/blob/master/docs/FAQ-ru.md
|
||||
[faq2]: https://github.com/OpenIPC/wiki/blob/master/ru/discussion.md
|
||||
|
|
|
@ -104,4 +104,4 @@ _...to be continued._
|
|||
** ПРОВЕРИТЬ ВСЕ КОМАНДЫ НА ЖИВОЙ СИСТЕМЕ!***
|
||||
|
||||
|
||||
[logo]: https://cdn.themactep.com/images/logo_openipc.png
|
||||
[logo]: ../images/logo_openipc.png
|
||||
|
|
|
@ -1,25 +1,26 @@
|
|||
## Switcam HS-303
|
||||
Switcam HS-303
|
||||
==============
|
||||
|
||||
Общественные заметки по перепрошивке устройств Switcam HS303 (всех версий) в [OpenIPC](https://openipc.org) v1.0 (на базе OpenWrt)..
|
||||
Публичные заметки по прошивке устройств Switcam HS303 (всех версий) в
|
||||
[OpenIPC](https://openipc.org) v1.0 (на базе OpenWrt).
|
||||
|
||||
Обсуждение проекта и возможностей прошивок (на русском языке) в группе [Telegram](https://t.me/openipc_modding)
|
||||
Обсуждение проекта и возможностей прошивок (на русском языке) в группе
|
||||
[Telegram](https://t.me/openipc_modding).
|
||||
|
||||
### Сборник наиболее актуальных вопросов и ответов в формате Q&A
|
||||
Наиболее актуальные вопросы и ответы
|
||||
------------------------------------
|
||||
|
||||
---
|
||||
#### Какие типы устройств поддерживаются в проекте OpenIPC v1.0?
|
||||
|
||||
**Q. Какие типы устройств поддерживаются в проекте OpenIPC v1.0 ?**
|
||||
На данный момент полноценно поддерживается Switcam HS-303 (v1).
|
||||
В будущем планируется поддержка устройств v2 и v3.
|
||||
|
||||
**A.** На данный момент полноценно поддерживается Switcam HS-303 (v1). В будущем планируется поддержка устройств v2 и v3.
|
||||
#### Где можно взять прошивку для устройства Ростелеком Switcam HS303 (v1)?
|
||||
|
||||
-----
|
||||
Обсуждение работы этих камер доступно по специальной подписке на
|
||||
[OpenIPC paywall](https://paywall.pw/openipc).
|
||||
|
||||
**Q. Где можно взять прошивку для устройства Ростелеком Switcam HS303 (v1) ?**
|
||||
#### Какой путь до SD карты необходимо указывать в `majestic.yaml` для прошивки
|
||||
openipc-1.0?
|
||||
|
||||
**A.** Обсуждение работы этих камер доступно по специальной подписке на [OpenIPC paywall](https://paywall.pw/openipc)
|
||||
|
||||
-----
|
||||
|
||||
**Q. Какой путь до SD карты необходимо указывать в majestic.yaml для прошивки openipc-1.0 ?**
|
||||
|
||||
**A.** /mnt/mmc/%Y/%m/%d/%H.mp4
|
||||
`/mnt/mmc/%Y/%m/%d/%H.mp4`
|
||||
|
|
|
@ -2,33 +2,42 @@
|
|||
|
||||
### План
|
||||
|
||||
* Процессор и имя профиля указываются автоматически при сборке в файле /etc/hostname и доступны постоянно через /rom/..
|
||||
* У плат ..._${platform}_unknown_defconfig hostname не прописан. ..._gk7205v200_fpv_defconfig имеет отличный hostname @p0isk
|
||||
* Добавить ключи в sysupgrade для обновления web-ui и majestic
|
||||
* Процессор и имя профиля указываются автоматически при сборке в файле
|
||||
* `/etc/hostname` и доступны постоянно через `/rom/..`
|
||||
* У плат `..._${platform}_unknown_defconfig` hostname не прописан.
|
||||
* `..._gk7205v200_fpv_defconfig` имеет отличный hostname (@p0isk)
|
||||
* Добавить ключи в `sysupgrade` для обновления web-ui и majestic.
|
||||
|
||||
### Безопасность
|
||||
|
||||
* При первых входах по SSH и WEB предлагать (настойчиво) пользователю сменить пароль, дабы не нарваться на CVE.
|
||||
* По вебу сделано themactep @p0isk
|
||||
* Реализовать интеграцию авторизации httpd на использование стандартных passwd/shadow из /etc
|
||||
* При первых входах в Web UI предлагать (настойчиво) пользователю сменить пароль,
|
||||
дабы не нарваться на CVE.
|
||||
* готово (@p0isk, @themactep).
|
||||
* При первых входах по SSH предлагать (настойчиво) пользователю сменить пароль,
|
||||
дабы не нарваться на CVE.
|
||||
* Реализовать интеграцию авторизации httpd на использование стандартных
|
||||
passwd/shadow из /etc.
|
||||
|
||||
### Унификация ядра
|
||||
|
||||
* Включить опции ROOT_NFS и PNP_DHCP во всех ядрах
|
||||
* Включить опции ROOT_NFS и PNP_DHCP во всех ядрах.
|
||||
|
||||
### Обновление системы
|
||||
|
||||
#### Ядро:
|
||||
* Добавить через mkimage имя процессора, например Linux-4.9.37-hi3516ev200
|
||||
* Готово @p0isk
|
||||
|
||||
* Добавить через mkimage имя процессора, например `Linux-4.9.37-hi3516ev200`
|
||||
* Готово (@p0isk).
|
||||
* По нему проверять и дате проверять пригодность для обновления.
|
||||
* Готово @p0isk
|
||||
* Готово (@p0isk).
|
||||
|
||||
### Обновление majestic
|
||||
|
||||
* Обновляются и проверяются только бинарник и укороченный конфиг.
|
||||
* Есть кнопка Восстановить настройки, нужна ли Восстановить стример?
|
||||
* Помимо ETag можно использовать Last-Modified
|
||||
* Есть кнопка "Восстановить настройки", нужна ли "Восстановить стример"?
|
||||
* Помимо ETag можно использовать Last-Modified.
|
||||
|
||||
#### Ветка разработки
|
||||
|
||||
* Отображать поле для номера коммита. Если пусто, то берём последний.
|
||||
* Неактуально? @p0isk
|
||||
* Неактуально? (@p0isk).
|
||||
|
|
|
@ -1,6 +1,8 @@
|
|||
## Специализированные настройки для устройств Switcam HS303(v2)
|
||||
Специализированные настройки для Switcam HS303(v2)
|
||||
--------------------------------------------------
|
||||
|
||||
Обсуждение работы этих камер доступно по специальной подписке на [OpenIPC paywall](https://paywall.pw/openipc)
|
||||
Обсуждение работы этих камер доступно по специальной подписке на
|
||||
[OpenIPC paywall](https://paywall.pw/openipc).
|
||||
|
||||
### Модифицированный блок из файла /etc/network/interface
|
||||
|
||||
|
@ -29,4 +31,4 @@ nightMode:
|
|||
pinSwitchDelayUs: 150
|
||||
backlightPin: 56
|
||||
nightAPI: true
|
||||
```
|
||||
```
|
||||
|
|
|
@ -1,19 +1,24 @@
|
|||
```
|
||||
Квест по перепрошивке gk7205v300 + IMX335 + XM_XT25F128B
|
||||
Прошивка gk7205v300 + IMX335 + XM_XT25F128B
|
||||
-------------------------------------------
|
||||
|
||||
Бутлодер на пароле, flash залочена.
|
||||
|
||||
Скачайте и установите у себя Tftpd сервер: https://github.com/peacepenguin/tftpd64/releases
|
||||
Скачайте и распакуйте в отдельную папку прошивку: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.gk7205v300-br.tgz, в настройках Tftpd укажите путь к папке с прошивкой.
|
||||
Найдите в чате OpenIPC Users (Ru) сообщение с тэгом #GkTool , установите на компьютер ToolPlatform-1.0.0-win32-x86_64.zip
|
||||
Скачайте u-boot.bin.img_cut из чата OpenIPC Users (Ru)
|
||||
Подключите камеру и компьютер через Ethernet к одному роутеру, чтобы компьютер и камера были в одной подсети.
|
||||
Подключите к компьютеру USB-TTL 3.3V адаптер, рекомендуется FTDI232. Он встанет на какой-то COM-порт, посмотреть номер COM порта в Диспетчере задач
|
||||
Подулючите RX/TX/GND на камере к TX/RX/GND на USB-TTL 3.3V адаптере
|
||||
Скачайте и установите Putty. Выставить режим COM порта на скорость 115200. Зайти на камеру через Putty, по COM порту. Убедится,что провода подключены правильно, видно лог камеры и вводятся символы с клавиатуры.
|
||||
ОБЯЗАТЕЛЬНО СОХРАНИТЕ МАС адрес камеры, в процессе прошивки он сотрётся.
|
||||
1. Скачайте и установите у себя [tftpd сервер](https://github.com/peacepenguin/tftpd64/releases).
|
||||
2. Скачайте и распакуйте в отдельную папку [прошивку](https://github.com/OpenIPC/firmware/releases/download/latest/openipc.gk7205v300-br.tgz), в настройках tftpd укажите путь к папке с прошивкой.
|
||||
3. Найдите в Telegram канале [OpenIPC Users (Ru)][t1] сообщение с тэгом #GkTool, установите на компьютер ToolPlatform-1.0.0-win32-x86_64.zip
|
||||
4. Скачайте u-boot.bin.img_cut из Telegram канала [OpenIPC Users (Ru)][t1].
|
||||
5. Подключите камеру и компьютер через Ethernet к одному роутеру, чтобы компьютер и камера были в одной подсети.
|
||||
6. Подключите к компьютеру USB-TTL 3.3V адаптер, рекомендуется FTDI232. Он встанет на какой-то COM-порт, посмотреть номер COM порта в Диспетчере задач.
|
||||
7. Подключите RX/TX/GND на камере к TX/RX/GND на USB-TTL 3.3V адаптере.
|
||||
8. Скачайте и установите Putty. Выставить рцежим COM порта на скорость 115200. Зайти на камеру через Putty, по COM порту. Убедится, что провода подключены правильно, видно лог камеры и вводятся символы с клавиатуры.
|
||||
|
||||
__ОБЯЗАТЕЛЬНО СОХРАНИТЕ МАС адрес камеры! В процессе прошивки он сотрётся!__
|
||||
|
||||
1)В Putty: бэкап копированием на свой hls сервер из ос, перешитой купером:
|
||||
### В Putty
|
||||
|
||||
Создать бэкап копированием на свой hls сервер из ос, перешитой купером:
|
||||
|
||||
```
|
||||
mkdir /mnt/Public
|
||||
mount -o nolock 192.168.1.15(тут указывается IP компьютера):/home/pi/nfs_share /mnt/Public
|
||||
cat /dev/mtdblock0 > /mnt/Public/mtd0
|
||||
|
@ -21,48 +26,49 @@ cat /dev/mtdblock1 > /mnt/Public/mtd1
|
|||
cat /dev/mtdblock2 > /mnt/Public/mtd2
|
||||
cat /dev/mtdblock3 > /mnt/Public/mtd3
|
||||
cat /dev/mtdblock4 > /mnt/Public/mtd4
|
||||
выйти из программы Putty и закрыть её.
|
||||
```
|
||||
|
||||
2) прошить xm бут u-boot.bin.img_cut через #gktool (ToolPlatform):
|
||||
В ToolPlatform выбрать COM-порт, на котором висит адаптер, Transfer mode - Serial.
|
||||
Во вкладке Burn Fastboot выбрать Flash type: spi nor, File: файл u-boot.bin.img_cut.
|
||||
Отключить камеру, нажать кнопку Burn, выждать 5 секунд, включить камеру. Начнется прошивка.
|
||||
Перезагрузить камеру по питанию
|
||||
Выйти из программы Putty и закрыть её.
|
||||
|
||||
3) зайти в U-boot через PUTTY, нажимая несколько раз CTRL-C в момент включения камеры (очень быстро нажимать).
|
||||
Ввести команды
|
||||
sf probe 0; sf lock 0;
|
||||
### Прошить xm бут u-boot.bin.img_cut через #gktool (ToolPlatform)
|
||||
|
||||
1. В ToolPlatform выбрать COM-порт, на котором висит адаптер, Transfer mode - Serial.
|
||||
2. Во вкладке Burn Fastboot выбрать Flash type: spi nor, File: файл u-boot.bin.img_cut.
|
||||
3. Отключить камеру, нажать кнопку Burn, выждать 5 секунд, включить камеру. Начнется прошивка.
|
||||
4. Перезагрузить камеру по питанию.
|
||||
5. Зайти в U-boot через PUTTY, нажимая несколько раз CTRL-C в момент включения камеры (очень быстро нажимать).
|
||||
Ввести команды
|
||||
```
|
||||
sf probe 0
|
||||
sf lock 0
|
||||
sf erase 0 1000000
|
||||
|
||||
-----нажать Enter----
|
||||
|
||||
setenv soc gk7205v300
|
||||
setenv osmem 32M
|
||||
setenv totalmem 128M
|
||||
saveenv
|
||||
-----нажать Enter----
|
||||
|
||||
|
||||
setenv gatewayip 192.168.1.1 //вводите ip адрес вашего шлюза/роутера
|
||||
setenv ipaddr 192.168.1.14 //ip адрес камеры
|
||||
setenv netmask 255.255.255.0 //Маска подсети
|
||||
setenv serverip 192.168.1.15 //ip адрес компьютера на котором вы работаете и запущен TFTPD сервер
|
||||
setenv ethaddr 05:68:31:be:da:38 //MAC вашей ip камеры обязательно
|
||||
saveenv
|
||||
|
||||
-----нажать Enter----
|
||||
setenv gatewayip 192.168.1.1 // вводите ip адрес вашего шлюза/роутера
|
||||
setenv ipaddr 192.168.1.14 // ip адрес камеры
|
||||
setenv netmask 255.255.255.0 // маска подсети
|
||||
setenv serverip 192.168.1.15 // ip адрес компьютера на котором вы работаете и запущен TFTPD сервер
|
||||
setenv ethaddr 05:68:31:be:da:38 // MAC вашей ip камеры обязательно
|
||||
saveenv
|
||||
|
||||
setenv bootargs 'mem=${osmem:-32M} console=ttyAMA0,115200 panic=20 root=/dev/mtdblock3 rootfstype=squashfs init=/init mtdparts=sfc:256k(boot),64k(env),2048k(kernel),5120k(rootfs),-(rootfs_data)'
|
||||
setenv bootcmd 'setenv setargs setenv bootargs ${bootargs}; run setargs; sf probe 0; sf read 0x42000000 0x50000 0x200000; bootm 0x42000000'
|
||||
setenv uk 'mw.b 0x42000000 ff 1000000; tftp 0x42000000 uImage.${soc} && sf probe 0; sf erase 0x50000 0x200000; sf write 0x42000000 0x50000 ${filesize}'
|
||||
setenv ur 'mw.b 0x42000000 ff 1000000; tftp 0x42000000 rootfs.squashfs.${soc} && sf probe 0; sf erase 0x250000 0x500000; sf write 0x42000000 0x250000 ${filesize}'
|
||||
saveenv
|
||||
-----нажать Enter----
|
||||
|
||||
run uk; run ur; reset
|
||||
-----нажать Enter----
|
||||
|
||||
если перезагрузка не помогла, и в консоли проходят пробелы то повторите 2 шаг, после него камера работает.
|
||||
|
||||
после загрузки, выполнить firstboot в консоли Putty
|
||||
run uk
|
||||
run ur
|
||||
reset
|
||||
```
|
||||
|
||||
Если перезагрузка не помогла, и в консоли проходят пробелы, то повторите 2 шаг.
|
||||
После него камера работает.
|
||||
|
||||
После загрузки, выполнить `firstboot` в консоли Putty.
|
||||
|
||||
[t1]: https://t.me/openipc_modding
|
||||
|
|
Loading…
Reference in New Issue