ubuntun安装mmap
时间: 2023-11-29 15:05:03 浏览: 71
mmap 是一个系统调用,用于将文件映射到进程地址空间中的一段内存区域,可以用于内存映射文件、实现共享内存等。在 Ubuntu 上安装 mmap 是不需要单独安装的,因为它已经是 Linux 内核的一部分。
如果你想在 C 语言中使用 mmap 函数,需要在程序中包含头文件 `<sys/mman.h>`,并链接 `-lrt` 库。你可以使用以下命令安装该库:
```
sudo apt-get install librt-dev
```
安装完成后,在编译时加上 `-lrt` 选项即可。
相关问题
UBUNTU安装音频驱动
在Ubuntu中安装音频驱动可以使用OSS替换掉ALSA。具体步骤如下:
1. 确认Ubuntu开机时能听到“噔噔噔”的开机音乐。
2. 到http://www.opensound.com/download.cgi上下载官方驱动。
3. 安装OSS的deb,会提示卸载snd模块错误,直接忽略错误。
4. 在/etc/pulse/default.pa文件最后面添加一行:load-module module-oss device=”/dev/dsp” sink_name=output source_name=input mmap=0。
5. 安装gstreamer0.10-plugins-bad。
6. 在/etc/asound.conf文件中添加如下代码:
pcm.oss {
type oss
device /dev/dsp
}
pcm.!default {
type oss
device /dev/dsp
}
ctl.oss {
type oss
device /dev/mixer
}
ctl.!default {
type oss
device /dev/mixer
}
7. 执行sudo dpkg-reconfigure linux-sound-base,选择OSS,然后重启Ubuntu。
8. 开机时,仍然能听见“噔噔噔”开机音,且能看到“dev/dsp”设备,说明已经替换成功。
ubuntu ffmpeg 摄像头采集 位图 代码
以下是基于 Ubuntu 系统的使用 FFmpeg 进行摄像头采集并保存位图的代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>
#include <errno.h>
#include <sys/ioctl.h>
#include <sys/mman.h>
#include <linux/videodev2.h>
#define DEVICE "/dev/video0"
#define IMAGE_WIDTH 640
#define IMAGE_HEIGHT 480
int main(int argc, char **argv) {
int fd = 0;
struct v4l2_capability cap;
struct v4l2_format fmt;
struct v4l2_requestbuffers req;
struct v4l2_buffer buf;
void *buffer_start = NULL;
FILE *fp = NULL;
char filename[32] = {0};
int n_buffers = 0;
int ret = 0;
// 打开视频设备
fd = open(DEVICE, O_RDWR);
if (-1 == fd) {
perror("open");
return errno;
}
// 查询设备能力
ret = ioctl(fd, VIDIOC_QUERYCAP, &cap);
if (-1 == ret) {
perror("ioctl(VIDIOC_QUERYCAP)");
return errno;
}
// 设置视频格式
memset(&fmt, 0, sizeof(fmt));
fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
fmt.fmt.pix.width = IMAGE_WIDTH;
fmt.fmt.pix.height = IMAGE_HEIGHT;
fmt.fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV;
fmt.fmt.pix.field = V4L2_FIELD_INTERLACED;
ret = ioctl(fd, VIDIOC_S_FMT, &fmt);
if (-1 == ret) {
perror("ioctl(VIDIOC_S_FMT)");
return errno;
}
// 请求分配内存
memset(&req, 0, sizeof(req));
req.count = 4;
req.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
req.memory = V4L2_MEMORY_MMAP;
ret = ioctl(fd, VIDIOC_REQBUFS, &req);
if (-1 == ret) {
perror("ioctl(VIDIOC_REQBUFS)");
return errno;
}
// 映射缓冲区
buffer_start = mmap(NULL, req.count * fmt.fmt.pix.sizeimage,
PROT_READ | PROT_WRITE, MAP_SHARED,
fd, 0);
if (MAP_FAILED == buffer_start) {
perror("mmap");
return errno;
}
// 缓存入队
for (n_buffers = 0; n_buffers < req.count; ++n_buffers) {
memset(&buf, 0, sizeof(buf));
buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
buf.memory = V4L2_MEMORY_MMAP;
buf.index = n_buffers;
ret = ioctl(fd, VIDIOC_QBUF, &buf);
if (-1 == ret) {
perror("ioctl(VIDIOC_QBUF)");
return errno;
}
}
// 开始采集
enum v4l2_buf_type type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
ret = ioctl(fd, VIDIOC_STREAMON, &type);
if (-1 == ret) {
perror("ioctl(VIDIOC_STREAMON)");
return errno;
}
// 采集图像
for (int i = 0; i < 10; ++i) {
memset(&buf, 0, sizeof(buf));
buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
buf.memory = V4L2_MEMORY_MMAP;
ret = ioctl(fd, VIDIOC_DQBUF, &buf);
if (-1 == ret) {
perror("ioctl(VIDIOC_DQBUF)");
return errno;
}
// 保存位图
sprintf(filename, "image%d.bmp", i);
fp = fopen(filename, "wb");
fwrite(buffer_start, fmt.fmt.pix.sizeimage, 1, fp);
fclose(fp);
// 重新入队
ret = ioctl(fd, VIDIOC_QBUF, &buf);
if (-1 == ret) {
perror("ioctl(VIDIOC_QBUF)");
return errno;
}
}
// 停止采集
ret = ioctl(fd, VIDIOC_STREAMOFF, &type);
if (-1 == ret) {
perror("ioctl(VIDIOC_STREAMOFF)");
return errno;
}
// 取消映射
munmap(buffer_start, req.count * fmt.fmt.pix.sizeimage);
// 关闭设备
close(fd);
return 0;
}
```
注意:在运行该代码之前,需要先安装 FFmpeg 和视频设备的驱动。
阅读全文