當前位置: 首頁>>代碼示例>>C++>>正文


C++ AO_load函數代碼示例

本文整理匯總了C++中AO_load函數的典型用法代碼示例。如果您正苦於以下問題:C++ AO_load函數的具體用法?C++ AO_load怎麽用?C++ AO_load使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了AO_load函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。

示例1: acqrel_thr

void * acqrel_thr(void *id)
{
  int me = (int)(long)id;

  int i;

  for (i = 0; i < NITERS; ++i)
    if (me & 1)
      {
        AO_T my_counter1;
	if (me != 1)
	  fprintf(stderr, "acqrel test: too many threads\n");
	my_counter1 = AO_load(&counter1);
	AO_store(&counter1, my_counter1 + 1);
	AO_store_release_write(&counter2, my_counter1 + 1);
      }
    else
      {
	AO_T my_counter2;
	AO_T my_counter1;
	my_counter2 = AO_load_acquire_read(&counter2);
	my_counter1 = AO_load(&counter1);
	if (my_counter1 < my_counter2)
	  {
	    fprintf(stderr, "Saw release store out of order: %lu < %lu\n",
		    (unsigned long)my_counter1, (unsigned long)my_counter2);
	    abort();
	  }
      }

  return 0;
}
開發者ID:pgerakios,項目名稱:Concurrent-Cyclone-with-inference,代碼行數:32,代碼來源:test_atomic.c

示例2: get_buffers_from_BM

/* get_buffers_from_BM: function used to get buffers to be used for reading data
 * off disks via DM_get
 */
void get_buffers_from_BM(uint64_t buffers_required,
	uri_entry_t *requested_object, nkn_buf_t *buffers[MAX_BUFFERS_FETCH_DM])
{
    nkn_buf_t *buffer = NULL, *attr_buffer_present = NULL;
    char *attr_uri_name = NULL;
    int counter = 0;
    //uint64_t append_offset = 0;
    //char buff[512];
    //memset(buff, 0, sizeof(buff));

    //append_offset = (requested_object->request_offset / DATA_BUFFER_SIZE) *
   //							DATA_BUFFER_SIZE;




    attr_buffer_present = g_hash_table_lookup(attr_hash_table,
					requested_object->uri_name);
    if (!attr_buffer_present) {
	//insert the entry in the hash;
	attr_buffer_present = getFreeAttrBuffer();
	//int len = strlen(requested_object->uri_name);
	attr_uri_name = (char*)calloc(MAX_URI_LEN,1);
	strncpy(attr_uri_name,requested_object->uri_name,
	                                             (MAX_URI_LEN-1));
	attr_buffer_present->uri_name = attr_uri_name;
	g_hash_table_insert(attr_hash_table,
	                             attr_uri_name,attr_buffer_present);
    }
    else if (AO_load(&(attr_buffer_present->ref)) == 0)
    {
       TAILQ_REMOVE(&attrbufferpool_queues[attr_buffer_present->flist],
                                     attr_buffer_present,attrbuffpoolentry);
       //if(present_buffer == buffer)
       //  attr_buffer_present->ref++;
       //                                                                  
    }
    requested_object->attrbuff = attr_buffer_present;
    while(buffers_required != 0) {

	pthread_mutex_lock(&bufferpool_queue_mutex);
	buffer = getFreeBuffer();
	pthread_mutex_unlock(&bufferpool_queue_mutex);
	assert(AO_load(&(buffer->ref))== 0);
	buffer->attrbuf = attr_buffer_present;
	buffers[counter] = buffer;
	buffers[counter]->use++;


	attr_buffer_present->use++;
	attr_buffer_present->use_ts = AO_load(&nkn_cur_ts);
	attr_buffer_present->provider = PROVIDER_DM;
	//append_offset += DATA_BUFFER_SIZE;
	buffers_required--;
	counter++;
    }



}
開發者ID:skizhak,項目名稱:open-media-flow-controller,代碼行數:63,代碼來源:nkn_bm.c

