【问题标题】:glGenBuffers crashing with Segmentation fault [closed]glGenBuffers 因分段错误而崩溃 [关闭]
【发布时间】:2014-11-03 05:35:24
【问题描述】:

我不明白为什么它总是在 glGenBuffers 上崩溃

GDB 回溯给了我这个

#0  0x00000000 in ?? ()
#1  0x0808701d in setupBuffers () at main_scene.cc:250
#2  0x08088cf8 in main (argc=1, argv=0xbffff3c4) at main_scene.cc:694

这是我的 main()

int main(int argc, char **argv) {

    glutInit(&argc, argv);
    glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH);
    glutInitWindowSize(WINDOW_WIDTH, WINDOW_HEIGHT);
    glutInitWindowPosition(20, 20);

    glutCreateWindow("New Window");

    GLenum err = glewInit();
    if (GLEW_OK != err)
    {
        /* glewInit failed, something is seriously wrong */
        fprintf(stderr, "Error: %s\n", glewGetErrorString(err));
    }
    setupBuffers();

    ...

    /* set callback functions  */
    glutReshapeFunc (reshape);
    glutDisplayFunc (display);
    glutKeyboardFunc(input);
    glutIdleFunc    (idle);

    glutMainLoop();
    return 0;
}

这是我的 setupBuffers() 方法

void setupBuffers() {
    GLenum errorCode = 0;

    // Normal
    size_t normal_buffer_size = 0; // Calc buffer size needed
    for (size_t i = 0; i < shapes.size(); i++) {
        normal_buffer_size += sizeof(float) * shapes[i].mesh.normals.size();
    }

    glGenBuffers(1, &normal_buffer);
    glBindBuffer(GL_ARRAY_BUFFER, normal_buffer);
    glBufferData(GL_ARRAY_BUFFER, normal_buffer_size, NULL, GL_STATIC_DRAW);
    normal_buffer_size = 0; 
    for (size_t i = 0; i < shapes.size(); i++) {
        glBufferSubData(GL_ARRAY_BUFFER, normal_buffer_size, sizeof(float) * shapes[i].mesh.normals.size(), &shapes[i].mesh.normals[0]); // Add the buffer data
        normal_buffer_size += sizeof(float) * shapes[i].mesh.normals.size();
    }
    glBindBuffer(GL_ARRAY_BUFFER, 0);

    ...

    // draw multiple objects with one draw call
    glGenVertexArrays(1, &vertex_array_object);
    glBindVertexArray(vertex_array_object);
    glBindBuffer(GL_ARRAY_BUFFER, normal_buffer);
    glBindBuffer(GL_ARRAY_BUFFER, vertex_buffer);
    glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, index_buffer);
    glBindVertexArray(0);

    errorCode = glGetError();
    if (errorCode != 0) {
        fprintf(stderr, "Error data: %s, code %d\n", glewGetErrorString(errorCode), errorCode);
    }
}

这是我正在使用的全局变量

GLuint vertex_buffer;
GLuint index_buffer;
GLuint normal_buffer;
GLuint texture_buffer;
GLuint vertex_array_object;

glxinfo 的输出(以备不时之需)

