xref: /haiku/src/add-ons/accelerants/intel_extreme/hooks.cpp (revision ca1a22a7a8d3a0c16948d40172e8b2eaf676ce0a)
1e404297eSAxel Dörfler /*
2e404297eSAxel Dörfler  * Copyright 2006, Haiku, Inc. All Rights Reserved.
3e404297eSAxel Dörfler  * Distributed under the terms of the MIT License.
4e404297eSAxel Dörfler  *
5e404297eSAxel Dörfler  * Authors:
6e404297eSAxel Dörfler  *		Axel Dörfler, axeld@pinc-software.de
7e404297eSAxel Dörfler  */
8e404297eSAxel Dörfler 
9e404297eSAxel Dörfler 
10e404297eSAxel Dörfler #include "accelerant_protos.h"
117d5957dfSAxel Dörfler #include "accelerant.h"
12e404297eSAxel Dörfler 
13e404297eSAxel Dörfler 
14e404297eSAxel Dörfler extern "C" void *
15e404297eSAxel Dörfler get_accelerant_hook(uint32 feature, void *data)
16e404297eSAxel Dörfler {
17e404297eSAxel Dörfler 	switch (feature) {
18e404297eSAxel Dörfler 		/* general */
19e404297eSAxel Dörfler 		case B_INIT_ACCELERANT:
206c05095cSIthamar R. Adema 			return (void*)intel_init_accelerant;
21e404297eSAxel Dörfler 		case B_UNINIT_ACCELERANT:
226c05095cSIthamar R. Adema 			return (void*)intel_uninit_accelerant;
23e404297eSAxel Dörfler 		case B_CLONE_ACCELERANT:
246c05095cSIthamar R. Adema 			return (void*)intel_clone_accelerant;
25e404297eSAxel Dörfler 		case B_ACCELERANT_CLONE_INFO_SIZE:
266c05095cSIthamar R. Adema 			return (void*)intel_accelerant_clone_info_size;
27e404297eSAxel Dörfler 		case B_GET_ACCELERANT_CLONE_INFO:
286c05095cSIthamar R. Adema 			return (void*)intel_get_accelerant_clone_info;
29e404297eSAxel Dörfler 		case B_GET_ACCELERANT_DEVICE_INFO:
306c05095cSIthamar R. Adema 			return (void*)intel_get_accelerant_device_info;
31e404297eSAxel Dörfler 		case B_ACCELERANT_RETRACE_SEMAPHORE:
326c05095cSIthamar R. Adema 			return (void*)intel_accelerant_retrace_semaphore;
33e404297eSAxel Dörfler 
34e404297eSAxel Dörfler 		/* mode configuration */
35e404297eSAxel Dörfler 		case B_ACCELERANT_MODE_COUNT:
366c05095cSIthamar R. Adema 			return (void*)intel_accelerant_mode_count;
37e404297eSAxel Dörfler 		case B_GET_MODE_LIST:
386c05095cSIthamar R. Adema 			return (void*)intel_get_mode_list;
39e404297eSAxel Dörfler 		case B_PROPOSE_DISPLAY_MODE:
406c05095cSIthamar R. Adema 			return (void*)intel_propose_display_mode;
41e404297eSAxel Dörfler 		case B_SET_DISPLAY_MODE:
426c05095cSIthamar R. Adema 			return (void*)intel_set_display_mode;
43e404297eSAxel Dörfler 		case B_GET_DISPLAY_MODE:
446c05095cSIthamar R. Adema 			return (void*)intel_get_display_mode;
45e404297eSAxel Dörfler 		case B_GET_FRAME_BUFFER_CONFIG:
466c05095cSIthamar R. Adema 			return (void*)intel_get_frame_buffer_config;
47e404297eSAxel Dörfler 		case B_GET_PIXEL_CLOCK_LIMITS:
486c05095cSIthamar R. Adema 			return (void*)intel_get_pixel_clock_limits;
49e404297eSAxel Dörfler 		case B_MOVE_DISPLAY:
506c05095cSIthamar R. Adema 			return (void*)intel_move_display;
51e404297eSAxel Dörfler 		case B_SET_INDEXED_COLORS:
526c05095cSIthamar R. Adema 			return (void*)intel_set_indexed_colors;
53e404297eSAxel Dörfler 		case B_GET_TIMING_CONSTRAINTS:
546c05095cSIthamar R. Adema 			return (void*)intel_get_timing_constraints;
55e404297eSAxel Dörfler 
56e404297eSAxel Dörfler 		/* DPMS */
57e404297eSAxel Dörfler 		case B_DPMS_CAPABILITIES:
586c05095cSIthamar R. Adema 			return (void*)intel_dpms_capabilities;
59e404297eSAxel Dörfler 		case B_DPMS_MODE:
606c05095cSIthamar R. Adema 			return (void*)intel_dpms_mode;
61e404297eSAxel Dörfler 		case B_SET_DPMS_MODE:
626c05095cSIthamar R. Adema 			return (void*)intel_set_dpms_mode;
63e404297eSAxel Dörfler 
64e404297eSAxel Dörfler 		/* cursor managment */
657d5957dfSAxel Dörfler 		case B_SET_CURSOR_SHAPE:
667d5957dfSAxel Dörfler 			if (gInfo->cursor_memory != NULL)
676c05095cSIthamar R. Adema 				return (void*)intel_set_cursor_shape;
68e404297eSAxel Dörfler 		case B_MOVE_CURSOR:
697d5957dfSAxel Dörfler 			if (gInfo->cursor_memory != NULL)
706c05095cSIthamar R. Adema 				return (void*)intel_move_cursor;
71e404297eSAxel Dörfler 		case B_SHOW_CURSOR:
727d5957dfSAxel Dörfler 			if (gInfo->cursor_memory != NULL)
736c05095cSIthamar R. Adema 				return (void*)intel_show_cursor;
747d5957dfSAxel Dörfler 
757d5957dfSAxel Dörfler 			return NULL;
767d5957dfSAxel Dörfler 
77e404297eSAxel Dörfler 		/* engine/synchronization */
78e404297eSAxel Dörfler 		case B_ACCELERANT_ENGINE_COUNT:
796c05095cSIthamar R. Adema 			return (void*)intel_accelerant_engine_count;
80e404297eSAxel Dörfler 		case B_ACQUIRE_ENGINE:
816c05095cSIthamar R. Adema 			return (void*)intel_acquire_engine;
82e404297eSAxel Dörfler 		case B_RELEASE_ENGINE:
836c05095cSIthamar R. Adema 			return (void*)intel_release_engine;
84e404297eSAxel Dörfler 		case B_WAIT_ENGINE_IDLE:
856c05095cSIthamar R. Adema 			return (void*)intel_wait_engine_idle;
86e404297eSAxel Dörfler 		case B_GET_SYNC_TOKEN:
876c05095cSIthamar R. Adema 			return (void*)intel_get_sync_token;
88e404297eSAxel Dörfler 		case B_SYNC_TO_TOKEN:
896c05095cSIthamar R. Adema 			return (void*)intel_sync_to_token;
90e404297eSAxel Dörfler 
91e404297eSAxel Dörfler 		/* 2D acceleration */
922ace35edSAxel Dörfler 		case B_SCREEN_TO_SCREEN_BLIT:
936c05095cSIthamar R. Adema 			return (void*)intel_screen_to_screen_blit;
942ace35edSAxel Dörfler 		case B_FILL_RECTANGLE:
956c05095cSIthamar R. Adema 			return (void*)intel_fill_rectangle;
962ace35edSAxel Dörfler 		case B_INVERT_RECTANGLE:
976c05095cSIthamar R. Adema 			return (void*)intel_invert_rectangle;
982ace35edSAxel Dörfler 		case B_FILL_SPAN:
99*ca1a22a7SStephan Aßmus 			return NULL;//(void*)intel_fill_span;
100d906e6a0SAxel Dörfler 
101e404297eSAxel Dörfler 		// overlay
102eea30ef3SAxel Dörfler 		case B_OVERLAY_COUNT:
1036c05095cSIthamar R. Adema 			return (void*)intel_overlay_supported_spaces;
104eea30ef3SAxel Dörfler 		case B_OVERLAY_SUPPORTED_SPACES:
1056c05095cSIthamar R. Adema 			return (void*)intel_overlay_supported_spaces;
106eea30ef3SAxel Dörfler 		case B_OVERLAY_SUPPORTED_FEATURES:
1076c05095cSIthamar R. Adema 			return (void*)intel_overlay_supported_features;
108eea30ef3SAxel Dörfler 		case B_ALLOCATE_OVERLAY_BUFFER:
1096c05095cSIthamar R. Adema 			return (void*)intel_allocate_overlay_buffer;
110eea30ef3SAxel Dörfler 		case B_RELEASE_OVERLAY_BUFFER:
1116c05095cSIthamar R. Adema 			return (void*)intel_release_overlay_buffer;
112eea30ef3SAxel Dörfler 		case B_GET_OVERLAY_CONSTRAINTS:
1136c05095cSIthamar R. Adema 			return (void*)intel_get_overlay_constraints;
114eea30ef3SAxel Dörfler 		case B_ALLOCATE_OVERLAY:
1156c05095cSIthamar R. Adema 			return (void*)intel_allocate_overlay;
116eea30ef3SAxel Dörfler 		case B_RELEASE_OVERLAY:
1176c05095cSIthamar R. Adema 			return (void*)intel_release_overlay;
118eea30ef3SAxel Dörfler 		case B_CONFIGURE_OVERLAY:
1196c05095cSIthamar R. Adema 			return (void*)intel_configure_overlay;
120e404297eSAxel Dörfler 	}
121e404297eSAxel Dörfler 
122e404297eSAxel Dörfler 	return NULL;
123e404297eSAxel Dörfler }
124e404297eSAxel Dörfler 
125