示例3: AO_stack_pop_explicit_aux_acquire

AO_t *
AO_stack_pop_explicit_aux_acquire(volatile AO_t *list, AO_stack_aux * a)
{
  unsigned i;
  int j = 0;
  AO_t first;
  AO_t * first_ptr;
  AO_t next;

 retry:
  first = AO_load(list);
  if (0 == first) return 0;
  /* Insert first into aux black list.                                  */
  /* This may spin if more than AO_BL_SIZE removals using auxiliary     */
  /* structure a are currently in progress.                             */
  for (i = 0; ; )
    {
      if (PRECHECK(a -> AO_stack_bl[i])
          AO_compare_and_swap_acquire(a->AO_stack_bl+i, 0, first))
        break;
      ++i;
      if ( i >= AO_BL_SIZE )
        {
          i = 0;
          AO_pause(++j);
        }
    }
  assert(i < AO_BL_SIZE);
  assert(a -> AO_stack_bl[i] == first);
  /* First is on the auxiliary black list.  It may be removed by        */
  /* another thread before we get to it, but a new insertion of x       */
  /* cannot be started here.                                            */
  /* Only we can remove it from the black list.                         */
  /* We need to make sure that first is still the first entry on the    */
  /* list.  Otherwise it's possible that a reinsertion of it was        */
  /* already started before we added the black list entry.              */
  if (AO_EXPECT_FALSE(first != AO_load(list))) {
    AO_store_release(a->AO_stack_bl+i, 0);
    goto retry;
  }
  first_ptr = AO_REAL_NEXT_PTR(first);
  next = AO_load(first_ptr);
  if (AO_EXPECT_FALSE(!AO_compare_and_swap_release(list, first, next))) {
    AO_store_release(a->AO_stack_bl+i, 0);
    goto retry;
  }
  assert(*list != first);
  /* Since we never insert an entry on the black list, this cannot have */
  /* succeeded unless first remained on the list while we were running. */
  /* Thus its next link cannot have changed out from under us, and we   */
  /* removed exactly one entry and preserved the rest of the list.      */
  /* Note that it is quite possible that an additional entry was        */
  /* inserted and removed while we were running; this is OK since the   */
  /* part of the list following first must have remained unchanged, and */
  /* first must again have been at the head of the list when the        */
  /* compare_and_swap succeeded.                                        */
  AO_store_release(a->AO_stack_bl+i, 0);
  return first_ptr;
}
開發者ID:yroux,項目名稱:libatomic_ops,代碼行數:59,代碼來源:atomic_ops_stack.c

示例4: rtsched_queue_dump_counters

void rtsched_queue_dump_counters(void)
{
    printf("\nglob_rtsched_runnable_q_pushes = %ld",
	    AO_load(&glob_rtsched_runnable_q_pushes));
    printf("\nglob_rtsched_runnable_q_pops = %ld",
	    AO_load(&glob_rtsched_runnable_q_pops));
    printf("\nglob_rtsched_cleanup_q_pushes = %ld",
	    AO_load(&glob_rtsched_cleanup_q_pushes));
    printf("\nglob_rtsched_cleanup_q_pops = %ld", glob_rtsched_cleanup_q_pops);
}
開發者ID:skizhak,項目名稱:open-media-flow-controller,代碼行數:10,代碼來源:nkn_rtsched_task_queue.c

示例5: AO_wait_lock_g

/* may cause starvation ... */
int AO_wait_lock_g( AO_lock_ptr_t lock, AO_lock_val_t self ) {
    AO_lock_t lk_val;
    if( AO_load((ao_t*) lock) == (ao_t) self ) return 0;
    while( AO_compare_and_swap_release((ao_t *)lock,(ao_t )0,(ao_t) self) == 0 ) {
        lk_val = AO_load((ao_t*) lock);
        if( lk_val  == 0 ) continue;
        futex_wait(lock,lk_val);
    }
    return 1;
}
開發者ID:pgerakios,項目名稱:Concurrent-Cyclone-with-inference,代碼行數:11,代碼來源:atomic_ops.c

