本文整理匯總了C++中D_ASSERT函數的典型用法代碼示例。如果您正苦於以下問題:C++ D_ASSERT函數的具體用法?C++ D_ASSERT怎麽用?C++ D_ASSERT使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了D_ASSERT函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: drbd_try_clear_on_disk_bm
/* ATTENTION. The AL's extents are 4MB each, while the extents in the
* resync LRU-cache are 16MB each.
* The caller of this function has to hold an get_ldev() reference.
*
* TODO will be obsoleted once we have a caching lru of the on disk bitmap
*/
static void drbd_try_clear_on_disk_bm(struct drbd_conf *mdev, sector_t sector,
int count, int success)
{
struct lc_element *e;
struct update_odbm_work *udw;
unsigned int enr;
D_ASSERT(atomic_read(&mdev->local_cnt));
/* I simply assume that a sector/size pair never crosses
* a 16 MB extent border. (Currently this is true...) */
enr = BM_SECT_TO_EXT(sector);
e = lc_get(mdev->resync, enr);
if (e) {
struct bm_extent *ext = lc_entry(e, struct bm_extent, lce);
if (ext->lce.lc_number == enr) {
if (success)
ext->rs_left -= count;
else
ext->rs_failed += count;
if (ext->rs_left < ext->rs_failed) {
dev_err(DEV, "BAD! sector=%llus enr=%u rs_left=%d "
"rs_failed=%d count=%d\n",
(unsigned long long)sector,
ext->lce.lc_number, ext->rs_left,
ext->rs_failed, count);
dump_stack();
lc_put(mdev->resync, &ext->lce);
drbd_force_state(mdev, NS(conn, C_DISCONNECTING));
return;
}
} else {
/* Normally this element should be in the cache,
* since drbd_rs_begin_io() pulled it already in.
*
* But maybe an application write finished, and we set
* something outside the resync lru_cache in sync.
*/
int rs_left = drbd_bm_e_weight(mdev, enr);
if (ext->flags != 0) {
dev_warn(DEV, "changing resync lce: %d[%u;%02lx]"
" -> %d[%u;00]\n",
ext->lce.lc_number, ext->rs_left,
ext->flags, enr, rs_left);
ext->flags = 0;
}
if (ext->rs_failed) {
dev_warn(DEV, "Kicking resync_lru element enr=%u "
"out with rs_failed=%d\n",
ext->lce.lc_number, ext->rs_failed);
set_bit(WRITE_BM_AFTER_RESYNC, &mdev->flags);
}
ext->rs_left = rs_left;
ext->rs_failed = success ? 0 : count;
lc_changed(mdev->resync, &ext->lce);
}
lc_put(mdev->resync, &ext->lce);
/* no race, we are within the al_lock! */
if (ext->rs_left == ext->rs_failed) {
ext->rs_failed = 0;
udw = kmalloc(sizeof(*udw), GFP_ATOMIC);
if (udw) {
udw->enr = ext->lce.lc_number;
udw->w.cb = w_update_odbm;
drbd_queue_work_front(&mdev->data.work, &udw->w);
} else {
dev_warn(DEV, "Could not kmalloc an udw\n");
set_bit(WRITE_BM_AFTER_RESYNC, &mdev->flags);
}
}
} else {
示例2: voodoo_link_init_local
DirectResult
voodoo_link_init_local( VoodooLink *link,
const char *path,
bool raw )
{
DirectResult ret;
int err;
struct sockaddr_un addr;
Link *l;
D_ASSERT( link != NULL );
D_ASSERT( path != NULL );
l = D_CALLOC( 1, sizeof(Link) );
if (!l)
return D_OOM();
/* Create the client socket. */
l->fd[0] = socket( AF_LOCAL, SOCK_STREAM, 0 );
if (l->fd[0] < 0) {
ret = errno2result( errno );
D_PERROR( "Voodoo/Link: Socket creation failed!\n" );
D_FREE( l );
return ret;
}
l->fd[1] = l->fd[0];
#if !VOODOO_BUILD_NO_SETSOCKOPT
if (setsockopt( l->fd[0], SOL_IP, IP_TOS, &tos, sizeof(tos) ) < 0)
D_PERROR( "Voodoo/Manager: Could not set IP_TOS!\n" );
if (setsockopt( l->fd[0], SOL_TCP, TCP_NODELAY, &one, sizeof(one) ) < 0)
D_PERROR( "Voodoo/Manager: Could not set TCP_NODELAY!\n" );
#endif
D_INFO( "Voodoo/Link: Connecting to '%s'...\n", path );
memset( &addr, 0, sizeof(addr) );
/* Bind the socket to the local port. */
addr.sun_family = AF_UNIX;
snprintf( addr.sun_path + 1, UNIX_PATH_MAX - 1, "%s", path );
/* Connect to the server. */
err = connect( l->fd[0], (struct sockaddr*) &addr, strlen(addr.sun_path+1)+1 + sizeof(addr.sun_family) );
if (err) {
ret = errno2result( errno );
D_PERROR( "Voodoo/Link: Socket connect failed!\n" );
close( l->fd[0] );
D_FREE( l );
return ret;
}
D_INFO( "Voodoo/Link: Connected.\n" );
DUMP_SOCKET_OPTION( l->fd[0], SO_SNDLOWAT );
DUMP_SOCKET_OPTION( l->fd[0], SO_RCVLOWAT );
DUMP_SOCKET_OPTION( l->fd[0], SO_SNDBUF );
DUMP_SOCKET_OPTION( l->fd[0], SO_RCVBUF );
if (!raw) {
link->code = 0x80008676;
if (write( l->fd[1], &link->code, sizeof(link->code) ) != 4) {
D_ERROR( "Voodoo/Link: Coult not write initial four bytes!\n" );
close( l->fd[0] );
D_FREE( l );
return DR_IO;
}
}
D_INFO( "Voodoo/Link: Sent link code (%s).\n", raw ? "raw" : "packet" );
if (pipe( l->wakeup_fds ))
return errno2result( errno );
link->priv = l;
link->Close = Close;
link->Read = Read;
link->Write = Write;
link->SendReceive = SendReceive;
link->WakeUp = WakeUp;
link->WaitForData = WaitForData;
return DR_OK;
}
示例3: main
int
main( int argc, char *argv[] )
{
DirectResult ret;
FusionWorld *world;
StretRegion *root;
StretRegion *child[16];
int child_num = 0;
StretIteration iteration;
DFBRegion clip;
FusionSHMPoolShared *pool;
ret = fusion_enter( -1, 0, FER_ANY, &world );
if (ret)
return -1;
ret = fusion_shm_pool_create( world, "StReT Test Pool", 0x10000, direct_config->debug, &pool );
if (ret) {
fusion_exit( world, false );
return -1;
}
D_INFO( "StReT/Test: Starting...\n" );
ret = stret_region_create( 0, NULL, 0, SRF_ACTIVE, 2, 0, 0, 1000, 1000, NULL, 0, pool, &root );
if (ret) {
D_DERROR( ret, "StReT/Test: Could not create root region!\n" );
goto error_root;
}
else {
ret = stret_region_create( 0, NULL, 0, SRF_ACTIVE, 1, 10, 10, 100, 100, root, 1, pool, &child[child_num++] );
if (ret) {
D_DERROR( ret, "StReT/Test: Could not create child region!\n" );
goto error_child;
}
else {
ret = stret_region_create( 0, NULL, 0, SRF_ACTIVE, 1, 50, 50, 30, 30, child[0], 0, pool, &child[child_num++] );
if (ret) {
D_DERROR( ret, "StReT/Test: Could not create child region!\n" );
goto error_child;
}
ret = stret_region_create( 0, NULL, 0, SRF_ACTIVE, 1, 20, 20, 30, 30, child[0], 0, pool, &child[child_num++] );
if (ret) {
D_DERROR( ret, "StReT/Test: Could not create child region!\n" );
goto error_child;
}
else {
ret = stret_region_create( 0, NULL, 0, SRF_ACTIVE, 1, 10, 10, 10, 10, child[2], 0, pool, &child[child_num++] );
if (ret) {
D_DERROR( ret, "StReT/Test: Could not create child region!\n" );
goto error_child;
}
ret = stret_region_create( 0, NULL, 0, SRF_ACTIVE, 1, 20, 20, 10, 10, child[2], 0, pool, &child[child_num++] );
if (ret) {
D_DERROR( ret, "StReT/Test: Could not create child region!\n" );
goto error_child;
}
}
}
ret = stret_region_create( 0, NULL, 0, SRF_ACTIVE, 1, 200, 10, 200, 200, root, 0, pool, &child[child_num++] );
if (ret) {
D_DERROR( ret, "StReT/Test: Could not create child region!\n" );
goto error_child;
}
}
stret_iteration_init( &iteration, root, NULL );
clip = (DFBRegion) { 50, 50, 200, 59 };
D_ASSERT( stret_iteration_next( &iteration, &clip ) == child[4] );
//D_ASSERT( stret_iteration_next( &iteration, &clip ) == child[3] );
D_ASSERT( stret_iteration_next( &iteration, &clip ) == child[2] );
//D_ASSERT( stret_iteration_next( &iteration, &clip ) == child[1] );
D_ASSERT( stret_iteration_next( &iteration, &clip ) == child[0] );
D_ASSERT( stret_iteration_next( &iteration, &clip ) == child[5] );
D_ASSERT( stret_iteration_next( &iteration, &clip ) == root );
D_ASSERT( stret_iteration_next( &iteration, &clip ) == NULL );
stret_region_destroy( child[child_num-1] );
error_child:
while (--child_num)
stret_region_destroy( child[child_num-1] );
stret_region_destroy( root );
error_root:
fusion_shm_pool_destroy( world, pool );
fusion_exit( world, false );
//.........這裏部分代碼省略.........
示例4: dfb_surface_pool_bridge_join
DFBResult
dfb_surface_pool_bridge_join( CoreDFB *core,
CoreSurfacePoolBridge *bridge,
const SurfacePoolBridgeFuncs *funcs,
void *context )
{
DFBResult ret;
D_MAGIC_ASSERT( bridge, CoreSurfacePoolBridge );
D_DEBUG_AT( Core_SurfPoolBridge, "%s( %p [%d], %p, %p )\n", __FUNCTION__, bridge, bridge->bridge_id, funcs, context );
D_ASSERT( core != NULL );
D_ASSERT( funcs != NULL );
D_ASSERT( bridge->bridge_id < MAX_SURFACE_POOL_BRIDGES );
D_ASSERT( bridge->bridge_id == bridge_count );
D_ASSERT( bridge_funcs[bridge->bridge_id] == NULL );
/* Enforce same order as initialization to be used during join. */
if (bridge->bridge_id != bridge_count) {
D_ERROR( "Core/SurfacePoolBridge: Wrong order of joining bridges, got %d, should be %d!\n",
bridge->bridge_id, bridge_count );
return DFB_BUG;
}
/* Allocate local bridge data. */
if (bridge->bridge_local_data_size &&
!(bridge_locals[bridge->bridge_id] = D_CALLOC( 1, bridge->bridge_local_data_size )))
return D_OOM();
/* Set function table of the bridge. */
bridge_funcs[bridge->bridge_id] = funcs;
/* Add to global bridge list. */
bridge_array[bridge->bridge_id] = bridge;
/* Adjust bridge count. */
if (bridge_count < bridge->bridge_id + 1)
bridge_count = bridge->bridge_id + 1;
funcs = get_funcs( bridge );
if (funcs->JoinPoolBridge) {
ret = funcs->JoinPoolBridge( core, bridge, bridge->data, get_local(bridge), context );
if (ret) {
D_DERROR( ret, "Core/SurfacePoolBridge: Joining '%s' failed!\n", bridge->desc.name );
if (bridge_locals[bridge->bridge_id]) {
D_FREE( bridge_locals[bridge->bridge_id] );
bridge_locals[bridge->bridge_id] = NULL;
}
bridge_array[bridge->bridge_id] = NULL;
bridge_funcs[bridge->bridge_id] = NULL;
bridge_count--;
return ret;
}
}
/* Insert new bridge into priority order */
insert_bridge_local( bridge );
return DFB_OK;
}
示例5: wm_init_stack
static DFBResult
wm_init_stack( CoreWindowStack *stack,
void *wm_data,
void *stack_data )
{
DFBResult ret;
StackData *data = stack_data;
WMData *wmdata = wm_data;
CoreLayerContext *context;
CoreLayerRegion *region;
D_ASSERT( stack != NULL );
D_ASSERT( stack->context != NULL );
D_ASSERT( wm_data != NULL );
D_ASSERT( stack_data != NULL );
context = stack->context;
D_ASSERT( context != NULL );
ret = dfb_layer_context_get_primary_region( context, true, ®ion );
if (ret) {
D_DERROR( ret, "WM/UniQuE: Could not get the primary region!\n" );
return ret;
}
/* Create the unique context. */
ret = unique_context_create( wmdata->core, stack, region, context->layer_id,
wmdata->shared, &data->context );
dfb_layer_region_unref( region );
if (ret) {
D_DERROR( ret, "WM/UniQuE: Could not create the context!\n" );
return ret;
}
/* Attach the global context listener. */
ret = unique_context_attach_global( data->context,
UNIQUE_WM_MODULE_CONTEXT_LISTENER,
data, &data->context_reaction );
if (ret) {
unique_context_unref( data->context );
D_DERROR( ret, "WM/UniQuE: Could not attach global context listener!\n" );
return ret;
}
/* Inherit all local references from the layer context. */
ret = unique_context_inherit( data->context, context );
unique_context_unref( data->context );
if (ret) {
unique_context_detach_global( data->context, &data->context_reaction );
D_DERROR( ret, "WM/UniQuE: Could not inherit from layer context!\n" );
return ret;
}
data->stack = stack;
D_MAGIC_SET( data, StackData );
return DFB_OK;
}
示例6: cont_prop_read
static int
cont_prop_read(struct rdb_tx *tx, struct cont *cont, uint64_t bits,
daos_prop_t **prop_out)
{
daos_prop_t *prop = NULL;
daos_iov_t value;
uint64_t val, bitmap;
uint32_t idx = 0, nr = 0;
int rc;
bitmap = bits & DAOS_CO_QUERY_PROP_ALL;
while (idx < DAOS_CO_QUERY_PROP_BITS_NR) {
if (bitmap & 0x1)
nr++;
idx++;
bitmap = bitmap >> 1;
};
if (nr == 0)
return 0;
D_ASSERT(nr <= DAOS_CO_QUERY_PROP_BITS_NR);
prop = daos_prop_alloc(nr);
if (prop == NULL)
return -DER_NOMEM;
idx = 0;
if (bits & DAOS_CO_QUERY_PROP_LABEL) {
daos_iov_set(&value, NULL, 0);
rc = rdb_tx_lookup(tx, &cont->c_prop, &ds_cont_prop_label,
&value);
if (rc != 0)
return rc;
if (value.iov_len > DAOS_PROP_LABEL_MAX_LEN) {
D_ERROR("bad label length %zu (> %d).\n", value.iov_len,
DAOS_PROP_LABEL_MAX_LEN);
D_GOTO(out, rc = -DER_NOMEM);
}
D_ASSERT(idx < nr);
prop->dpp_entries[idx].dpe_type = DAOS_PROP_CO_LABEL;
prop->dpp_entries[idx].dpe_str =
strndup(value.iov_buf, value.iov_len);
if (prop->dpp_entries[idx].dpe_str == NULL)
D_GOTO(out, rc = -DER_NOMEM);
idx++;
}
if (bits & DAOS_CO_QUERY_PROP_LAYOUT_TYPE) {
daos_iov_set(&value, &val, sizeof(val));
rc = rdb_tx_lookup(tx, &cont->c_prop, &ds_cont_prop_layout_type,
&value);
if (rc != 0)
D_GOTO(out, rc);
D_ASSERT(idx < nr);
prop->dpp_entries[idx].dpe_type = DAOS_PROP_CO_LAYOUT_TYPE;
prop->dpp_entries[idx].dpe_val = val;
idx++;
}
if (bits & DAOS_CO_QUERY_PROP_LAYOUT_VER) {
daos_iov_set(&value, &val, sizeof(val));
rc = rdb_tx_lookup(tx, &cont->c_prop, &ds_cont_prop_layout_ver,
&value);
if (rc != 0)
D_GOTO(out, rc);
D_ASSERT(idx < nr);
prop->dpp_entries[idx].dpe_type = DAOS_PROP_CO_LAYOUT_VER;
prop->dpp_entries[idx].dpe_val = val;
idx++;
}
if (bits & DAOS_CO_QUERY_PROP_CSUM) {
daos_iov_set(&value, &val, sizeof(val));
rc = rdb_tx_lookup(tx, &cont->c_prop, &ds_cont_prop_csum,
&value);
if (rc != 0)
D_GOTO(out, rc);
D_ASSERT(idx < nr);
prop->dpp_entries[idx].dpe_type = DAOS_PROP_CO_CSUM;
prop->dpp_entries[idx].dpe_val = val;
idx++;
}
if (bits & DAOS_CO_QUERY_PROP_REDUN_FAC) {
daos_iov_set(&value, &val, sizeof(val));
rc = rdb_tx_lookup(tx, &cont->c_prop, &ds_cont_prop_redun_fac,
&value);
if (rc != 0)
D_GOTO(out, rc);
D_ASSERT(idx < nr);
prop->dpp_entries[idx].dpe_type = DAOS_PROP_CO_REDUN_FAC;
prop->dpp_entries[idx].dpe_val = val;
idx++;
}
if (bits & DAOS_CO_QUERY_PROP_REDUN_LVL) {
daos_iov_set(&value, &val, sizeof(val));
rc = rdb_tx_lookup(tx, &cont->c_prop, &ds_cont_prop_redun_lvl,
&value);
if (rc != 0)
D_GOTO(out, rc);
D_ASSERT(idx < nr);
prop->dpp_entries[idx].dpe_type = DAOS_PROP_CO_REDUN_LVL;
prop->dpp_entries[idx].dpe_val = val;
idx++;
}
//.........這裏部分代碼省略.........
示例7: processor_thread
static void *
processor_thread( DirectThread *thread,
void *ctx )
{
DirectResult ret;
bool started = false;
DirectProcessor *processor = ctx;
const DirectProcessorFuncs *funcs;
D_DEBUG_AT( Direct_Processor, "%s( %p, %p )...\n", __FUNCTION__, thread, ctx );
D_MAGIC_ASSERT( processor, DirectProcessor );
funcs = processor->funcs;
D_ASSERT( funcs != NULL );
D_ASSERT( funcs->Process != NULL );
while (!processor->stop) {
ProcessorCommand *command = direct_fifo_pull( &processor->commands );
if (command) {
D_DEBUG_AT( Direct_Processor, "=---### %p - %p (%s)\n", command, command + 1, processor->name );
D_MAGIC_ASSERT( command, ProcessorCommand );
if (!started) {
if (funcs->Start)
funcs->Start( processor, processor->context );
started = true;
}
ret = funcs->Process( processor, command + 1, processor->context );
if (ret)
D_DERROR( ret, "Direct/Processor: Processing failed! (%s)\n", processor->name );
}
else {
if (started) {
if (funcs->Stop)
funcs->Stop( processor, processor->context );
started = false;
}
#if 0
while (processor->lock) {
direct_mutex_lock( &processor->lock_mutex );
processor->locked = true;
direct_waitqueue_signal( &processor->lock_cond );
while (processor->lock)
direct_waitqueue_wait( &processor->lock_cond, &processor->lock_mutex );
processor->locked = false;
direct_waitqueue_signal( &processor->lock_cond );
direct_mutex_unlock( &processor->lock_mutex );
}
#endif
if (processor->idle_ms) {
while (direct_fifo_wait_timed( &processor->commands, processor->idle_ms ) == DR_TIMEOUT) {
if (funcs->Idle)
funcs->Idle( processor, processor->context );
}
}
else {
if (funcs->Idle)
funcs->Idle( processor, processor->context );
direct_fifo_wait( &processor->commands );
}
}
}
return NULL;
}
示例8: _req_may_be_done
/* Helper for __req_mod().
* Set m->bio to the master bio, if it is fit to be completed,
* or leave it alone (it is initialized to NULL in __req_mod),
* if it has already been completed, or cannot be completed yet.
* If m->bio is set, the error status to be returned is placed in m->error.
*/
void _req_may_be_done(struct drbd_request *req, struct bio_and_error *m)
{
const unsigned long s = req->rq_state;
struct drbd_conf *mdev = req->mdev;
int rw = req->rq_state & RQ_WRITE ? WRITE : READ;
/* we must not complete the master bio, while it is
* still being processed by _drbd_send_zc_bio (drbd_send_dblock)
* not yet acknowledged by the peer
* not yet completed by the local io subsystem
* these flags may get cleared in any order by
* the worker,
* the receiver,
* the bio_endio completion callbacks.
*/
if (s & RQ_NET_QUEUED)
return;
if (s & RQ_NET_PENDING)
return;
if (s & RQ_LOCAL_PENDING && !(s & RQ_LOCAL_ABORTED))
return;
if (req->master_bio) {
/* this is data_received (remote read)
* or protocol C P_WRITE_ACK
* or protocol B P_RECV_ACK
* or protocol A "handed_over_to_network" (SendAck)
* or canceled or failed,
* or killed from the transfer log due to connection loss.
*/
/*
* figure out whether to report success or failure.
*
* report success when at least one of the operations succeeded.
* or, to put the other way,
* only report failure, when both operations failed.
*
* what to do about the failures is handled elsewhere.
* what we need to do here is just: complete the master_bio.
*
* local completion error, if any, has been stored as ERR_PTR
* in private_bio within drbd_endio_pri.
*/
int ok = (s & RQ_LOCAL_OK) || (s & RQ_NET_OK);
int error = PTR_ERR(req->private_bio);
/* remove the request from the conflict detection
* respective block_id verification hash */
if (!hlist_unhashed(&req->collision))
hlist_del(&req->collision);
else
D_ASSERT((s & (RQ_NET_MASK & ~RQ_NET_DONE)) == 0);
/* for writes we need to do some extra housekeeping */
if (rw == WRITE)
_about_to_complete_local_write(mdev, req);
/* Update disk stats */
_drbd_end_io_acct(mdev, req);
m->error = ok ? 0 : (error ?: -EIO);
m->bio = req->master_bio;
req->master_bio = NULL;
}
示例9: dfb_screen_get_layer_dimension
DFBResult
dfb_screen_get_layer_dimension( CoreScreen *screen,
CoreLayer *layer,
int *ret_width,
int *ret_height )
{
int i;
DFBResult ret = DFB_UNSUPPORTED;
CoreScreenShared *shared;
ScreenFuncs *funcs;
D_ASSERT( screen != NULL );
D_ASSERT( screen->shared != NULL );
D_ASSERT( screen->funcs != NULL );
D_ASSERT( layer != NULL );
D_ASSERT( ret_width != NULL );
D_ASSERT( ret_height != NULL );
shared = screen->shared;
funcs = screen->funcs;
if (funcs->GetMixerState) {
for (i=0; i<shared->description.mixers; i++) {
const DFBScreenMixerConfig *config = &shared->mixers[i].configuration;
if ((config->flags & DSMCONF_LAYERS) &&
DFB_DISPLAYLAYER_IDS_HAVE( config->layers, dfb_layer_id(layer) ))
{
CoreMixerState state;
ret = funcs->GetMixerState( screen, screen->driver_data, screen->screen_data, i, &state );
if (ret == DFB_OK) {
if (state.flags & CMSF_DIMENSION) {
*ret_width = state.dimension.w;
*ret_height = state.dimension.h;
return DFB_OK;
}
ret = DFB_UNSUPPORTED;
}
}
}
for (i=0; i<shared->description.mixers; i++) {
const DFBScreenMixerDescription *desc = &shared->mixers[i].description;
if ((desc->caps & DSMCAPS_SUB_LAYERS) &&
DFB_DISPLAYLAYER_IDS_HAVE( desc->sub_layers, dfb_layer_id(layer) ))
{
CoreMixerState state;
ret = funcs->GetMixerState( screen, screen->driver_data, screen->screen_data, i, &state );
if (ret == DFB_OK) {
if (state.flags & CMSF_DIMENSION) {
*ret_width = state.dimension.w;
*ret_height = state.dimension.h;
return DFB_OK;
}
ret = DFB_UNSUPPORTED;
}
}
}
}
if (funcs->GetScreenSize)
ret = funcs->GetScreenSize( screen,
screen->driver_data, screen->screen_data,
ret_width, ret_height );
return ret;
}
示例10: root_update
static void
root_update( StretRegion *region,
void *region_data,
void *update_data,
unsigned long arg,
int x,
int y,
const DFBRegion *updates,
int num )
{
int i;
CoreWindowStack *stack;
UniqueContext *context = region_data;
CardState *state = update_data;
D_ASSERT( region != NULL );
D_ASSERT( region_data != NULL );
D_ASSERT( update_data != NULL );
D_ASSERT( updates != NULL );
D_ASSERT( x == 0 );
D_ASSERT( y == 0 );
D_MAGIC_ASSERT( context, UniqueContext );
D_MAGIC_ASSERT( state, CardState );
stack = context->stack;
D_ASSERT( stack != NULL );
D_ASSERT( stack->bg.image != NULL || (stack->bg.mode != DLBM_IMAGE &&
stack->bg.mode != DLBM_TILE) );
D_DEBUG_AT( UniQuE_Root, "root_update( region %p, num %d )\n", region, num );
#if D_DEBUG_ENABLED
for (i=0; i<num; i++) {
D_DEBUG_AT( UniQuE_Root, " (%d) %4d,%4d - %4dx%4d\n",
i, DFB_RECTANGLE_VALS_FROM_REGION( &updates[i] ) );
}
#endif
switch (stack->bg.mode) {
case DLBM_COLOR: {
CoreSurface *dest = state->destination;
DFBColor *color = &stack->bg.color;
DFBRectangle rects[num];
/* Set the background color. */
if (DFB_PIXELFORMAT_IS_INDEXED( dest->config.format ))
dfb_state_set_color_index( state,
dfb_palette_search( dest->palette, color->r,
color->g, color->b, color->a ) );
else
dfb_state_set_color( state, color );
for (i=0; i<num; i++)
dfb_rectangle_from_region( &rects[i], &updates[i] );
/* Simply fill the background. */
dfb_gfxcard_fillrectangles( rects, num, state );
break;
}
case DLBM_IMAGE: {
CoreSurface *bg = stack->bg.image;
/* Set blitting source. */
state->source = bg;
state->modified |= SMF_SOURCE;
/* Set blitting flags. */
dfb_state_set_blitting_flags( state, DSBLIT_NOFX );
/* Check the size of the background image. */
if (bg->config.size.w == stack->width && bg->config.size.h == stack->height) {
for (i=0; i<num; i++) {
DFBRectangle dst = DFB_RECTANGLE_INIT_FROM_REGION( &updates[i] );
/* Simple blit for 100% fitting background image. */
dfb_gfxcard_blit( &dst, dst.x, dst.y, state );
}
}
else {
DFBRegion clip = state->clip;
for (i=0; i<num; i++) {
DFBRectangle src = { 0, 0, bg->config.size.w, bg->config.size.h };
DFBRectangle dst = { 0, 0, stack->width, stack->height };
/* Change clipping region. */
dfb_state_set_clip( state, &updates[i] );
/* Stretch blit for non fitting background images. */
dfb_gfxcard_stretchblit( &src, &dst, state );
}
/* Restore clipping region. */
dfb_state_set_clip( state, &clip );
}
//.........這裏部分代碼省略.........
示例11: x11Read
static DFBResult
x11Read( CoreSurfacePool *pool,
void *pool_data,
void *pool_local,
CoreSurfaceAllocation *allocation,
void *alloc_data,
void *destination,
int pitch,
const DFBRectangle *rect )
{
XImage *image;
XImage *sub;
x11PoolLocalData *local = pool_local;
x11AllocationData *alloc = alloc_data;
DFBX11 *x11 = local->x11;
D_DEBUG_AT( X11_Surfaces, "%s( %p )\n", __FUNCTION__, allocation );
D_DEBUG_AT( X11_Surfaces, " -> allocation: %s\n", ToString_CoreSurfaceAllocation( allocation ) );
D_MAGIC_ASSERT( pool, CoreSurfacePool );
D_MAGIC_ASSERT( allocation, CoreSurfaceAllocation );
D_ASSERT( destination != NULL );
D_ASSERT( pitch >= 0 );
DFB_RECTANGLE_ASSERT( rect );
D_DEBUG_AT( X11_Surfaces, " => %p 0x%08lx [%4d,%4d-%4dx%4d]\n", alloc, alloc->xid, DFB_RECTANGLE_VALS(rect) );
XLockDisplay( x11->display );
#if 1
image = XCreateImage( x11->display, alloc->visual, alloc->depth, ZPixmap, 0, destination, rect->w, rect->h, 32, pitch );
if (!image) {
D_ERROR( "X11/Surfaces: XCreateImage( %dx%d, depth %d ) failed!\n", rect->w, rect->h, alloc->depth );
XUnlockDisplay( x11->display );
return DFB_FAILURE;
}
sub = XGetSubImage( x11->display, alloc->xid, rect->x, rect->y, rect->w, rect->h, ~0, ZPixmap, image, 0, 0 );
#else
image = XGetImage( x11->display, alloc->window ? alloc->window : alloc->xid,
rect->x, rect->y, rect->w, rect->h, ~0, ZPixmap );
#endif
if (image) {
// dfb_surface_buffer_dump_type_locked2( allocation->buffer, ".", "x11Read", false, image->data, image->bytes_per_line );
/* FIXME: Why the X-hell is XDestroyImage() freeing *MY* data? */
image->data = NULL;
XDestroyImage( image );
}
XUnlockDisplay( x11->display );
#if 1
if (!sub) {
D_ERROR( "X11/Surfaces: XGetSubImage( %d,%d-%dx%d ) failed!\n", DFB_RECTANGLE_VALS(rect) );
return DFB_FAILURE;
}
#endif
return DFB_OK;
}
示例12: ColEdge
ColEdge(std::pair<int, int> p)
: tar(p.first),
col(p.second)
{ D_ASSERT(tar > 0); }
示例13: _dfb_layer_region_surface_listener
/*
* listen to the layer's surface
*/
ReactionResult
_dfb_layer_region_surface_listener( const void *msg_data, void *ctx )
{
CoreSurfaceNotificationFlags flags;
CoreSurface *surface;
CoreLayer *layer;
CoreLayerShared *shared;
DisplayLayerFuncs *funcs;
const CoreSurfaceNotification *notification = msg_data;
CoreLayerRegion *region = ctx;
D_ASSERT( notification != NULL );
D_ASSERT( region != NULL );
D_ASSERT( region->context != NULL );
D_DEBUG_AT( Core_Layers, "_dfb_layer_region_surface_listener( %p, %p ) <- 0x%08x\n",
notification, region, notification->flags );
D_ASSERT( notification->surface != NULL );
D_ASSUME( notification->surface == region->surface );
if (notification->surface != region->surface)
return RS_OK;
layer = dfb_layer_at( region->context->layer_id );
D_ASSERT( layer != NULL );
D_ASSERT( layer->funcs != NULL );
D_ASSERT( layer->funcs->SetRegion != NULL );
D_ASSERT( layer->shared != NULL );
funcs = layer->funcs;
shared = layer->shared;
flags = notification->flags;
surface = notification->surface;
if (flags & CSNF_DESTROY) {
D_WARN( "layer region surface destroyed" );
region->surface = NULL;
return RS_REMOVE;
}
if (dfb_layer_region_lock( region ))
return RS_OK;
if (D_FLAGS_ARE_SET( region->state, CLRSF_REALIZED | CLRSF_CONFIGURED )) {
if (D_FLAGS_IS_SET( flags, CSNF_PALETTE_CHANGE | CSNF_PALETTE_UPDATE )) {
if (surface->palette)
funcs->SetRegion( layer,
layer->driver_data, layer->layer_data,
region->region_data, ®ion->config,
CLRCF_PALETTE, surface, surface->palette );
}
if ((flags & CSNF_FIELD) && funcs->SetInputField)
funcs->SetInputField( layer,
layer->driver_data, layer->layer_data,
region->region_data, surface->field );
if ((flags & CSNF_ALPHA_RAMP) && (shared->description.caps & DLCAPS_ALPHA_RAMP)) {
region->config.alpha_ramp[0] = surface->alpha_ramp[0];
region->config.alpha_ramp[1] = surface->alpha_ramp[1];
region->config.alpha_ramp[2] = surface->alpha_ramp[2];
region->config.alpha_ramp[3] = surface->alpha_ramp[3];
funcs->SetRegion( layer,
layer->driver_data, layer->layer_data,
region->region_data, ®ion->config,
CLRCF_ALPHA_RAMP, surface, surface->palette );
}
}
dfb_layer_region_unlock( region );
return RS_OK;
}
示例14: dfb_colorhash_lookup
unsigned int
dfb_colorhash_lookup( DFBColorHashCore *core,
CorePalette *palette,
u8 r,
u8 g,
u8 b,
u8 a )
{
unsigned int pixel = PIXEL_ARGB(a, r, g, b);
unsigned int index = (pixel ^ (unsigned long) palette) % HASH_SIZE;
DFBColorHashCoreShared *shared;
// D_ASSUME( core != NULL );
if (core) {
D_MAGIC_ASSERT( core, DFBColorHashCore );
D_MAGIC_ASSERT( core->shared, DFBColorHashCoreShared );
}
else
core = core_colorhash;
shared = core->shared;
D_ASSERT( shared->hash != NULL );
fusion_skirmish_prevail( &shared->hash_lock );
/* try a lookup in the hash table */
if (shared->hash[index].palette == palette && shared->hash[index].pixel == pixel) {
/* set the return value */
index = shared->hash[index].index;
} else { /* look for the closest match */
DFBColor *entries = palette->entries;
int min_diff = 0;
unsigned int i, min_index = 0;
for (i = 0; i < palette->num_entries; i++) {
int diff;
int r_diff = (int) entries[i].r - (int) r;
int g_diff = (int) entries[i].g - (int) g;
int b_diff = (int) entries[i].b - (int) b;
int a_diff = (int) entries[i].a - (int) a;
if (a)
diff = (r_diff * r_diff + g_diff * g_diff +
b_diff * b_diff + ((a_diff * a_diff) >> 6));
else
diff = (r_diff + g_diff + b_diff + (a_diff * a_diff));
if (i == 0 || diff < min_diff) {
min_diff = diff;
min_index = i;
}
if (!diff)
break;
}
/* store the matching entry in the hash table */
shared->hash[index].pixel = pixel;
shared->hash[index].index = min_index;
shared->hash[index].palette = palette;
/* set the return value */
index = min_index;
}
示例15: realize_region
static DFBResult
realize_region( CoreLayerRegion *region )
{
DFBResult ret;
CoreLayer *layer;
CoreLayerShared *shared;
DisplayLayerFuncs *funcs;
D_ASSERT( region != NULL );
D_ASSERT( region->context != NULL );
D_ASSERT( D_FLAGS_IS_SET( region->state, CLRSF_CONFIGURED ) );
D_ASSERT( ! D_FLAGS_IS_SET( region->state, CLRSF_REALIZED ) );
layer = dfb_layer_at( region->context->layer_id );
D_ASSERT( layer != NULL );
D_ASSERT( layer->shared != NULL );
D_ASSERT( layer->funcs != NULL );
shared = layer->shared;
funcs = layer->funcs;
D_ASSERT( ! fusion_vector_contains( &shared->added_regions, region ) );
/* Allocate the driver's region data. */
if (funcs->RegionDataSize) {
int size = funcs->RegionDataSize();
if (size > 0) {
region->region_data = SHCALLOC( 1, size );
if (!region->region_data)
return D_OOSHM();
}
}
D_DEBUG_AT( Core_Layers, "Adding region (%d, %d - %dx%d) to '%s'.\n",
DFB_RECTANGLE_VALS( ®ion->config.dest ), shared->description.name );
/* Add the region to the driver. */
if (funcs->AddRegion) {
ret = funcs->AddRegion( layer,
layer->driver_data, layer->layer_data,
region->region_data, ®ion->config );
if (ret) {
D_DERROR( ret, "Core/Layers: Could not add region!\n" );
if (region->region_data) {
SHFREE( region->region_data );
region->region_data = NULL;
}
return ret;
}
}
/* Add the region to the 'added' list. */
fusion_vector_add( &shared->added_regions, region );
/* Update the region's state. */
D_FLAGS_SET( region->state, CLRSF_REALIZED );
/* Initially setup hardware. */
ret = set_region( region, ®ion->config, CLRCF_ALL, region->surface );
if (ret) {
unrealize_region( region );
return ret;
}
return DFB_OK;
}