name of display: localhost:11.0
display: localhost:11  screen: 0
direct rendering: No (If you want to find out why, try setting LIBGL_DEBUG=verbose)
server glx vendor string: SGI
server glx version string: 1.4
server glx extensions:
GLX_ARB_multisample, GLX_EXT_import_context, GLX_EXT_visual_info,
GLX_EXT_visual_rating, GLX_MESA_copy_sub_buffer, GLX_OML_swap_method,
GLX_SGI_make_current_read, GLX_SGI_swap_control, GLX_SGIS_multisample,
GLX_SGIX_fbconfig, GLX_SGIX_pbuffer
client glx vendor string: ATI
client glx version string: 1.4
client glx extensions:
GLX_ARB_create_context, GLX_ARB_create_context_profile,
GLX_ARB_get_proc_address, GLX_ARB_multisample, GLX_EXT_import_context,
GLX_EXT_swap_control, GLX_EXT_visual_info, GLX_EXT_visual_rating,
GLX_MESA_allocate_memory, GLX_MESA_copy_sub_buffer, GLX_MESA_swap_control,
GLX_MESA_swap_frame_usage, GLX_NV_swap_group, GLX_OML_swap_method,
GLX_SGI_make_current_read, GLX_SGI_swap_control, GLX_SGI_video_sync,
GLX_SGIS_multisample, GLX_SGIX_fbconfig, GLX_SGIX_pbuffer,
GLX_SGIX_swap_barrier, GLX_SGIX_swap_group, GLX_SGIX_visual_select_group,
GLX_EXT_texture_from_pixmap, GLX_EXT_framebuffer_sRGB,
GLX_ARB_fbconfig_float, GLX_AMD_gpu_association, GLX_EXT_buffer_age
GLX version: 1.4
GLX extensions:
GLX_ARB_get_proc_address, GLX_ARB_multisample, GLX_EXT_import_context,
GLX_EXT_visual_info, GLX_EXT_visual_rating, GLX_MESA_copy_sub_buffer,
GLX_OML_swap_method, GLX_SGI_make_current_read, GLX_SGI_swap_control,
GLX_SGIS_multisample, GLX_SGIX_fbconfig, GLX_SGIX_pbuffer
OpenGL vendor string: ATI Technologies Inc.
OpenGL renderer string: AMD Radeon HD 7800 Series
OpenGL version string: 1.4 (4.4.12967 Compatibility Profile Context 14.200.1004.0)
OpenGL extensions:
GL_ARB_depth_texture, GL_ARB_draw_buffers, GL_ARB_fragment_program,
GL_ARB_fragment_program_shadow, GL_ARB_imaging, GL_ARB_multisample,
GL_ARB_multitexture, GL_ARB_occlusion_query, GL_ARB_point_parameters,
GL_ARB_point_sprite, GL_ARB_shadow, GL_ARB_shadow_ambient,
GL_ARB_texture_border_clamp, GL_ARB_texture_compression,
GL_ARB_texture_cube_map, GL_ARB_texture_env_add,
GL_ARB_texture_env_combine, GL_ARB_texture_env_crossbar,
GL_ARB_texture_env_dot3, GL_ARB_texture_mirrored_repeat,
GL_ARB_texture_non_power_of_two, GL_ARB_texture_rectangle,
GL_ARB_transpose_matrix, GL_ARB_vertex_buffer_object,
GL_ARB_vertex_program, GL_ARB_window_pos, GL_ARB_shader_objects,
GL_ARB_vertex_shader, GL_ARB_fragment_shader, GL_ARB_framebuffer_object,
GL_ARB_geometry_shader4, GL_EXT_abgr, GL_EXT_bgra, GL_EXT_blend_color,
GL_EXT_blend_equation_separate, GL_EXT_blend_func_separate,
GL_EXT_blend_minmax, GL_EXT_blend_subtract, GL_EXT_copy_texture,
GL_EXT_draw_range_elements, GL_EXT_fog_coord, GL_EXT_framebuffer_object,
GL_EXT_multi_draw_arrays, GL_EXT_packed_pixels, GL_EXT_point_parameters,
GL_EXT_rescale_normal, GL_EXT_secondary_color,
GL_EXT_separate_specular_color, GL_EXT_shadow_funcs, GL_EXT_stencil_wrap,
GL_EXT_subtexture, GL_EXT_texture3D, GL_EXT_texture_compression_s3tc,
GL_EXT_texture_edge_clamp, GL_EXT_texture_env_add,
GL_EXT_texture_env_combine, GL_EXT_texture_env_dot3,
GL_EXT_texture_filter_anisotropic, GL_EXT_texture_lod,
GL_EXT_texture_lod_bias, GL_EXT_texture_mirror_clamp,
GL_EXT_texture_object, GL_EXT_texture_rectangle, GL_EXT_vertex_array,
GL_EXT_histogram, GL_EXT_framebuffer_blit, GL_EXT_framebuffer_multisample,
GL_EXT_geometry_shader4, GL_EXT_gpu_shader4, GL_ATI_draw_buffers,
GL_ATI_texture_env_combine3, GL_ATI_texture_float,
GL_ATI_texture_mirror_once, GL_ATIX_texture_env_combine3,
GL_IBM_texture_mirrored_repeat, GL_INGR_blend_func_separate,
GL_SGIS_generate_mipmap, GL_SGIS_texture_border_clamp,
GL_SGIS_texture_edge_clamp, GL_SGIS_texture_lod, GL_SGIX_shadow_ambient,
GL_SUN_multi_draw_arrays, GL_ARB_texture_float

哦,顺便说一句,我使用的是静态 glew 库。

【问题讨论】:

    标签: c++ opengl crash segmentation-fault glew


    【解决方案1】:

    从你的问题来看,不太清楚你使用的是哪个操作系统进行开发,但根据 gdb 的使用情况,我会猜测你使用的是 Linux。

    当您获得 OpenGL 1.4 兼容模式(可能是软件渲染堆栈)时,您的显卡硬件支持 OpenGL 4.2。这通常在未安装显卡驱动程序时发生(在 Linux 中,您可能使用开源驱动程序而不是供应商提供的闭源驱动程序),但如果您尝试在远程会话中运行 OpenGL 程序,也会发生这种情况。如果您尝试这样做,安装 VirtualGL 可能会有所帮助 (http://www.virtualgl.org/)。

    【讨论】:

    • 是的,这就是问题所在,我试图通过 ssh 在 uni lab 计算机上运行我的 opengl 程序。计划在校园内工作
    【解决方案2】:

    您没有正确处理 GLEW 未初始化的情况。打印一条消息后,您只需继续执行您的程序,然后可能会在崩溃中运行。

    但更糟糕的是:您不会检查您想要使用的特定功能或扩展是否真的可用。 glGenBuffers 实际上是 OpenGL-1-5 的一个函数,而您只能获得 OpenGL-1.4 上下文,至少版本字符串是这样说的(这很奇怪,因为显然您的 GPU 可以执行 OpenGL-4)。 您必须在使用它们之前检查扩展程序的可用性。 不用说,您不能使用超出 OpenGL 实现为您提供的上下文功能的 OpenGL 版本配置文件的功能。您的 OpenGL 实现支持 GL_ARB_vertex_buffer_object,但如果您想使用它,您必须使用 glGenBuffersARB

    更新我认为您系统上的驱动程序未安装,无法正常运行。服务器字符串报告“供应商 SGI”,它与您的 GPU 驱动程序不匹配。

    【讨论】:

    • glGenBuffers 实际上来自 GL 1.5——3.0 中添加了 VAO,但 1.5 中引入了 VBO。一切仍然完全准确,1.4 比 1.5 旧,问题仍然存在;)
    • @AndonM.Coleman:你当然是对的,我已经确定了答案。
    猜你喜欢
    • 2012-07-01
    • 2017-09-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-04-26
    • 1970-01-01
    • 1970-01-01
    • 2018-12-20
    相关资源
    最近更新 更多