示例6: AO_stack_push_explicit_aux_release

/* pointers with extra bits "or"ed into the low order bits.             */
void
AO_stack_push_explicit_aux_release(volatile AO_t *list, AO_t *x,
                                   AO_stack_aux *a)
{
  AO_t x_bits = (AO_t)x;
  AO_t next;

  /* No deletions of x can start here, since x is not currently in the  */
  /* list.                                                              */
 retry:
# if AO_BL_SIZE == 2
  {
    /* Start all loads as close to concurrently as possible. */
    AO_t entry1 = AO_load(a -> AO_stack_bl);
    AO_t entry2 = AO_load(a -> AO_stack_bl + 1);
    if (entry1 == x_bits || entry2 == x_bits)
      {
        /* Entry is currently being removed.  Change it a little.       */
          ++x_bits;
          if ((x_bits & AO_BIT_MASK) == 0)
            /* Version count overflowed;         */
            /* EXTREMELY unlikely, but possible. */
            x_bits = (AO_t)x;
        goto retry;
      }
  }
# else
  {
    int i;
    for (i = 0; i < AO_BL_SIZE; ++i)
      {
        if (AO_load(a -> AO_stack_bl + i) == x_bits)
          {
            /* Entry is currently being removed.  Change it a little.   */
              ++x_bits;
              if ((x_bits & AO_BIT_MASK) == 0)
                /* Version count overflowed;         */
                /* EXTREMELY unlikely, but possible. */
                x_bits = (AO_t)x;
            goto retry;
          }
      }
  }
# endif
  /* x_bits is not currently being deleted */
  do
    {
      next = AO_load(list);
      *x = next;
    }
  while (AO_EXPECT_FALSE(!AO_compare_and_swap_release(list, next, x_bits)));
}
開發者ID:chipdude,項目名稱:MoarVM,代碼行數:53,代碼來源:atomic_ops_stack.c

示例7: return_buffers_to_client

/* return_buffers_to_client: used to simulate the communication after a DM_get
 * to send buffers back to the client.
 * Also stores the buffers into the cache. (only if the buffer was not 
 * previously present in the cache
 */
void return_buffers_to_client(uint64_t buffers_required,
    uri_entry_t *requested_object, nkn_buf_t *buffers[MAX_BUFFERS_FETCH_DM])
{

    uint64_t counter = 0;
    nkn_buf_t *present_buffer = NULL;

    while(counter != buffers_required)
    {

	//total_dup_bytes_delivered += (buffers[counter])->length;
	//total_bytes_delivered += (buffers[counter])->length;
	present_buffer = g_hash_table_lookup(uri_hash_table,
		(buffers[counter])->uri_name);

	if (present_buffer == NULL) {

	    //this is a new buffer
	    //insert into the hash table
	    //insert into requested_obj->databufs
	    //inc ref count
	    //inc attrbuff refcount
	    //inc total bytes in ram
	    g_hash_table_insert(uri_hash_table, buffers[counter]->uri_name,
					 buffers[counter]);

	    requested_object->data_bufs[requested_object->buffer_fetch_count++]=
							    buffers[counter];
	    AO_fetch_and_add1(&((buffers[counter])->ref));
	    assert(AO_load(&((buffers[counter])->ref)) == 1);
	    ((buffers[counter])->attrbuf)->buffer_count++;
	    AO_fetch_and_add1(&(((buffers[counter])->attrbuf)->ref));

	    total_bytes_in_ram += (buffers[counter])->length;

	}
	else {
	    free((buffers[counter])->uri_name);
	    assert(AO_load(&(buffers[counter]->ref)) == 0);
	    makeBufferAvailable(buffers[counter]);

	}
	counter++;
    }





}
開發者ID:skizhak,項目名稱:open-media-flow-controller,代碼行數:55,代碼來源:nkn_bm.c

