Android13以太网静态IP不保存的问题
最近在做Amlogic T982的样机,关于以太网部分,系统Settings只有一个Ethernet的条目,没有其他任何信息,什么以太网mac地址,开关,IP地址,子网掩码,默认网关,dns, 设置代理,设置静态IP这些功能统统都没有,只能自己参考Android11的代码移植过来,目前来看其他都正常,只有静态IP设置后无法保存,重启之后,依然还是dhcp 查了logcat发现如下信息:
07-26 03:24:59.141 572 2065 E DelayedDiskWrite: Error writing data file /data/misc/apexdata/com.android.tethering/misc/ethernet/ipconfig.txt
07-26 03:24:59.141 972 972 D EthernetSettings: curEtherStateETHER_STATE_CONNECTING
07-26 03:24:59.141 572 748 D EthernetNetworkFactory: updateInterface, iface: eth0, ipConfig: IP assignment: STATIC
07-26 03:24:59.141 572 748 D EthernetNetworkFactory: Static configuration: IP address 192.168.0.179/24 Gateway 192.168.0.1 DNS servers: [ 192.168.0.1 0.0.0.0 ] Domains
07-26 03:24:59.141 572 748 D EthernetNetworkFactory: Proxy settings: NONE
07-26 03:24:59.141 572 748 D EthernetNetworkFactory: , old ipConfig: IP assignment: DHCP
07-26 03:24:59.141 572 748 D EthernetNetworkFactory: Proxy settings: NONE
07-26 03:24:59.141 572 748 D EthernetNetworkFactory: , capabilities: null, old capabilities: [ Transports: ETHERNET Capabilities: NOT_METERED&INTERNET&NOT_RESTRICTED&TRUSTED&NOT_VPN&NOT_ROAMING&NOT_CONGESTED&NOT_SUSPENDED&NOT_VCN_MANAGED LinkUpBandwidth>=100000Kbps LinkDnBandwidth>=100000Kbps Specifier: <EthernetNetworkSpecifier (eth0)> UnderlyingNetworks: Null], listener: null
07-26 03:24:59.141 572 748 D EthernetNetworkFactory: reconnecting Ethernet
看起来是在写这个文件/data/misc/apexdata/com.android.tethering/misc/ethernet/ipconfig.txt失败了
找到相关代码位置,packages/modules/Connectivity/service-t/src/com/android/server/ethernet/EthernetConfigStore.java
发现是直接在写配置文件,也没有去判断路径文件是否存在,于是手动创建目录和文件之后,发现IP配置信息会写进去,但是重启之后发现依然还是dhcp
在write方法里面做了路径判断,路径不存在就去创建,并且把路径改成了以前的老版本的路径,
data/misc/ethernet/ipconfig.txt
修改如下:
public void write(String iface, IpConfiguration config) {
- write(iface, config, APEX_IP_CONFIG_FILE_PATH + CONFIG_FILE);
+ //write(iface, config, APEX_IP_CONFIG_FILE_PATH + CONFIG_FILE);
+ String filePath = LEGACY_IP_CONFIG_FILE_PATH + CONFIG_FILE;
+ try {
+ File dir = new File(LEGACY_IP_CONFIG_FILE_PATH);
+ if (!dir.exists()) {
+ Log.i(TAG, "write path = " + APEX_IP_CONFIG_FILE_PATH + ", dir.exists() = " + dir.exists());
+ dir.mkdirs();
+ }
+ File file = new File(filePath);
+ if (!file.exists()) {
+ file.createNewFile();
+ }
+ Log.i(TAG, "write file.exists() = " + file.exists());
+ } catch (Exception e) {
+ Log.i(TAG, "writee:" + e.getMessage());
+ }
+ write(iface, config, filePath);}
这样试了一下,发现可以正常保存和获取到静态IP信息。
以为这样就万事大吉拉?并没有,在反复测试中偶然发现设置静态IP后重启,竟然卡在开机动画无限循环,logcat也没有看到有用的信息,百思不得其解,cat data/misc/ethernet/ipconfig.txt查看了一下配置文件,竟然是空的,设置好静态IP之后,我确定查看过这个文件,IP信息已经写进去了,没想到竟然会丢失数据,于是把这个配置文件删除,再重启,发现就可以正常开机了,那这个随机丢失数据导致不能开机的问题也太致命了,这要是发给客户不得被喷死?还得继续研究一下是什么问题。
我有仔细研究了一下logcat发现了报错信息:
--------- beginning of crash
07-26 06:56:29.917 580 580 E AndroidRuntime: *** FATAL EXCEPTION IN SYSTEM PROCESS: main
07-26 06:56:29.917 580 580 E AndroidRuntime: java.lang.RuntimeException: Failed to boot service com.android.server.ConnectivityServiceInitializer: onBootPhase threw an exception during phase 500
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.SystemServiceManager.startBootPhase(SystemServiceManager.java:297)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.SystemServer.startOtherServices(SystemServer.java:2664)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.SystemServer.run(SystemServer.java:938)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.SystemServer.main(SystemServer.java:648)
07-26 06:56:29.917 580 580 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:548)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:914)
07-26 06:56:29.917 580 580 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to read from field 'int android.util.ArrayMap.mSize' on a null object reference in method 'void android.util.ArrayMap.putAll(android.util.ArrayMap)'
07-26 06:56:29.917 580 580 E AndroidRuntime: at android.util.ArrayMap.putAll(ArrayMap.java:705)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.ethernet.EthernetConfigStore.loadConfigFileLocked(EthernetConfigStore.java:112)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.ethernet.EthernetConfigStore.read(EthernetConfigStore.java:104)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.ethernet.EthernetConfigStore.read(EthernetConfigStore.java:87)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.ethernet.EthernetTracker.start(EthernetTracker.java:196)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.ethernet.EthernetServiceImpl.start(EthernetServiceImpl.java:85)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.ConnectivityServiceInitializer.onBootPhase(ConnectivityServiceInitializer.java:97)
07-26 06:56:29.917 580 580 E AndroidRuntime: at com.android.server.SystemServiceManager.startBootPhase(SystemServiceManager.java:294)
07-26 06:56:29.917 580 580 E AndroidRuntime: ... 6 more
07-26 06:56:29.917 623 642 V APM::AudioPolicyEngine: getDevicesForStrategyInt no device found for strategy 1
查看代码位置:
private void loadConfigFileLocked(final String filepath) {final ArrayMap<String, IpConfiguration> configs =IpConfigStore.readIpConfigurations(filepath);mIpConfigurations.putAll(configs);}
原来是这里直接读取文件,读到的信息是空的没有判断就放进ArrayMap 看log报错是int android.util.ArrayMap.mSize空指针,就是说获取的这个configs为null
/** Returns a map of network identity token and {@link IpConfiguration}. */public static ArrayMap<String, IpConfiguration> readIpConfigurations(InputStream inputStream) {ArrayMap<String, IpConfiguration> networks = new ArrayMap<>();DataInputStream in = null;try {in = new DataInputStream(inputStream);int version = in.readInt();if (version != 3 && version != 2 && version != 1) {loge("Bad version on IP configuration file, ignore read");return null;}
就是这里文件内容是空的,就直接return null 了
loadConfigFileLocked方法里面拿到数据configs也没有判断是否为空,就直接putAll传进去了,这就导致遍历map时候空指针了。
我发现就算解决了这个空指针的问题,不会出现开机报错卡在动画,依然解决不了问题,数据还是会丢失,静态IP还是无法保存,客户依然会喷人,这可怎么办,自己写一个保存获取静态IP的逻辑吗?
我仔细分析了一下,这问题不是单纯的保存获取数据的问题了,系统代码这个写文件读文件的操作没什么大毛病,自己写一个逻辑依然是文件读写,这个可能涉及到系统文件读写的问题,可能是软件也可能是硬件问题,需要进一步排查分析原因。。。
相关文章:
Android13以太网静态IP不保存的问题
最近在做Amlogic T982的样机,关于以太网部分,系统Settings只有一个Ethernet的条目,没有其他任何信息,什么以太网mac地址,开关,IP地址,子网掩码,默认网关,dns, 设置代理&a…...
Redis 7.x 系列【31】LUA 脚本
有道无术,术尚可求,有术无道,止于术。 本系列Redis 版本 7.2.5 源码地址:https://gitee.com/pearl-organization/study-redis-demo 文章目录 1. 概述2. 常用命令2.1 EVAL2.2 SCRIPT LOAD2.3 EVALSHA2.4 SCRIPT FLUSH2.5 其他 3. …...
mysql中You can’t specify target table for update in FROM clause错误
mysql中You can’t specify target table for update in FROM clause错误 You cannot update a table and select directly from the same table in a subquery. mysql官网中有这句话,我们不能在一个语句中先在子查询中从某张表查出一些值,再update这张表…...
Linux Vim最全面的教程
Vim 是一个非常强大的文本编辑器,它在 Linux 环境中尤其受欢迎。Vim 支持高度定制,并且拥有丰富的功能,包括多级撤销、宏、脚本语言支持等。下面是关于 Vim 的一个较为全面的教程。 Vim 的启动 要启动 Vim,你可以在终端中输入 v…...
setsockopt选项对tcp速度
GPT-4 (OpenAI) 每个setsockopt调用都涉及到一个套接字描述符,一个指定网络层的常数(如IPPROTO_IP, IPPROTO_TCP, IPPROTO_IPV6, SOL_SOCKET等),一个指定需配置的选项的常数,一个指向配置值的指针,以及那个…...
HarmonyOS应用开发者高级认证,Next版本发布后最新题库 - 多选题序号3
基础认证题库请移步:HarmonyOS应用开发者基础认证题库 注:有读者反馈,题库的代码块比较多,打开文章时会卡死。所以笔者将题库拆分,单选题20个为一组,多选题10个为一组,题库目录如下,…...
bool数组的理解和应用[C++]
文章目录 bool数组的用法bool数组的定义声明bool数组的初始化访问和修改数组元素遍历数组 运用bool数组简单代码 在今天做题中发现了bool类不仅能用于函数类型还能用于数组类型,好奇查了查发现bool还有很多用处:基本变量,在枚举类型中会用到&…...
JavaScript模拟滑动手势
双击回到顶部 左滑动 右滑动 代码展示 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>Gesture…...
Text Control 控件教程:使用 .NET C# 中的二维码和条形码增强文档
QR 码和条形码非常适合为文档和 PDF 文件增加价值,因为它们提供轻松的信息访问、验证信息、跟踪项目和提高交互性。条形码可以弥补纸质或数字人类可读文档与网络门户或网络应用程序中的数字信息之间的差距。大多数用户都熟悉 QR 码和条形码,它们在许多过…...
最新爆火的开源AI项目 | LivePortrait 本地安装教程
LivePortrait 本地部署教程,强大且开源的可控人像AI视频生成 1,准备工作,本地下载代码并准备环境,运行命令前需安装git 以下操作不要安装在C盘和容量较小的硬盘,可以找个大点的硬盘装哟 2,需要安装FFmp…...
揭秘Django与Neo4j:构建智能知识图谱的终极指南
揭秘Django与Neo4j:构建智能知识图谱的终极指南 前言 图是一种用于对象之间的成对关系进行建模的数学结构。 它由两个主要元素组成:节点和关系。 节点:节点可以看作是传统数据库中的记录。每个节点代表一个对象或实体,例如一个人或一个地方。节点按标签分类,这有助于根…...
项目一缓存商品
文章目录 概要整体架构流程技术细节小结 概要 因为商品是经常被浏览的,所以数据库的访问量就问大大增加,造成负载过大影响性能,所以我们需要把商品缓存到redis当中,因为redis是存在内存中的,所以效率会比MySQL的快. 整体架构流程 技术细节 我们在缓存时需要保持数据的一致性所…...
SEO与数据中心代理IP的结合能带来哪些便利?
本文将探讨将SEO与数据中心代理IP结合所带来的好处,以及如何利用这种组合来提升网站在搜索引擎中的排名和可见性。 1. 数据中心代理IP的作用和优势 数据中心代理IP指的是由数据中心提供的IP地址,用于隐藏真实服务器的位置和身份。与其他类型的代理IP相…...
《昇思25天学习打卡营第6天|ResNet50图像分类》
写在前面 从本次开始,接触一些上层应用。 本次通过经典的模型,开始本次任务。这里开始学习resnet50网络模型,应该也会有resnet18,估计18的模型速度会更快一些。 resnet 通过对论文的结论进行展示,说明了模型的功能&…...
Activiti 6 兼容openGauss数据库bytes类型不匹配
当前有个项目需要做国产调研,需要适配高斯数据库,项目启动的时候,提示column "bytes_" is type bytea but expression is of type blob byte_字段是act_ge_bytearray表的,openGauss里的类型是bytea,类型是匹…...
缓存技术:提升性能与效率的利器
在当今数字化时代,软件应用的性能与响应速度成为了衡量其成功与否的重要标准之一。随着数据量的爆炸性增长和用户需求的日益多样化,如何高效地处理这些数据并快速响应用户请求成为了软件开发中亟待解决的问题。缓存技术,作为提升系统性能、优…...
LeetCode 637, 67, 399
文章目录 637. 二叉树的层平均值题目链接标签思路代码 67. 二进制求和题目链接标签思路代码 399. 除法求值题目链接标签思路导入value 属性find() 方法union() 方法query() 方法 代码 637. 二叉树的层平均值 题目链接 637. 二叉树的层平均值 标签 树 深度优先搜索 广度优先…...
如何压缩视频大小不改变画质?这5个视频压缩免费软件超好用!
如何压缩视频大小不改变画质?随着生活的水平逐步提高,视频流媒体服务越来越受欢迎。提供简短而引人注目的视频来展示您的产品或服务已成为一种出色的营销手段。然而,当您要准备导出最终视频时,可能会面临一个常见问题:…...
深入理解 Java 虚拟机第三版(周志明)
这次社招选的这本作为 JVM 资料查阅,记录一些重点 1. 虚拟机历史 Sun Classic VM :已退休 HotSpot VM:主流虚拟机,热点代码探测技术 Mobile / Embedded VM :移动端、嵌入式使用的虚拟机 2.2 运行时数据区域 程序计…...
算法 定长按组翻转链表
一、题目 已知一个链表的头部head,每k个结点为一组,按组翻转。要求返回翻转后的头部 k是一个正整数,它的值小于等于链表长度。如果节点总数不是k的整数倍,则剩余的结点保留原来的顺序。示例如下: (要求不…...
Python|GIF 解析与构建(5):手搓截屏和帧率控制
目录 Python|GIF 解析与构建(5):手搓截屏和帧率控制 一、引言 二、技术实现:手搓截屏模块 2.1 核心原理 2.2 代码解析:ScreenshotData类 2.2.1 截图函数:capture_screen 三、技术实现&…...
进程地址空间(比特课总结)
一、进程地址空间 1. 环境变量 1 )⽤户级环境变量与系统级环境变量 全局属性:环境变量具有全局属性,会被⼦进程继承。例如当bash启动⼦进程时,环 境变量会⾃动传递给⼦进程。 本地变量限制:本地变量只在当前进程(ba…...
Xshell远程连接Kali(默认 | 私钥)Note版
前言:xshell远程连接,私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...
Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)
引言:为什么 Eureka 依然是存量系统的核心? 尽管 Nacos 等新注册中心崛起,但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制,是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...
Swagger和OpenApi的前世今生
Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章,二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑: 🔄 一、起源与初创期:Swagger的诞生(2010-2014) 核心…...
Device Mapper 机制
Device Mapper 机制详解 Device Mapper(简称 DM)是 Linux 内核中的一套通用块设备映射框架,为 LVM、加密磁盘、RAID 等提供底层支持。本文将详细介绍 Device Mapper 的原理、实现、内核配置、常用工具、操作测试流程,并配以详细的…...
深入浅出深度学习基础:从感知机到全连接神经网络的核心原理与应用
文章目录 前言一、感知机 (Perceptron)1.1 基础介绍1.1.1 感知机是什么?1.1.2 感知机的工作原理 1.2 感知机的简单应用:基本逻辑门1.2.1 逻辑与 (Logic AND)1.2.2 逻辑或 (Logic OR)1.2.3 逻辑与非 (Logic NAND) 1.3 感知机的实现1.3.1 简单实现 (基于阈…...
深度学习之模型压缩三驾马车:模型剪枝、模型量化、知识蒸馏
一、引言 在深度学习中,我们训练出的神经网络往往非常庞大(比如像 ResNet、YOLOv8、Vision Transformer),虽然精度很高,但“太重”了,运行起来很慢,占用内存大,不适合部署到手机、摄…...
springboot 日志类切面,接口成功记录日志,失败不记录
springboot 日志类切面,接口成功记录日志,失败不记录 自定义一个注解方法 import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target;/***…...
vue3 daterange正则踩坑
<el-form-item label"空置时间" prop"vacantTime"> <el-date-picker v-model"form.vacantTime" type"daterange" start-placeholder"开始日期" end-placeholder"结束日期" clearable :editable"fal…...
