【问题标题】:Writing to frame buffer写入帧缓冲区
【发布时间】:2011-01-18 09:11:16
【问题描述】:

我正在使用带有内置图形加速器 GMA-HD 的 i5 内核,在 RHEL 6.0 操作系统上运行。 我需要测试图形驱动程序的图形加速功能(我发现它是我 PC 中的 i915)。 我使用以下代码(我从互联网上获得并进行了一些修改)写入帧缓冲区。

#include <unistd.h>
#include <stdio.h>
#include <fcntl.h>
#include <linux/fb.h>
#include <sys/mman.h>

int main()
{
        int fbfd = 0;
        struct fb_var_screeninfo vinfo;
        struct fb_fix_screeninfo finfo;
        long int screensize = 0;
         char *fbp = 0;
        int x = 0, y = 0;
        long int location = 0;
        int count ;

        /* Open the file for reading and writing */
        fbfd = open("/dev/fb0", O_RDWR);
        if (!fbfd) {
                printf("Error: cannot open framebuffer device.\n");
                exit(1);
        }
        printf("The framebuffer device was opened successfully.\n");
     /* Get fixed screen information */
        if (ioctl(fbfd, FBIOGET_FSCREENINFO, &finfo)) {
               printf("Error reading fixed information.\n");
                exit(2);
        }

        /* Get variable screen information */
        if (ioctl(fbfd, FBIOGET_VSCREENINFO, &vinfo)) {
                printf("Error reading variable information.\n");
                exit(3);
        }

        /* Figure out the size of the screen in bytes */
        screensize = vinfo.xres * vinfo.yres * vinfo.bits_per_pixel / 8;
        printf("\nScreen size is %d",screensize);
        printf("\nVinfo.bpp = %d",vinfo.bits_per_pixel);

        /* Map the device to memory */
        fbp = (char *)mmap(0, screensize, PROT_READ | PROT_WRITE, MAP_SHARED,fbfd, 0);
        if ((int)fbp == -1) {
                printf("Error: failed to map framebuffer device to memory.\n");
                exit(4);
        }
         printf("The framebuffer device was mapped to memory successfully.\n");


        x = 100; y = 100; /* Where we are going to put the pixel */

        /* Figure out where in memory to put the pixel */
        location = (x+vinfo.xoffset) * (vinfo.bits_per_pixel/8) + (y+vinfo.yoffset) * finfo.line_length;
        for(count = 1 ;count < 100 ;count++)
        {
                *(fbp + location) = 255;    /* Some blue */
                *(fbp + location + count) = 0; /* A little green */
                *(fbp + location + count + 1) = 0; /* A lot of red */
                *(fbp + location + count + 2) = 0; /* No transparency */
        }
        munmap(fbp, screensize);
        close(fbfd);
        return 0;
}

运行上述代码后,显示未发现任何变化,但“cat /dev/fb0”显示了一些数据。 有人可以解释为什么屏幕上什么都看不到吗? (我还发现 fb0 对应于帧缓冲区 'inteldrmfb' 。)

提前致谢,

Neeraj N.T

【问题讨论】:

  • 你看到屏幕闪过一次了吗? (在黑暗中拍摄)
  • 我会大胆猜测并说你刚刚写了一个红色强度为 255/65535 的像素。 Vinfo.bpp printf 的输出是什么?

标签: c linux framebuffer


【解决方案1】:

你没有增加位置!所以 255 只在第一个像素上,其他的都是 0。试试这个吧:

        location = (x+vinfo.xoffset) * (vinfo.bits_per_pixel/8) + (y+vinfo.yoffset) * finfo.line_length;
        for(count = 1 ;count < 100 ;count++)
        {
                *(fbp + location) = 255;    /* Some blue */
                *(fbp + location + 1) = 0; /* A little green */
                *(fbp + location + 2) = 0; /* A lot of red */
                *(fbp + location + 3) = 0; /* No transparency */
                location += 4;   
        }

但是,可能对测试正确的做法是使用directfb 它来了 进行一些帧缓冲性能测试

【讨论】:

  • 为什么是 -1 ?我犯了什么丑陋的错误吗?
  • 我必须在 aplha 因子(第 4 个字节)中添加一些不透明性。还需要增加位置。通过这样做,通过使用 'fbdump 捕获可以看到来自 '/dev/fb0' 的输出'(fbdump -fb /dev/fb0 > image.ppm)。要在我的屏幕上查看帧缓冲区输出,我必须调用 FBIO_PAN_DISPLAY ioctl 调用。
  • 我认为directfb 的正确链接现在是directfb.net 答案中的链接目前重定向到一个完全不同的站点。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-07
  • 2014-06-26
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多