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