- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试编写一个脚本,输出到 GPIO 引脚 1 秒。我发现最好的方法是通过 GPIO sysfs 命令,但我一直随机收到“Segmentation Fault”。这主要发生在设置方向时。在 bash 脚本中和通过终端运行时也会发生这种情况。
sudo echo 227 > /sys/class/gpio/export
sudo chmod 777 /sys/class/gpio/gpio227/*
sudo echo "out" > /sys/class/gpio/gpio227/direction # sometimes segmentation fault
sudo echo "1" > /sys/class/gpio/gpio227/value
# wait a bit
sudo echo "out" > /sys/class/gpio/gpio227/direction # almost always segmentation fault
sudo echo "0" > /sys/class/gpio/gpio227/value
我在装有 Ubuntu MATE 1.12.1 和 ARMv7 处理器版本 3 (v7l) 的 ODROID-XU4 上运行它。我也在运行无密码 sudo。
关于为什么会发生这种情况以及如何预防有什么建议吗?
编辑:我以为我最初是在 ODROID-XU3 上运行,但实际上是 XU4。
最佳答案
段错误通常发生在用户空间程序读取或写入非法内存地址时。对于简单且经过良好测试的程序(例如 echo),这种情况并不常见。
这可能是由内核/GPIO 驱动程序引起的,该驱动程序存在错误甚至可能是硬件损坏。我建议直接以 root 身份运行命令以确保它是导致段错误的 echo,然后使用 strace 确定段错误是否总是发生在同一位置...
关于linux - 段错误 sysfs gpio linux odroid,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43824217/
我之前已经发布了查询,我正在重复同样的问题我想修改 kernel2.6 中内置的 igmpv3 (Linux)。-- 以便它从文件中读取一个值并适本地决定内部的保留 (res 1) 值主机发送的igm
在内核 4.0 上,当单步执行 sysfs_create_bin_file 的内核源代码时,我注意到它传递给了 sysfs_add_file(kobj->sd, &attr->attr, true);
我只是想为/sys 文件系统中的设备添加一个简单的属性。看起来很简单,但没有提到任何辅助方法 here或 here是从内核导出的,所以我不能从模块中使用它们?我一定遗漏了什么,任何人都可以提供一些见解
所以我一直在阅读 Linux API(系统调用和 libc)以及设备 ioctls,通过 create(dev_name) 和 ioctl(device_file_handle) 调用 ioctls
我想将大于 1024 个字符的字符串传递到我的模块(文件系统)。由于内核参数限制为 1024 个字符,someone recommended改为使用 sysfs。 我试图包括 this example
在用户空间中,我可以echo noop >/sys/block/sda/queue/scheduler。 如何在内核模块中做同样的事情? 我期待这样的事情(伪代码): struct dentry* e
我正在编写一个检查电池容量的守护进程。这是用于运行 Linux 的太阳能嵌入式设备。我读过使用 sleep() 是个坏主意在守护进程中,因此我正在尝试使用事件。所以我写了一些 PoC,但我没有收到任何
最近我正在查看 kobjects 和 sysfs 的内核。 我知道/理解以下.. 所有内核对象使用地址 > 0x80000000 kobjects 也不异常(exception) sysfs 只不过是
处理 sysfs阅读我需要创建一个 show添加到 kobj_attribute 的函数结构体。 the function is defined as的原型(prototype): ssize_t (
我已经成功地向我的设备驱动程序添加了一个设备属性,但在我发现的所有示例中,该属性都用于向内核注入(inject)数据,而我的目标是从内核导出一些数据以使其可见在用户空间。从内核空间写入该文件的正确方法
源自this question (和 my solution ),我已经意识到可能存在死锁,但我不明白为什么以及如何避免它。 简而言之,内核空间中有一个信号量,内核模块(它们实际上是在内核空间中运行的
我如何从用户应用程序读取 sysfs 属性。它与 cat 命令的内容类似。比如我有一个标签是亮度。如何获取亮度标签的值?因为我需要从我的应用程序读取 USB 信息,并且我看到它们被导出到 sysfs,
如何使用 sysfs 检测我的硬件模块(例如 MSR)是否执行事件或中断? 最佳答案 你的问题有点含糊。 对于中断,您可以查看 cat/proc/interrupts 的输出,看看您的驱动程序的中断计
我想知道..实际上什么是 sysfs 中的属性文件,..为什么我们需要在 sysfs 目录中为某些驱动程序而不是某些驱动程序创建属性文件.. 我们什么时候真正需要它? 我已经阅读了 LDD3 和其他一
我正在为多个定制硬件编写驱动程序。所有设备都通过 PCIe 连接到主机。为了方便起见,我想将所有这些自定义设备组合到一个 sysfs 类中(我认为这是可以接受的事情?)。不幸的是,LDD3 中的信息已
在我正在使用的设备上,我可以写入 /sys/class/leds 来打开/关闭 LED 灯。我可以在我的代码中保持文件打开并仅在进程退出时关闭,还是应该仅在需要写入文件时打开文件? 最佳答案 是的。这
我正在编写一个 linux 设备驱动程序,除其他外,它在 sysfs 中公开了一个只读二进制属性,其接口(interface)是 static ssize_t read_dump_fifo(struc
我正在尝试学习如何编写 sysfs 模块,但对基本的初始化感到困惑。在 this查看 kobject.h 文件的文档,有几个与创建 sysfs 条目相关的不同函数。 从外观上看,函数“kobject_
我正在使用 C 文件 IO 从 linux 中的 sysfs 接口(interface)读取值。寄存器的路径和样例值如下: cat /sys/class/powercap/intel-rapl/int
我的 FPGA 中有一个带有多个 I/O 寄存器的通用 AXI 从设备。我想使用 sysfs 接口(interface)访问我的寄存器。对于我想要访问的每个寄存器,我都创建了一个 _show 和一个
我是一名优秀的程序员,十分优秀!