今天调试网络服务的时候为了区分,修改了原有服务名称,同时新增了两个服务。

系统运行的时候报错找不到对应的服务

init: no such service 'wpa_supplicant_common'

cat init.rc文件,查看对应的服务是否存在对应的rc文件。

# wifi service
# wifi sta service
service wpa_supplicant_common /system/bin/wpa_supplicant p2p_supported=false \
-iwlan0 -Dnl80211 -c/data/misc/wifi/wpa_supplicant.conf \
-I/system/etc/wifi/wpa_supplicant_overlay.conf \
-O/data/misc/wifi/sockets -e/data/misc/wifi/entropy.bin
class main
socket wpa_wlan0 dgram 660 wifi wifi
disabled
oneshot # wifi sta p2p concurrent service
service p2p_supplicant_common /system/bin/wpa_supplicant p2p_supported=true \
-ip2p0 -Dnl80211 -c/data/misc/wifi/p2p_supplicant.conf \
-e/data/misc/wifi/entropy.bin -N \
-iwlan0 -Dnl80211 -c/data/misc/wifi/wpa_supplicant.conf \
-I/system/etc/wifi/wpa_supplicant_overlay.conf \
-O/data/misc/wifi/sockets
class main
socket wpa_wlan0 dgram 660 wifi wifi
disabled
oneshot # for rtl wifi
service p2p_supplicant_rtl /system/bin/wpa_supplicant \
-ip2p0 -Dnl80211 -c/data/misc/wifi/p2p_supplicant.conf -e/data/misc/wifi/entropy.bin -N \
-iwlan0 -Dnl80211 -c/data/misc/wifi/wpa_supplicant.conf
class main
socket wpa_wlan0 dgram 660 wifi wifi
group wifi inet
disabled
oneshot service wpa_supplicant_rtl /system/bin/wpa_supplicant \
-iwlan0 -Dnl80211 -c/data/misc/wifi/wpa_supplicant.conf \
-e/data/misc/wifi/entropy.bin
class main
socket wpa_wlan0 dgram 660 wifi wifi
group wifi inet
disabled
oneshot

确认服务是已经添加到了对应的文件。

手动启动服务再测试一下,同样显示找不到对应的服务。

setprop ctl.start wpa_supplicant_common
[ 126.046251] init: no such service 'wpa_supplicant_common'
dolphin-fvd-p1:/ # setprop ctl.start wpa_supplicant_rtl
[ 136.016232] init: no such service 'wpa_supplicant_rtl'
.589306] init: no such service 'wpa_supplicant_common'

查看系统开机的init log,提示无效的服务名。

[    1.816434] init: /init.sun8iw7p1.rc: 291: invalid service name 'wpa_supplicant_common'
[ 1.825430] init: /init.sun8iw7p1.rc: 304: invalid service name 'p2p_supplicant_common'
[ 1.834409] init: /init.sun8iw7p1.rc: 313: invalid service name 'p2p_supplicant_rtl'
[ 1.843091] init: /init.sun8iw7p1.rc: 322: invalid service name 'wpa_supplicant_rtl'

原本的服务名是

wpa_supplicant
p2p_supplicant

但是为了适应不同的wifi模块所以新加后缀方便区分。

查看init源码,检查服务名称invalid的判定规则。

bool ServiceParser::ParseSection(const std::vector<std::string>& args,
789 std::string* err) {
790 if (args.size() < 3) {
791 *err = "services must have a name and a program";
792 return false;
793 }
794
795 const std::string& name = args[1];
796 if (!IsValidName(name)) {
797 *err = StringPrintf("invalid service name '%s'", name.c_str());
798 return false;
799 }
800
801 std::vector<std::string> str_args(args.begin() + 2, args.end());
802 service_ = std::make_unique<Service>(name, "default", str_args);
803 return true;
804 } bool ServiceParser::IsValidName(const std::string& name) const {
819 if (name.size() > 16) {
820 return false;
821 }
822 for (const auto& c : name) {
823 if (!isalnum(c) && (c != '_') && (c != '-')) {
824 return false;
825 }
826 }
827 return true;
828 }

从上可以看出android的服务名称限制如下:

1、必须小于等于16个字符。

2、只允许数字、字母及下划线、中划线。

查看修改后的服务名称明显都超出了16个字符,所以只需要服务名称再16个字符内即可。

[    1.816434] init: /init.sun8iw7p1.rc: 291: invalid service name 'wpa_supplicant_common'
[ 1.825430] init: /init.sun8iw7p1.rc: 304: invalid service name 'p2p_supplicant_common'
[ 1.834409] init: /init.sun8iw7p1.rc: 313: invalid service name 'p2p_supplicant_rtl'
[ 1.843091] init: /init.sun8iw7p1.rc: 322: invalid service name 'wpa_supplicant_rtl'

重新修改后名称如下,验证已解决。

# wifi service
# wifi sta service
service wpa_supp_com /system/bin/wpa_supplicant p2p_supported=false \
............. # wifi sta p2p concurrent service
service p2p_supp_com /system/bin/wpa_supplicant p2p_supported=true \
....................
# for rtl wifi
service p2p_supp_rtl /system/bin/wpa_supplicant \
............. service wpa_supp_rtl /system/bin/wpa_supplicant \
......................

