framebuffer_service.c revision 04bee29ad979ca770677338e343869a0d5662cfb
1dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/*
2dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
3dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *
4dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
5dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * you may not use this file except in compliance with the License.
6dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * You may obtain a copy of the License at
7dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *
8dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
9dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *
10dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
11dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
12dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * See the License for the specific language governing permissions and
14dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * limitations under the License.
15dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project */
16dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
17dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <stdlib.h>
18dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <stdio.h>
19dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <unistd.h>
20dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <string.h>
21dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <fcntl.h>
22dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
23414ff7d98ac8d7610a26206335954ad15f43f3acDavid 'Digit' Turner#include "fdevent.h"
24dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include "adb.h"
25dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
26dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <linux/fb.h>
27dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <sys/ioctl.h>
28dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <sys/mman.h>
29dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
30dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* TODO:
31dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** - sync with vsync to avoid tearing
32dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
33dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
34dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid framebuffer_service(int fd, void *cookie)
35dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
36dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    struct fb_var_screeninfo vinfo;
3704bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    int fb, offset;
3804bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    char x[256];
39dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
40dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned fbinfo[4];
4104bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    unsigned i, bytespp;
42dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
43dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fb = open("/dev/graphics/fb0", O_RDONLY);
44dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    if(fb < 0) goto done;
45dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
46dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    if(ioctl(fb, FBIOGET_VSCREENINFO, &vinfo) < 0) goto done;
47dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fcntl(fb, F_SETFD, FD_CLOEXEC);
48dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
4904bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    bytespp = vinfo.bits_per_pixel / 8;
5004bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin
5104bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    fbinfo[0] = vinfo.bits_per_pixel;
5204bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    fbinfo[1] = vinfo.xres * vinfo.yres * bytespp;
53dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fbinfo[2] = vinfo.xres;
54dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fbinfo[3] = vinfo.yres;
55dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
5604bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    /* HACK: for several of our 3d cores a specific alignment
5704bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin     * is required so the start of the fb may not be an integer number of lines
5804bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin     * from the base.  As a result we are storing the additional offset in
5904bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin     * xoffset. This is not the correct usage for xoffset, it should be added
6004bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin     * to each line, not just once at the beginning */
6104bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    offset = vinfo.xoffset * bytespp;
6204bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin
6304bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    offset += vinfo.xres * vinfo.yoffset * bytespp;
64dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
6504bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    if(writex(fd, fbinfo, sizeof(fbinfo))) goto done;
66dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
6704bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    lseek(fb, offset, SEEK_SET);
6804bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    for(i = 0; i < fbinfo[1]; i += 256) {
6904bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin      if(readx(fb, &x, 256)) goto done;
7004bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin      if(writex(fd, &x, 256)) goto done;
71dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    }
72dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
7304bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    if(readx(fb, &x, fbinfo[1] % 256)) goto done;
7404bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin    if(writex(fd, &x, fbinfo[1] % 256)) goto done;
7504bee29ad979ca770677338e343869a0d5662cfbRebecca Schultz Zavin
76dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectdone:
77dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    if(fb >= 0) close(fb);
78dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    close(fd);
79dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project}
80