xref: /haiku/src/add-ons/accelerants/vesa/accelerant_protos.h (revision d16ddc579cc378b230e7782b82e6007063d1442d)
193ee2104SAxel Dörfler /*
2*d16ddc57SAxel Dörfler  * Copyright 2005-2008, Axel Dörfler, axeld@pinc-software.de. All rights reserved.
393ee2104SAxel Dörfler  * Distributed under the terms of the MIT License.
493ee2104SAxel Dörfler  */
593ee2104SAxel Dörfler #ifndef _ACCELERANT_PROTOS_H
693ee2104SAxel Dörfler #define _ACCELERANT_PROTOS_H
793ee2104SAxel Dörfler 
893ee2104SAxel Dörfler 
993ee2104SAxel Dörfler #include <Accelerant.h>
1093ee2104SAxel Dörfler #include "video_overlay.h"
1193ee2104SAxel Dörfler 
1293ee2104SAxel Dörfler 
1393ee2104SAxel Dörfler #ifdef __cplusplus
1493ee2104SAxel Dörfler extern "C" {
1593ee2104SAxel Dörfler #endif
1693ee2104SAxel Dörfler 
1793ee2104SAxel Dörfler // general
1893ee2104SAxel Dörfler status_t vesa_init_accelerant(int fd);
1993ee2104SAxel Dörfler ssize_t vesa_accelerant_clone_info_size(void);
2093ee2104SAxel Dörfler void vesa_get_accelerant_clone_info(void *data);
2193ee2104SAxel Dörfler status_t vesa_clone_accelerant(void *data);
2293ee2104SAxel Dörfler void vesa_uninit_accelerant(void);
2393ee2104SAxel Dörfler status_t vesa_get_accelerant_device_info(accelerant_device_info *adi);
2493ee2104SAxel Dörfler sem_id vesa_accelerant_retrace_semaphore(void);
2593ee2104SAxel Dörfler 
2693ee2104SAxel Dörfler // modes & constraints
2793ee2104SAxel Dörfler uint32 vesa_accelerant_mode_count(void);
2893ee2104SAxel Dörfler status_t vesa_get_mode_list(display_mode *dm);
29*d16ddc57SAxel Dörfler status_t vesa_propose_display_mode(display_mode *target,
30*d16ddc57SAxel Dörfler 	const display_mode *low, const display_mode *high);
3193ee2104SAxel Dörfler status_t vesa_set_display_mode(display_mode *mode_to_set);
3293ee2104SAxel Dörfler status_t vesa_get_display_mode(display_mode *current_mode);
33*d16ddc57SAxel Dörfler status_t vesa_get_edid_info(void *info, size_t size, uint32 *_version);
3493ee2104SAxel Dörfler status_t vesa_get_frame_buffer_config(frame_buffer_config *config);
35*d16ddc57SAxel Dörfler status_t vesa_get_pixel_clock_limits(display_mode *dm, uint32 *low,
36*d16ddc57SAxel Dörfler 	uint32 *high);
3793ee2104SAxel Dörfler status_t vesa_move_display(uint16 h_display_start, uint16 v_display_start);
3893ee2104SAxel Dörfler status_t vesa_get_timing_constraints(display_timing_constraints *dtc);
39*d16ddc57SAxel Dörfler void vesa_set_indexed_colors(uint count, uint8 first, uint8 *color_data,
40*d16ddc57SAxel Dörfler 	uint32 flags);
4193ee2104SAxel Dörfler 
4293ee2104SAxel Dörfler // DPMS
4393ee2104SAxel Dörfler uint32 vesa_dpms_capabilities(void);
4493ee2104SAxel Dörfler uint32 vesa_dpms_mode(void);
4593ee2104SAxel Dörfler status_t vesa_set_dpms_mode(uint32 dpms_flags);
4693ee2104SAxel Dörfler 
4793ee2104SAxel Dörfler // cursor
48*d16ddc57SAxel Dörfler status_t vesa_set_cursor_shape(uint16 width, uint16 height, uint16 hot_x,
49*d16ddc57SAxel Dörfler 	uint16 hot_y, uint8 *andMask, uint8 *xorMask);
5093ee2104SAxel Dörfler void vesa_move_cursor(uint16 x, uint16 y);
5193ee2104SAxel Dörfler void vesa_show_cursor(bool is_visible);
5293ee2104SAxel Dörfler 
5393ee2104SAxel Dörfler // accelerant engine
5493ee2104SAxel Dörfler uint32 vesa_accelerant_engine_count(void);
55*d16ddc57SAxel Dörfler status_t vesa_acquire_engine(uint32 capabilities, uint32 max_wait,
56*d16ddc57SAxel Dörfler 	sync_token *st, engine_token **et);
5793ee2104SAxel Dörfler status_t vesa_release_engine(engine_token *et, sync_token *st);
5893ee2104SAxel Dörfler void vesa_wait_engine_idle(void);
5993ee2104SAxel Dörfler status_t vesa_get_sync_token(engine_token *et, sync_token *st);
6093ee2104SAxel Dörfler status_t vesa_sync_to_token(sync_token *st);
6193ee2104SAxel Dörfler 
6293ee2104SAxel Dörfler // 2D acceleration
63*d16ddc57SAxel Dörfler void vesa_screen_to_screen_blit(engine_token *et, blit_params *list,
64*d16ddc57SAxel Dörfler 	uint32 count);
65*d16ddc57SAxel Dörfler void vesa_fill_rectangle(engine_token *et, uint32 color, fill_rect_params *list,
66*d16ddc57SAxel Dörfler 	uint32 count);
67*d16ddc57SAxel Dörfler void vesa_invert_rectangle(engine_token *et, fill_rect_params *list,
68*d16ddc57SAxel Dörfler 	uint32 count);
6993ee2104SAxel Dörfler void vesa_fill_span(engine_token *et, uint32 color, uint16 *list, uint32 count);
7093ee2104SAxel Dörfler 
7193ee2104SAxel Dörfler // overlay
7293ee2104SAxel Dörfler uint32 vesa_overlay_count(const display_mode *dm);
7393ee2104SAxel Dörfler const uint32 *vesa_overlay_supported_spaces(const display_mode *dm);
7493ee2104SAxel Dörfler uint32 vesa_overlay_supported_features(uint32 a_color_space);
75*d16ddc57SAxel Dörfler const overlay_buffer *vesa_allocate_overlay_buffer(color_space cs, uint16 width,
76*d16ddc57SAxel Dörfler 	uint16 height);
7793ee2104SAxel Dörfler status_t vesa_release_overlay_buffer(const overlay_buffer *ob);
78*d16ddc57SAxel Dörfler status_t vesa_get_overlay_constraints(const display_mode *dm,
79*d16ddc57SAxel Dörfler 	const overlay_buffer *ob, overlay_constraints *oc);
8093ee2104SAxel Dörfler overlay_token vesa_allocate_overlay(void);
8193ee2104SAxel Dörfler status_t vesa_release_overlay(overlay_token ot);
82*d16ddc57SAxel Dörfler status_t vesa_configure_overlay(overlay_token ot, const overlay_buffer *ob,
83*d16ddc57SAxel Dörfler 	const overlay_window *ow, const overlay_view *ov);
8493ee2104SAxel Dörfler 
8593ee2104SAxel Dörfler #ifdef __cplusplus
8693ee2104SAxel Dörfler }
8793ee2104SAxel Dörfler #endif
8893ee2104SAxel Dörfler 
8993ee2104SAxel Dörfler #endif	/* _ACCELERANT_PROTOS_H */
90