示例8: main

int main(void)
{
    int i;
# ifdef GC_PTHREADS
    int err;
    pthread_t th[INITIAL_THREAD_COUNT];
# else
    HANDLE th[INITIAL_THREAD_COUNT];
# endif

    GC_INIT();
    for (i = 0; i < INITIAL_THREAD_COUNT; ++i) {
#     ifdef GC_PTHREADS
        err = pthread_create(&th[i], NULL, entry, 0);
        if (err) {
            fprintf(stderr, "Thread creation failed: %s", strerror(err));
            exit(1);
        }
#     else
        DWORD thread_id;
        th[i] = CreateThread(NULL, 0, entry, 0, 0, &thread_id);
        if (th[i] == NULL) {
            printf("Thread creation failed: %d\n", (int)GetLastError());
            exit(1);
        }
#     endif
    }

    for (i = 0; i < INITIAL_THREAD_COUNT; ++i) {
#     ifdef GC_PTHREADS
        void *res;
        err = pthread_join(th[i], &res);
        if (err) {
            fprintf(stderr, "Failed to join thread: %s", strerror(err));
            exit(1);
        }
#     else
        if (WaitForSingleObject(th[i], INFINITE) != WAIT_OBJECT_0) {
            printf("Failed to join thread: %d\n", (int)GetLastError());
            CloseHandle(th[i]);
            exit(1);
        }
        CloseHandle(th[i]);
#     endif
    }
  printf("subthread_create: created %d threads (%d ended)\n",
         (int)AO_load(&thread_created_cnt), (int)AO_load(&thread_ended_cnt));
  return 0;
}
開發者ID:mcandre,項目名稱:bdwgc,代碼行數:49,代碼來源:subthread_create.c

示例9: AO_unlock

int  AO_unlock( AO_lock_ptr_t lock ) {
    pthread_t self = pthread_self();
    if( AO_load((ao_t*) lock) != (ao_t) self ) return 0;
    AO_store_release(lock,0);
    futex_wake(lock,1); // wake up exactly one thread
    return 1;
}
開發者ID:pgerakios,項目名稱:Concurrent-Cyclone-with-inference,代碼行數:7,代碼來源:atomic_ops.c

示例10: ns_stat_add

int
ns_stat_add(ns_stat_token_t	stoken,
            ns_stat_category_t	stat_type,
            int64_t		add_val,
            int64_t		*old_val)
{
    int64_t  tmp_val;
    uint32_t ns_index = stoken.u.stat_token_data.val;
    uint32_t gen = stoken.u.stat_token_data.gen;
    uint32_t curr_gen;

    curr_gen = (uint32_t) AO_load(&ns_token_gen[ns_index]);
    if (curr_gen != gen) {
        glob_ns_stat_add_gen_mismatch_err++;
        return NKN_STAT_GEN_MISMATCH;
    }

    if (stat_type >= NS_STAT_MAX) {
        glob_ns_stat_add_type_einval_err++;
        return NKN_STAT_TYPE_EINVAL;
    }

    tmp_val = AO_fetch_and_add(&ns_stats[ns_index][stat_type], add_val);

    if (old_val)
        *old_val = tmp_val;
    return 0;
}	/* ns_stat_add */
開發者ID:skizhak,項目名稱:open-media-flow-controller,代碼行數:28,代碼來源:nkn_namespace_stats.c

示例11: traces_obtain_log_line_number

static inline int traces_obtain_log_line_number(void)
{
	int linenum;

	while (1) {
		/* wait for buffer to be emptied */
		while (AO_load(&traces->logcnt) > LAST_LOGLINE);

		while (AO_test_and_set(&traces->lock) == AO_TS_SET);
		
		/* new line will be used! */
		AO_fetch_and_add1(&traces->usecnt);
		
		/* get log line number */
		linenum = AO_fetch_and_add1(&traces->logcnt);

		AO_CLEAR(&traces->lock);

		/* line number with valid properties has been acquired so leave */
		if (linenum <= LAST_LOGLINE)
			break;
		
		/* release non-existing line number */
		AO_fetch_and_sub1(&traces->usecnt);
	}
	
	DEBUG("linenum = %d", linenum);

	/* linenum is storing now a unique number n, such as 0 <= n <= LAST_LOGLINE */
	return linenum;
}
開發者ID:cahirwpz,項目名稱:mneme,代碼行數:31,代碼來源:traces.c

