{"value":"### **介绍**\n#### **加速 IPC 设备开发进度**\n为IPC出海客户提供快速开发产品的代码原型参考。\n\n相信每个想要 IPC 出海的厂商,在设备接入亚马逊 Kinesis Video Stream 服务时都面临同样一个痛点:如何快速的开发一款安全,稳定,高效,低成本的亚马逊云连接 IPC。[KVS embedded producer C SDK](https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c)就是为了这个目的而诞生的。\n\nKVS embedded producer C SDK 延续了亚马逊云一贯的高安全性。并且我们着重深度优化了软件的内存占用情况,使得仅拥有64MB甚至32MB的低成本 IPC SoC 一样可以正常运行。在与芯片厂商(如本文下面提到的君正T31)深度合作的背景下,这款 SDK 拥有了更好的稳定性和高效的性能表现。它提供了“自带电池”一般的使用体验,极易上手。\n\n#### **Kinesis Video Stream 介绍**\n\n![image.png](https://dev-media.amazoncloud.cn/ee2d2aaabf474bac8542f5237ae1638e_image.png)\n\n#### **T31 介绍**\nT31 智能视频处理器拥有1.5G高主频 CPU 计算性能,星光增强 ISP,5M@30帧视频编码,安全引擎 并且内置 DDR 。\n\n专业的成像能力,领先的编码品质,丰富的差异化扩展,极致的成本控制和低功耗基因,搭配整合好的丰富 AI 功能算法,使 T31成为业内最全面均衡的H.265+AI视频处理器。\n\n![image.png](https://dev-media.amazoncloud.cn/8012dce617224192ae408549337b5278_image.png)\n\n#### **T31 硬件开发板**\n\n![image.png](https://dev-media.amazoncloud.cn/60ad80e6ee25468da4f5d9ca3e05f582_image.png)\n\n### **使用方法**\n#### **下载代码**\n```\ngit clone --recursive https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c.git\n```\n\n如果在执行 git clone 命令的时候忘记带上 –recursive ,参数,可以进入代码目录中执行 git submodule update –init –recursive 。\n\n#### **预置设备证书(可选)**\nIP Camera 设备也可以使用 X.509 证书连接到 Amazon IoT,然后从Amazon IoT credentials provider 中获取授权信息,并用此信息来授权 Kinesis Video Streams service 的相关操作。请参考文档中 “[how-iot](https://docs.aws.amazon.com/kinesisvideostreams/latest/dg/how-iot.html)” 的相关操作步骤。\n\n#### **准备 H264 视频文件**\n上面介绍的代码中,我们上传的视频是预先录制好,并以文件形式储存在本地的。可以在代码中 “samples/h264SampleFrames/” 目录下面找到,这些文件都是以”frame-[index].h264″作为开头。比如,”frame-001.h264″, “frame-002.h264”, 等等。\nYou can also use [sample frames of amazon-kinesis-video-streams-producer-c](https://github.com/awslabs/amazon-kinesis-video-streams-producer-c/tree/master/samples/h264SampleFrames).\n\n#### **Ingenic T31 example**\n##### **准备工作**\n- Ingenic T31 SDK ISVP-T31-1.1.3-20210223:\n\n\t注意:上面的代码中没有附带君正 T31 的 SDK,所以需要自行联系君正或者该SDK\n\n- Ingenic T31 EVB 开发板\n- 以太网网络连接\n\n\n##### **Device 设置**\n请跟随君正 T31 的 SDK 中附带的”T31 SNIPE_user_guide.pdf”配置设备,加入如下配置到 /system/init/app_init.sh\n\n#### **设置 DNS server**\n使用如下命令设置 DNS 服务器。.其中 “8.8.8.8” 是谷歌的DNS服务器,可以根据实际情况修改。.\n\n```echo 'nameserver 8.8.8.8' > /etc/resolv.conf```\n\n然后,使用如下命令验证 DNS 服务器是否正确。\n\n```\n# ping aws.amazon.com\nPING aws.amazon.com (13.35.25.75): 56 data bytes\n64 bytes from 13.35.25.75: seq=0 ttl=242 time=10.026 ms\n64 bytes from 13.35.25.75: seq=1 ttl=242 time=9.244 ms\n```\n\n##### **设置 NTP time**\n注意:请确保你的 NTP 服务器工作正常,可以根据实际情况修改NTP服务器地址。\n\n```ntpd -nqp pool.ntp.org```\n\n然后,使用如下命令验证 NTP 服务器是否正确。\n\n```\n[root@Ingenic-uc1_1:mnt]# date\nFri Jul 16 03:30:05 UTC 2021\n```\n\n##### **挂载 SD card**\n这里我们会把执行程序放在 SD 中,如果你使用其他地址存放执行程序,比如 Flash,可以跳过这一步。\n使用如下命令挂载 SD 卡。\n\n```mount -t vfat /dev/mmcblk0p1 /mnt```\n\n##### **使能 音频驱动**\n使用如下命令加载音频模块,如果你不想使用音频,可以跳过这一步。\n\n```insmod /system/lib/modules/audio.ko```\n\n##### **构建代码**\n##### **下载代码**\n```\ngit clone --recursive https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c.git\n```\n\n如果在执行 git clone 命令的时候忘记带上 –recursive ,参数,可以进入代码目录中执行 ```git submodule update --init --recursive``` 。\n\n##### **配置 T31 SDK**\n将 T31 的 SDK 放到 “samples/kvsapp-ingenic-t31/sdk/”目录下\n\n```\ncp -rf /path/to/ISVP-T31-1.1.3-20210223/software/sdk/Ingenic-SDK-T31-1.1.3-20210223/sdk/4.7.2 \\\n /path/to/amazon-kinesis-video-streams-producer-embedded-c/samples/kvsapp-ingenic-t31/sdk/\n```\n\n最终的目录结构如下:\n```\n\n.\n├── app\n├── libraries\n├── misc\n├── samples\n│ ├── kvsapp-ingenic-t31\n│ │ ├── include\n│ │ ├── library\n│ │ ├── sdk\n│ │ │ ├── include\n│ │ │ │ ├── imp\n│ │ │ │ └── sysutils\n│ │ │ ├── lib\n│ │ │ │ ├── glibc\n│ │ │ │ └── uclibc\n│ │ │ └── samples\n│ │ │ ├── libimp-samples\n│ │ │ └── libsysutils-samples\n│ │ └── source\n│ └── mkv_uploader\n└── src\n```\n\n##### **配置 toolchain**\n添加”mips-gcc472-glibc216-64bit”交叉编译链到系统的 PATH 中\n\n```\nexport PATH=$PATH:/path/to/your/toolchain/mips-gcc472-glibc216-64bit/bin\n```\n\n##### **配置 sample**\n如果你想使用环境变量,可以跳过这一步。\n详细配置保存在 “samples/kvsapp-ingenic-t31/include/sample_config.h“文件中。\n\n##### **Build**\n创建 build 目录\n\n```mkdir build && cd build```\n\n执行 cmake 命令\n\n```\ncmake -DCMAKE_C_COMPILER=mips-linux-gnu-gcc \\\n -DCMAKE_CXX_COMPILER=mips-linux-gnu-g++ \\\n -DBOARD_INGENIC_T31=ON \\\n ..\n```\n\n##### **Build 整个项目**\n\n```cmake --build``` .\n\n在编译完成以后,在”build/bin/”目录下将会出现两个可执行文件: “kvsappcli-ingenic-t31” 和 “kvsappcli-ingenic-t31-static” 。 “kvsappcli-ingenic-t31″ 使用”build/lib/” 目录下的shared library。 “kvsappcli-ingenic-t31-static” 是一个静态可执行程序,它不需要其他的动态库,除了最基本的运行时 library,比如 “libc” 和 “pthread”。 将上述编译生成的文件以及相关的音视频文件拷贝到 SD 卡中。\n\n##### **运行 sample**\n如果你没有把配置写入文件 “*samples/kvsapp-ingenic-t31/include/sample_config.h*“,可以直接配置环境变量:\n\n```\nexport AWS_ACCESS_KEY_ID=xxxxxxxxxxxxxxxxxxxx\nexport AWS_SECRET_ACCESS_KEY=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\nexport AWS_DEFAULT_REGION=us-east-1\nexport AWS_KVS_HOST=kinesisvideo.us-east-1.amazonaws.com\n```\n\n现在可执行文件已经在 SD 卡上了,可以使用如下命令启动应用,其中 kvs-stream-name 是 KVS 流的名字。也可以把这些参数细节写入sample_config.h 文件中。\n\n```\ncd /mnt\n./kvsappcli-ingenic-t31-static [kvs-stream-name]\n```\n\n如果一切正常,可以看到如下输出:\n\n```\n[root@Ingenic-uc1_1:mnt]# ./kvsappcli-ingenic-t31\nAACEncoderInit channels = 1, pcm_frame_len = 2048\n[ 5577.435278] gc2053 chip found @ 0x37 (i2c0) version H20210315a\n---- FPGA board is ready ----\nBoard UID : 30AB6E51\nBoard HW ID : 72000460\nBoard rev. : 5DE5A975\nBoard date : 20190326\n-----------------------------\n!! The specified ScalingList is not allowed; it will be adjusted!!\n[ 5577.814323] codec_set_device: set device: MIC...\nInfo: SPS is found\nInfo: SPS is set\nInfo: PPS is found\nInfo: PPS is set\nInfo: KVS stream buffer created\nInfo: Try to describe stream\nInfo: PUT MEDIA endpoint: s-xxxxxxxx.kinesisvideo.us-east-1.amazonaws.com\nInfo: 100-continue\nInfo: Flush to next cluster\nInfo: Fragment buffering, timecode:1628131208569\nInfo: Fragment received, timecode:1628131208569\nInfo: Fragment buffering, timecode:1628131212771\nInfo: Fragment persisted, timecode:1628131208569\nInfo: Fragment received, timecode:1628131212771\nInfo: Fragment buffering, timecode:1628131216972\nInfo: Fragment persisted, timecode:1628131212771\nInfo: Fragment received, timecode:1628131216972\nInfo: Fragment buffering, timecode:1628131220975\nInfo: Fragment persisted, timecode:1628131216972\nInfo: Fragment received, timecode:1628131220975\nInfo: Fragment buffering, timecode:1628131224975\nInfo: Fragment persisted, timecode:1628131220975\n```\n\n##### **KVS sample for Ingenic T31**\n上面的 build 步骤以后,””build/ingenic_t31_kvs_sample”目录中将会出现一些预编译好的 libraries。这样可以大大加速再次 build 的速度。\n\n##### **目前支持的其他硬件平台**\n上面介绍的代码是为嵌入式设备特殊优化的,比如 FreeRTOS/Embedded Linux。如下的几种常见的嵌入式平台,目前都可以使用这份代码安全的上传音视频流到 Kinesis Video Streams.\n\n- [Espressif ESP-WROVER-KIT](https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#esp-wrover-kit-example)\n- [Ingenic T31](https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c/tree/main/samples/kvsapp-ingenic-t31)\n- [Realtek AmebaPro](https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#realtek-amebapro-example)\n- [Raspberry Pi/V4L2](https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#raspberry-pi-v4l2-example)\n- [Linux](https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#linux-example)\n\n### **KVS 认证**\nAmazon 提供一系列硬體相關的[認證程序](https://aws.amazon.com/partners/programs/dqp/),用來協助合作伙伴驗證其硬體設備正常運行在 Amazon 相關服務。經由 Amazon 認證通過的硬件設備將會被列表在 Amazon 合作伙伴的[設備目錄](https://devices.amazonaws.com/)。此設備目錄將協助終端用戶快速搜索相關的硬件設備,加速搭建解決方案所選用之硬件,目的在於讓用戶專注在解決方案之開發,利用 Amazon IoT 生態圈來簡化硬件的選用,達成最佳的用戶體驗。 Amazon Kinesis Video Streams 為 Amazon Device Qualification Program 其中一項硬體認證服務。\n\nAmazon Kinesis Video Streams 認證程序基於有攝像頭的設備,或是俱備上傳影音功能之設備已整合相關軟件。確保設備正常運行[ KVS 相關軟件](https://aws.amazon.com/kinesis/video-streams/resources/?amazon-kinesis-video-streams-resources-blog.sort-by=item.additionalFields.createdDate&amazon-kinesis-video-streams-resources-blog.sort-order=desc),且能持續的將影音資料上傳至 KVS 服務。認證程序涵蓋了設備連線能力,與 KVS 服務之交互,設備身份驗證程序,以及合乎最佳安全實踐。客戶透過登入 Amazon Partner Central 來取得相關認證文件。\n\n合作伙伴所提交之設備,經過技術團隊驗證以及市場團隊審核其內容,完成認證流程後,硬件設備將會被公開發佈在[ Amazon Partner Device Catalog](https://devices.amazonaws.com/search?page=1&sv=kinvid) 以及 [ Amazon 硬件合作伙伴](https://aws.amazon.com/partners/programs/dqp/partners/) 之中。\n\n#### **本篇作者**\n\n![image.png](https://dev-media.amazoncloud.cn/18201cca2edd4ce8b3ea7bb9a39b50cb_image.png)\n\n**William**\nAmazon 物联网实验室 解决方案架构师,主要负责物联网解决方案,致力于 Amazon IoT 相关技术的的推广与应用\n\n![image.png](https://dev-media.amazoncloud.cn/b6bad4bdfbd44e42bc5042b1d5527e6e_image.png)\n\n**Blake**\nAmazon 物联网实验室 技术项目经理,主要负责物联网实验室项目推动,致力于 Amazon IoT 相关技术的扩展与推动新服务\n\n\n![image.png](https://dev-media.amazoncloud.cn/b28347abe28a4d13b00a380c2234b092_image.png)\n\n**Jimmy**\n北京君正智能视频事业部软件工程师,致力于 IPC 产品解决方案的推广与应用\n\n![image.png](https://dev-media.amazoncloud.cn/82c076bd50b642dfa93e735bda027dc9_image.png)\n\n**徐开**\nAmazon 物联网实验室 解决方案架构师,主要负责物联网解决方案,致力于 Amazon IoT 相关技术的的推广与应用","render":"<h3><a id=\"_0\"></a><strong>介绍</strong></h3>\n<h4><a id=\"_IPC__1\"></a><strong>加速 IPC 设备开发进度</strong></h4>\n<p>为IPC出海客户提供快速开发产品的代码原型参考。</p>\n<p>相信每个想要 IPC 出海的厂商,在设备接入亚马逊 Kinesis Video Stream 服务时都面临同样一个痛点:如何快速的开发一款安全,稳定,高效,低成本的亚马逊云连接 IPC。<a href=\"https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c\" target=\"_blank\">KVS embedded producer C SDK</a>就是为了这个目的而诞生的。</p>\n<p>KVS embedded producer C SDK 延续了亚马逊云一贯的高安全性。并且我们着重深度优化了软件的内存占用情况,使得仅拥有64MB甚至32MB的低成本 IPC SoC 一样可以正常运行。在与芯片厂商(如本文下面提到的君正T31)深度合作的背景下,这款 SDK 拥有了更好的稳定性和高效的性能表现。它提供了“自带电池”一般的使用体验,极易上手。</p>\n<h4><a id=\"Kinesis_Video_Stream__8\"></a><strong>Kinesis Video Stream 介绍</strong></h4>\n<p><img src=\"https://dev-media.amazoncloud.cn/ee2d2aaabf474bac8542f5237ae1638e_image.png\" alt=\"image.png\" /></p>\n<h4><a id=\"T31__12\"></a><strong>T31 介绍</strong></h4>\n<p>T31 智能视频处理器拥有1.5G高主频 CPU 计算性能,星光增强 ISP,5M@30帧视频编码,安全引擎 并且内置 DDR 。</p>\n<p>专业的成像能力,领先的编码品质,丰富的差异化扩展,极致的成本控制和低功耗基因,搭配整合好的丰富 AI 功能算法,使 T31成为业内最全面均衡的H.265+AI视频处理器。</p>\n<p><img src=\"https://dev-media.amazoncloud.cn/8012dce617224192ae408549337b5278_image.png\" alt=\"image.png\" /></p>\n<h4><a id=\"T31__19\"></a><strong>T31 硬件开发板</strong></h4>\n<p><img src=\"https://dev-media.amazoncloud.cn/60ad80e6ee25468da4f5d9ca3e05f582_image.png\" alt=\"image.png\" /></p>\n<h3><a id=\"_23\"></a><strong>使用方法</strong></h3>\n<h4><a id=\"_24\"></a><strong>下载代码</strong></h4>\n<pre><code class=\"lang-\">git clone --recursive https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c.git\n</code></pre>\n<p>如果在执行 git clone 命令的时候忘记带上 –recursive ,参数,可以进入代码目录中执行 git submodule update –init –recursive 。</p>\n<h4><a id=\"_31\"></a><strong>预置设备证书(可选)</strong></h4>\n<p>IP Camera 设备也可以使用 X.509 证书连接到 Amazon IoT,然后从Amazon IoT credentials provider 中获取授权信息,并用此信息来授权 Kinesis Video Streams service 的相关操作。请参考文档中 “<a href=\"https://docs.aws.amazon.com/kinesisvideostreams/latest/dg/how-iot.html\" target=\"_blank\">how-iot</a>” 的相关操作步骤。</p>\n<h4><a id=\"_H264__34\"></a><strong>准备 H264 视频文件</strong></h4>\n<p>上面介绍的代码中,我们上传的视频是预先录制好,并以文件形式储存在本地的。可以在代码中 “samples/h264SampleFrames/” 目录下面找到,这些文件都是以”frame-[index].h264″作为开头。比如,”frame-001.h264″, “frame-002.h264”, 等等。<br />\nYou can also use <a href=\"https://github.com/awslabs/amazon-kinesis-video-streams-producer-c/tree/master/samples/h264SampleFrames\" target=\"_blank\">sample frames of amazon-kinesis-video-streams-producer-c</a>.</p>\n<h4><a id=\"Ingenic_T31_example_38\"></a><strong>Ingenic T31 example</strong></h4>\n<h5><a id=\"_39\"></a><strong>准备工作</strong></h5>\n<ul>\n<li>\n<p>Ingenic T31 SDK ISVP-T31-1.1.3-20210223:</p>\n<p>注意:上面的代码中没有附带君正 T31 的 SDK,所以需要自行联系君正或者该SDK</p>\n</li>\n<li>\n<p>Ingenic T31 EVB 开发板</p>\n</li>\n<li>\n<p>以太网网络连接</p>\n</li>\n</ul>\n<h5><a id=\"Device__48\"></a><strong>Device 设置</strong></h5>\n<p>请跟随君正 T31 的 SDK 中附带的”T31 SNIPE_user_guide.pdf”配置设备,加入如下配置到 /system/init/app_init.sh</p>\n<h4><a id=\"_DNS_server_51\"></a><strong>设置 DNS server</strong></h4>\n<p>使用如下命令设置 DNS 服务器。.其中 “8.8.8.8” 是谷歌的DNS服务器,可以根据实际情况修改。.</p>\n<p><code>echo 'nameserver 8.8.8.8' > /etc/resolv.conf</code></p>\n<p>然后,使用如下命令验证 DNS 服务器是否正确。</p>\n<pre><code class=\"lang-\"># ping aws.amazon.com\nPING aws.amazon.com (13.35.25.75): 56 data bytes\n64 bytes from 13.35.25.75: seq=0 ttl=242 time=10.026 ms\n64 bytes from 13.35.25.75: seq=1 ttl=242 time=9.244 ms\n</code></pre>\n<h5><a id=\"_NTP_time_65\"></a><strong>设置 NTP time</strong></h5>\n<p>注意:请确保你的 NTP 服务器工作正常,可以根据实际情况修改NTP服务器地址。</p>\n<p><code>ntpd -nqp pool.ntp.org</code></p>\n<p>然后,使用如下命令验证 NTP 服务器是否正确。</p>\n<pre><code class=\"lang-\">[root@Ingenic-uc1_1:mnt]# date\nFri Jul 16 03:30:05 UTC 2021\n</code></pre>\n<h5><a id=\"_SD_card_77\"></a><strong>挂载 SD card</strong></h5>\n<p>这里我们会把执行程序放在 SD 中,如果你使用其他地址存放执行程序,比如 Flash,可以跳过这一步。<br />\n使用如下命令挂载 SD 卡。</p>\n<p><code>mount -t vfat /dev/mmcblk0p1 /mnt</code></p>\n<h5><a id=\"__83\"></a><strong>使能 音频驱动</strong></h5>\n<p>使用如下命令加载音频模块,如果你不想使用音频,可以跳过这一步。</p>\n<p><code>insmod /system/lib/modules/audio.ko</code></p>\n<h5><a id=\"_88\"></a><strong>构建代码</strong></h5>\n<h5><a id=\"_89\"></a><strong>下载代码</strong></h5>\n<pre><code class=\"lang-\">git clone --recursive https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c.git\n</code></pre>\n<p>如果在执行 git clone 命令的时候忘记带上 –recursive ,参数,可以进入代码目录中执行 <code>git submodule update --init --recursive</code> 。</p>\n<h5><a id=\"_T31_SDK_96\"></a><strong>配置 T31 SDK</strong></h5>\n<p>将 T31 的 SDK 放到 “samples/kvsapp-ingenic-t31/sdk/”目录下</p>\n<pre><code class=\"lang-\">cp -rf /path/to/ISVP-T31-1.1.3-20210223/software/sdk/Ingenic-SDK-T31-1.1.3-20210223/sdk/4.7.2 \\\n /path/to/amazon-kinesis-video-streams-producer-embedded-c/samples/kvsapp-ingenic-t31/sdk/\n</code></pre>\n<p>最终的目录结构如下:</p>\n<pre><code class=\"lang-\">\n.\n├── app\n├── libraries\n├── misc\n├── samples\n│ ├── kvsapp-ingenic-t31\n│ │ ├── include\n│ │ ├── library\n│ │ ├── sdk\n│ │ │ ├── include\n│ │ │ │ ├── imp\n│ │ │ │ └── sysutils\n│ │ │ ├── lib\n│ │ │ │ ├── glibc\n│ │ │ │ └── uclibc\n│ │ │ └── samples\n│ │ │ ├── libimp-samples\n│ │ │ └── libsysutils-samples\n│ │ └── source\n│ └── mkv_uploader\n└── src\n</code></pre>\n<h5><a id=\"_toolchain_130\"></a><strong>配置 toolchain</strong></h5>\n<p>添加”mips-gcc472-glibc216-64bit”交叉编译链到系统的 PATH 中</p>\n<pre><code class=\"lang-\">export PATH=$PATH:/path/to/your/toolchain/mips-gcc472-glibc216-64bit/bin\n</code></pre>\n<h5><a id=\"_sample_137\"></a><strong>配置 sample</strong></h5>\n<p>如果你想使用环境变量,可以跳过这一步。<br />\n详细配置保存在 “samples/kvsapp-ingenic-t31/include/sample_config.h“文件中。</p>\n<h5><a id=\"Build_141\"></a><strong>Build</strong></h5>\n<p>创建 build 目录</p>\n<p><code>mkdir build && cd build</code></p>\n<p>执行 cmake 命令</p>\n<pre><code class=\"lang-\">cmake -DCMAKE_C_COMPILER=mips-linux-gnu-gcc \\\n -DCMAKE_CXX_COMPILER=mips-linux-gnu-g++ \\\n -DBOARD_INGENIC_T31=ON \\\n ..\n</code></pre>\n<h5><a id=\"Build__155\"></a><strong>Build 整个项目</strong></h5>\n<p><code>cmake --build</code> .</p>\n<p>在编译完成以后,在”build/bin/”目录下将会出现两个可执行文件: “kvsappcli-ingenic-t31” 和 “kvsappcli-ingenic-t31-static” 。 “kvsappcli-ingenic-t31″ 使用”build/lib/” 目录下的shared library。 “kvsappcli-ingenic-t31-static” 是一个静态可执行程序,它不需要其他的动态库,除了最基本的运行时 library,比如 “libc” 和 “pthread”。 将上述编译生成的文件以及相关的音视频文件拷贝到 SD 卡中。</p>\n<h5><a id=\"_sample_161\"></a><strong>运行 sample</strong></h5>\n<p>如果你没有把配置写入文件 “<em>samples/kvsapp-ingenic-t31/include/sample_config.h</em>“,可以直接配置环境变量:</p>\n<pre><code class=\"lang-\">export AWS_ACCESS_KEY_ID=xxxxxxxxxxxxxxxxxxxx\nexport AWS_SECRET_ACCESS_KEY=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\nexport AWS_DEFAULT_REGION=us-east-1\nexport AWS_KVS_HOST=kinesisvideo.us-east-1.amazonaws.com\n</code></pre>\n<p>现在可执行文件已经在 SD 卡上了,可以使用如下命令启动应用,其中 kvs-stream-name 是 KVS 流的名字。也可以把这些参数细节写入sample_config.h 文件中。</p>\n<pre><code class=\"lang-\">cd /mnt\n./kvsappcli-ingenic-t31-static [kvs-stream-name]\n</code></pre>\n<p>如果一切正常,可以看到如下输出:</p>\n<pre><code class=\"lang-\">[root@Ingenic-uc1_1:mnt]# ./kvsappcli-ingenic-t31\nAACEncoderInit channels = 1, pcm_frame_len = 2048\n[ 5577.435278] gc2053 chip found @ 0x37 (i2c0) version H20210315a\n---- FPGA board is ready ----\nBoard UID : 30AB6E51\nBoard HW ID : 72000460\nBoard rev. : 5DE5A975\nBoard date : 20190326\n-----------------------------\n!! The specified ScalingList is not allowed; it will be adjusted!!\n[ 5577.814323] codec_set_device: set device: MIC...\nInfo: SPS is found\nInfo: SPS is set\nInfo: PPS is found\nInfo: PPS is set\nInfo: KVS stream buffer created\nInfo: Try to describe stream\nInfo: PUT MEDIA endpoint: s-xxxxxxxx.kinesisvideo.us-east-1.amazonaws.com\nInfo: 100-continue\nInfo: Flush to next cluster\nInfo: Fragment buffering, timecode:1628131208569\nInfo: Fragment received, timecode:1628131208569\nInfo: Fragment buffering, timecode:1628131212771\nInfo: Fragment persisted, timecode:1628131208569\nInfo: Fragment received, timecode:1628131212771\nInfo: Fragment buffering, timecode:1628131216972\nInfo: Fragment persisted, timecode:1628131212771\nInfo: Fragment received, timecode:1628131216972\nInfo: Fragment buffering, timecode:1628131220975\nInfo: Fragment persisted, timecode:1628131216972\nInfo: Fragment received, timecode:1628131220975\nInfo: Fragment buffering, timecode:1628131224975\nInfo: Fragment persisted, timecode:1628131220975\n</code></pre>\n<h5><a id=\"KVS_sample_for_Ingenic_T31_216\"></a><strong>KVS sample for Ingenic T31</strong></h5>\n<p>上面的 build 步骤以后,””build/ingenic_t31_kvs_sample”目录中将会出现一些预编译好的 libraries。这样可以大大加速再次 build 的速度。</p>\n<h5><a id=\"_219\"></a><strong>目前支持的其他硬件平台</strong></h5>\n<p>上面介绍的代码是为嵌入式设备特殊优化的,比如 FreeRTOS/Embedded Linux。如下的几种常见的嵌入式平台,目前都可以使用这份代码安全的上传音视频流到 Kinesis Video Streams.</p>\n<ul>\n<li><a href=\"https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#esp-wrover-kit-example\" target=\"_blank\">Espressif ESP-WROVER-KIT</a></li>\n<li><a href=\"https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c/tree/main/samples/kvsapp-ingenic-t31\" target=\"_blank\">Ingenic T31</a></li>\n<li><a href=\"https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#realtek-amebapro-example\" target=\"_blank\">Realtek AmebaPro</a></li>\n<li><a href=\"https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#raspberry-pi-v4l2-example\" target=\"_blank\">Raspberry Pi/V4L2</a></li>\n<li><a href=\"https://github.com/aws-samples/amazon-kinesis-video-streams-producer-embedded-c#linux-example\" target=\"_blank\">Linux</a></li>\n</ul>\n<h3><a id=\"KVS__228\"></a><strong>KVS 认证</strong></h3>\n<p>Amazon 提供一系列硬體相關的<a href=\"https://aws.amazon.com/partners/programs/dqp/\" target=\"_blank\">認證程序</a>,用來協助合作伙伴驗證其硬體設備正常運行在 Amazon 相關服務。經由 Amazon 認證通過的硬件設備將會被列表在 Amazon 合作伙伴的<a href=\"https://devices.amazonaws.com/\" target=\"_blank\">設備目錄</a>。此設備目錄將協助終端用戶快速搜索相關的硬件設備,加速搭建解決方案所選用之硬件,目的在於讓用戶專注在解決方案之開發,利用 Amazon IoT 生態圈來簡化硬件的選用,達成最佳的用戶體驗。 Amazon Kinesis Video Streams 為 Amazon Device Qualification Program 其中一項硬體認證服務。</p>\n<p>Amazon Kinesis Video Streams 認證程序基於有攝像頭的設備,或是俱備上傳影音功能之設備已整合相關軟件。確保設備正常運行<a href=\"https://aws.amazon.com/kinesis/video-streams/resources/?amazon-kinesis-video-streams-resources-blog.sort-by=item.additionalFields.createdDate&amazon-kinesis-video-streams-resources-blog.sort-order=desc\" target=\"_blank\"> KVS 相關軟件</a>,且能持續的將影音資料上傳至 KVS 服務。認證程序涵蓋了設備連線能力,與 KVS 服務之交互,設備身份驗證程序,以及合乎最佳安全實踐。客戶透過登入 Amazon Partner Central 來取得相關認證文件。</p>\n<p>合作伙伴所提交之設備,經過技術團隊驗證以及市場團隊審核其內容,完成認證流程後,硬件設備將會被公開發佈在<a href=\"https://devices.amazonaws.com/search?page=1&sv=kinvid\" target=\"_blank\"> Amazon Partner Device Catalog</a> 以及 <a href=\"https://aws.amazon.com/partners/programs/dqp/partners/\" target=\"_blank\"> Amazon 硬件合作伙伴</a> 之中。</p>\n<h4><a id=\"_235\"></a><strong>本篇作者</strong></h4>\n<p><img src=\"https://dev-media.amazoncloud.cn/18201cca2edd4ce8b3ea7bb9a39b50cb_image.png\" alt=\"image.png\" /></p>\n<p><strong>William</strong><br />\nAmazon 物联网实验室 解决方案架构师,主要负责物联网解决方案,致力于 Amazon IoT 相关技术的的推广与应用</p>\n<p><img src=\"https://dev-media.amazoncloud.cn/b6bad4bdfbd44e42bc5042b1d5527e6e_image.png\" alt=\"image.png\" /></p>\n<p><strong>Blake</strong><br />\nAmazon 物联网实验室 技术项目经理,主要负责物联网实验室项目推动,致力于 Amazon IoT 相关技术的扩展与推动新服务</p>\n<p><img src=\"https://dev-media.amazoncloud.cn/b28347abe28a4d13b00a380c2234b092_image.png\" alt=\"image.png\" /></p>\n<p><strong>Jimmy</strong><br />\n北京君正智能视频事业部软件工程师,致力于 IPC 产品解决方案的推广与应用</p>\n<p><img src=\"https://dev-media.amazoncloud.cn/82c076bd50b642dfa93e735bda027dc9_image.png\" alt=\"image.png\" /></p>\n<p><strong>徐开</strong><br />\nAmazon 物联网实验室 解决方案架构师,主要负责物联网解决方案,致力于 Amazon IoT 相关技术的的推广与应用</p>\n"}