Обычно я начинаю с малого с вводами и выводами, которые я знаю, должен работать. Затем поскольку я исправляю ошибки, я добавляю больше тестов для обеспечения вещей, которые я починил, тестируются. Это является органическим, и работает хорошо на меня.
можно ли протестировать слишком много? Вероятно, но, вероятно, лучше допустить ошибку на стороне осторожности в целом, хотя это будет зависеть от того, какова цена решения ответственных задач Ваше приложение.
Насколько я знаю после нескольких дней исследований, ioctl для вызова этой функции отсутствует. Я должен написать свой собственный системный вызов, желательно в модуле ядра. Или скопируйте алгоритм из исходного кода ядра и используйте его в пользовательском пространстве через nmaped память.
Вот код для запуска и закрытия FrameBuffer
class CFrameBuffer
{
void* m_FrameBuffer;
struct fb_fix_screeninfo m_FixInfo;
struct fb_var_screeninfo m_VarInfo;
int m_FBFD;
int InitFB()
{
int iFrameBufferSize;
/* Open the framebuffer device in read write */
m_FBFD = open(FB_NAME, O_RDWR);
if (m_FBFD < 0) {
printf("Unable to open %s.\n", FB_NAME);
return 1;
}
/* Do Ioctl. Retrieve fixed screen info. */
if (ioctl(m_FBFD, FBIOGET_FSCREENINFO, &m_FixInfo) < 0) {
printf("get fixed screen info failed: %s\n",
strerror(errno));
close(m_FBFD);
return 1;
}
/* Do Ioctl. Get the variable screen info. */
if (ioctl(m_FBFD, FBIOGET_VSCREENINFO, &m_VarInfo) < 0) {
printf("Unable to retrieve variable screen info: %s\n",
strerror(errno));
close(m_FBFD);
return 1;
}
/* Calculate the size to mmap */
iFrameBufferSize = m_FixInfo.line_length * m_VarInfo.yres;
printf("Line length %d\n", m_FixInfo.line_length);
/* Now mmap the framebuffer. */
m_FrameBuffer = mmap(NULL, iFrameBufferSize, PROT_READ | PROT_WRITE,
MAP_SHARED, m_FBFD,0);
if (m_FrameBuffer == NULL) {
printf("mmap failed:\n");
close(m_FBFD);
return 1;
}
return 0;
}
void CloseFB()
{
munmap(m_FrameBuffer,0);
close(m_FBFD);
}
};