Android 服务名称规则invalid service name 限制16字符以内的更多相关文章

  1. Android 服务类Service 的详细学习

    http://blog.csdn.net/vipzjyno1/article/details/26004831 Android服务类Service学习四大组建   目录(?)[+] 什么是服务 服务有 ...

  2. Android Service 服务(一)—— Service .

    http://blog.csdn.net/ithomer/article/details/7364024 一. Service简介 Service是android 系统中的四大组件之一(Activit ...

  3. Android服务Service总结

    转自 http://blog.csdn.net/liuhe688/article/details/6874378 富貴必從勤苦得,男兒須讀五車書.唐.杜甫<柏學士茅屋> 作为程序员的我们, ...

  4. Java乔晓松-android的四大组件之一Service(服务的绑定)

    android的四大组件之一Service(服务的绑定) 怎么绑定服务,又怎么解除服务,代码如下: MainActivity.java源码: package com.example.lesson14_ ...

  5. Android服务Service具体解释(作用,生命周期,AIDL)系列文章-为什么须要服务呢?

    Android服务Service具体解释(作用,生命周期,AIDL) 近期沉迷于上班,没有时间写博客了.解衣入睡,未眠.随起床写一篇博客压压惊! ##我们android系统为什么须要服务Service ...

  6. Android服务Service

    安卓Service服务 一    Service简介 Service是运行在后台的,没有界面的,用来处理耗时比较长的.Service不是一个单独的进程,也不是一个单独的线程. Service有两种类型 ...

  7. Kubernetes K8S之Pod跨namespace名称空间访问Service服务

    Kubernetes的两个Service(ServiceA.ServiceB)和对应的Pod(PodA.PodB)分别属于不同的namespace名称空间,现需要PodA和PodB跨namespace ...

  8. Android 代码混淆规则

    1. Proguard介绍 Android SDK自带了混淆工具Proguard.它位于SDK根目录toolsproguard下面.ProGuard是一个免费的Java类文件收缩,优化,混淆和预校验器 ...

  9. Android 四大组件之二(Service)

    service可以在和多场合的应用中使用,比如播放多媒体的时候用户启动了其他Activity这个时候程序要在后台继续播放,比如检测SD卡上文件的变化,再或者在后台记录你地理信息位置的改变等等,总之服务 ...

随机推荐

  1. 线程调用BeginInvoke

    线程异步调用 Thread objThread = new Thread(new ThreadStart(delegate             {                 Dispatch ...

  2. CI框架页面打开空白,无报错为解决方法新环境

    1.打开错误显示,可以在控制controllers的首页入口加入以下代码,查看错误 error_reporting(-1); ini_set('display_errors', 1); //插入显示所 ...

  3. Jmeter线程组设置

    添加线程组:右键测试计划->添加->Threads->线程组 左侧树形标签栏中,显示标签信息. 选中线程组,右侧内容栏中显示线程组的相关信息. 名称:可以给线程组设置一个个性化的命名 ...

  4. Python调用函数带括号和不带括号的区别

    1.不带括号时,调用的是这个函数本身 ,是整个函数体,是一个函数对象,不需等该函数执行完成 2.带括号(此时必须传入需要的参数),调用的是函数的return结果,需要等待函数执行完成的结果 如果函数本 ...

  5. P4480-[BJWC2018]餐巾计划问题【三分,贪心】

    正题 题目链接:https://www.luogu.com.cn/problem/P4480 题目大意 \(n\)天,第\(i\)天需要\(a_i\)个餐巾. 每个餐巾价格为\(p\),使用完后有两种 ...

  6. Kettle启动时报错Cannot create java virtual machine & A java exception has occurred

    开源免费--最喜欢的四个字没有之一 1.官网下载 https://sourceforge.net/projects/pentaho/files/Data%20Integration/ 下载完后,解压即 ...

  7. 通过Python收集MySQL MHA 部署及运行状态信息的功能实现

    一. 背景介绍 当集团的MySQL数据库实例数达到2000+.MHA集群规模数百个时,对MHA的及时.高效管理是DBA必须面对的一个挑战.MHA 集群 节点信息 和 运行状态 是管理的基础.本篇幅主要 ...

  8. kubelet源码分析——监控Pod变更

    前言 前文介绍Pod无论是启动时还是关闭时,处理是由kubelet的主循环syncLoop开始执行逻辑,而syncLoop的入参是一条传递变更Pod的通道,显然syncLoop往后的逻辑属于消费者一方 ...

  9. apiserver源码分析——处理请求

    前言 上一篇说道k8s-apiserver如何启动,本篇则介绍apiserver启动后,接收到客户端请求的处理流程.如下图所示 认证与授权一般系统都会使用到,认证是鉴别访问apiserver的请求方是 ...

  10. 微服务Cloud整体聚合工程创建过程

    1.父工程创建及使用 使用idea开发工具,选择File-new- project ,在选项中选择Maven工程,选择jdk版本1.8,勾选maven-archetype-site,点击next,输入 ...