#define MODULE_BIT 0x02000000
#include "acc_std.h"
status_t GET_DISPLAY_MODE(display_mode *current_mode)
{
if (current_mode == NULL) return B_ERROR;
LOG(4, ("GET_DISPLAY_MODE: returning current mode\n"));
*current_mode = si->dm;
return B_OK;
}
status_t GET_FRAME_BUFFER_CONFIG(frame_buffer_config *afb)
{
if (afb == NULL) return B_ERROR;
*afb = si->fbc;
return B_OK;
}
status_t GET_PIXEL_CLOCK_LIMITS(display_mode *dm, uint32 *low, uint32 *high)
{
uint32 max_pclk = 0;
uint32 min_pclk = 0;
if ((dm == NULL) || (low == NULL) || (high == NULL)) return B_ERROR;
if (dm->flags & DUALHEAD_BITS)
{
switch (si->ps.card_type)
{
case G550:
case G450:
*low = ((si->ps.min_video_vco * 1000) / 16);
break;
default:
*low = ((si->ps.min_video_vco * 1000) / 8);
break;
}
switch (dm->space)
{
case B_CMAP8:
max_pclk = si->ps.max_dac2_clock_8;
break;
case B_RGB15_LITTLE:
case B_RGB16_LITTLE:
max_pclk = si->ps.max_dac2_clock_16;
break;
case B_RGB24_LITTLE:
max_pclk = si->ps.max_dac2_clock_24;
break;
case B_RGB32_LITTLE:
max_pclk = si->ps.max_dac2_clock_32dh;
break;
default:
max_pclk = si->ps.max_dac2_clock_32dh;
break;
}
*high = max_pclk * 1000;
}
else
{
switch (si->ps.card_type)
{
case G550:
case G450:
*low = ((si->ps.min_pixel_vco * 1000) / 16);
break;
default:
*low = ((si->ps.min_pixel_vco * 1000) / 8);
break;
}
switch (dm->space)
{
case B_CMAP8:
max_pclk = si->ps.max_dac1_clock_8;
break;
case B_RGB15_LITTLE:
case B_RGB16_LITTLE:
max_pclk = si->ps.max_dac1_clock_16;
break;
case B_RGB24_LITTLE:
max_pclk = si->ps.max_dac1_clock_24;
break;
case B_RGB32_LITTLE:
max_pclk = si->ps.max_dac1_clock_32;
break;
default:
max_pclk = si->ps.max_dac1_clock_32;
break;
}
*high = max_pclk * 1000;
}
min_pclk = ((uint32)dm->timing.h_total * (uint32)dm->timing.v_total * 48) / 1000;
if (min_pclk > *low) *low = min_pclk;
return B_OK;
}
sem_id ACCELERANT_RETRACE_SEMAPHORE(void)
{
if (si->ps.int_assigned)
return si->vblank;
else
return B_ERROR;
}