示例12: _gcollect_proc

static void *
_gcollect_proc(void *arg)
{
    while (AO_load(&pending))
	GC_gcollect();
    return NULL;
}
開發者ID:paurkedal,項目名稱:culibs,代碼行數:7,代碼來源:halloc_t1.c

示例13: traces_log_write_out

static void traces_log_write_out(void)
{
	DEBUG("begin");
	
	/* disallow to obtain new lines */
	while (AO_test_and_set(&traces->lock) == AO_TS_SET);

	/* if any line is still used, wait for it to be released */
	while (AO_load(&traces->usecnt) > 0);

	int lines = (traces->logcnt >= LAST_LOGLINE) ? (LAST_LOGLINE - 1) : traces->logcnt;
	
	if (lines > 0) {
		if (write(traces->logfd, &traces->logs, lines * sizeof(traces_log_t)) == -1)
			perror("traces: writing out failed: ");
		else
			DEBUG("written out %d lines", lines);
	}
	
	memset(&traces->logs, 0, (LAST_LOGLINE - 1) * sizeof(traces_log_t));

	/* reset line log counter */
	AO_store(&traces->logcnt, 0);
	AO_CLEAR(&traces->lock);
	
	DEBUG("finished");
}
開發者ID:cahirwpz,項目名稱:mneme,代碼行數:27,代碼來源:traces.c

示例14: acqrel_thr

void * acqrel_thr(void *id)
{
  int me = (int)(AO_PTRDIFF_T)id;

  int i;

  for (i = 0; i < NITERS; ++i)
    if (me & 1)
      {
        AO_t my_counter1;
        if (me != 1)
          {
            fprintf(stderr, "acqrel test: too many threads\n");
            abort();
          }
        my_counter1 = AO_load(&counter1);
        AO_store(&counter1, my_counter1 + 1);
        AO_store_release_write(&counter2, my_counter1 + 1);
      }
    else
      {
        AO_t my_counter1a, my_counter2a;
        AO_t my_counter1b, my_counter2b;

        my_counter2a = AO_load_acquire_read(&counter2);
        my_counter1a = AO_load(&counter1);
        /* Redo this, to make sure that the second load of counter1 */
        /* is not viewed as a common subexpression.         */
        my_counter2b = AO_load_acquire_read(&counter2);
        my_counter1b = AO_load(&counter1);
        if (my_counter1a < my_counter2a)
          {
            fprintf(stderr, "Saw release store out of order: %lu < %lu\n",
                (unsigned long)my_counter1a, (unsigned long)my_counter2a);
            abort();
          }
        if (my_counter1b < my_counter2b)
          {
            fprintf(stderr,
                "Saw release store out of order (bad CSE?): %lu < %lu\n",
                (unsigned long)my_counter1b, (unsigned long)my_counter2b);
            abort();
          }
      }

  return 0;
}
開發者ID:ffabbri4,項目名稱:libatomic_ops,代碼行數:47,代碼來源:test_atomic.c

示例15: traces_register_at_exit

static void traces_register_at_exit(void)
{
	/* atexit uses internally malloc ! */
	if ((traces != NULL) && (AO_load(&initcnt) == 0) && (AO_fetch_and_add1(&initcnt) == 0)) {
		DEBUG("initializing atexit handler");
		atexit(&traces_at_exit);
		DEBUG("initialized atexit handler");
	}
}
開發者ID:cahirwpz,項目名稱:mneme,代碼行數:9,代碼來源:traces.c


注:本文中的AO_load函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。