/* UIKit Tools - command-line utilities for UIKit
* Copyright (C) 2018-2019 Sam Bingner
* Copyright (C) 2008-2012 Jay Freeman (saurik)
*/
/* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
/* Modified BSD License {{{ */
/*
* Redistribution and use in source and binary
* forms, with or without modification, are permitted
* provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the
* above copyright notice, this list of conditions
* and the following disclaimer.
* 2. Redistributions in binary form must reproduce the
* above copyright notice, this list of conditions
* and the following disclaimer in the documentation
* and/or other materials provided with the
* distribution.
* 3. The name of the author may not be used to endorse
* or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/* }}} */
#include
#include
#include
#include
#include
#if 0
set -e
sdk=/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS4.3.sdk
/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/g++ \
-Wall -fmessage-length=0 \
-arch armv6 -miphoneos-version-min=2.0 \
-isysroot "${sdk}" -I. -F"${sdk}"/System/Library/PrivateFrameworks \
-framework IOKit -framework IOMobileFramebuffer \
-o iomfsetgamma iomfsetgamma.c
ldid iomfsetgamma
exit 0
#endif
typedef void *IOMobileFramebufferRef;
kern_return_t IOMobileFramebufferOpen(io_service_t, mach_port_t, void *, IOMobileFramebufferRef *);
kern_return_t IOMobileFramebufferSetGammaTable(IOMobileFramebufferRef, void *);
kern_return_t (*$IOMobileFramebufferGetGammaTable)(IOMobileFramebufferRef, void *);
#define _assert(test) \
if (!(test)) { \
fprintf(stderr, "_assert(%s)\n", #test); \
exit(-1); \
}
int main(int argc, char *argv[]) {
if (argc != 4) {
fprintf(stderr, "usage: iomfsetgamma \n");
fprintf(stderr, " example: 1.00 0.78 0.64\n");
return 1;
}
unsigned rs = strtod(argv[1], NULL) * 0x100;
_assert(rs <= 0x100);
unsigned gs = strtod(argv[2], NULL) * 0x100;
_assert(gs <= 0x100);
unsigned bs = strtod(argv[3], NULL) * 0x100;
_assert(bs <= 0x100);
kern_return_t error;
mach_port_t self = mach_task_self();
io_service_t service = 0;
if (service == 0)
service = IOServiceGetMatchingService(kIOMasterPortDefault, IOServiceMatching("AppleCLCD"));
if (service == 0)
service = IOServiceGetMatchingService(kIOMasterPortDefault, IOServiceMatching("AppleH1CLCD"));
if (service == 0)
service = IOServiceGetMatchingService(kIOMasterPortDefault, IOServiceMatching("AppleM2CLCD"));
_assert(service != 0);
IOMobileFramebufferRef fb;
error = IOMobileFramebufferOpen(service, self, 0, &fb);
_assert(error == 0);
uint32_t data[0xc00 / sizeof(uint32_t)];
memset(data, 0, sizeof(data));
FILE *file = fopen("/tmp/.iomfgamma.dat", "rb");
if (file == NULL) {
$IOMobileFramebufferGetGammaTable = dlsym(RTLD_DEFAULT, "IOMobileFramebufferGetGammaTable");
_assert($IOMobileFramebufferGetGammaTable != NULL);
error = $IOMobileFramebufferGetGammaTable(fb, data);
_assert(error == 0);
file = fopen("/tmp/.iomfgamma.dat", "wb");
_assert(file != NULL);
fwrite(data, 1, sizeof(data), file);
fclose(file);
file = fopen("/tmp/.iomfgamma.dat", "rb");
_assert(file != NULL);
}
fread(data, 1, sizeof(data), file);
fclose(file);
size_t i;
for (i = 0; i != 256; ++i) {
int j = 255 - i;
int r = j * rs >> 8;
int g = j * gs >> 8;
int b = j * bs >> 8;
data[j + 0x000] = data[r + 0x000];
data[j + 0x100] = data[g + 0x100];
data[j + 0x200] = data[b + 0x200];
}
error = IOMobileFramebufferSetGammaTable(fb, data);
_assert(error == 0);
return 0;
}