本文整理匯總了C++中DCC_LOG1函數的典型用法代碼示例。如果您正苦於以下問題:C++ DCC_LOG1函數的具體用法?C++ DCC_LOG1怎麽用?C++ DCC_LOG1使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了DCC_LOG1函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: thinkos_ev_wait_svc
void thinkos_ev_wait_svc(int32_t * arg)
{
unsigned int wq = arg[0];
unsigned int no = wq - THINKOS_EVENT_BASE;
int self = thinkos_rt.active;
unsigned int ev;
#if THINKOS_ENABLE_ARG_CHECK
if (no >= THINKOS_EVENT_MAX) {
DCC_LOG1(LOG_ERROR, "object %d is not an event set!", wq);
arg[0] = THINKOS_EINVAL;
return;
}
#if THINKOS_ENABLE_EVENT_ALLOC
if (__bit_mem_rd(&thinkos_rt.ev_alloc, no) == 0) {
DCC_LOG1(LOG_ERROR, "invalid event set %d!", wq);
arg[0] = THINKOS_EINVAL;
return;
}
#endif
#endif
cm3_cpsid_i();
/* check for any pending unmasked event */
if ((ev = __clz(__rbit(thinkos_rt.ev[no].pend &
thinkos_rt.ev[no].mask))) < 32) {
DCC_LOG2(LOG_MSG, "set=0x%08x msk=0x%08x",
thinkos_rt.ev[no].pend, thinkos_rt.ev[no].mask);
__bit_mem_wr(&thinkos_rt.ev[no].pend, ev, 0);
DCC_LOG2(LOG_INFO, "pending event %d.%d!", wq, ev);
arg[0] = ev;
cm3_cpsie_i();
return;
}
/* insert into the wait queue */
__thinkos_wq_insert(wq, self);
/* wait for event */
/* remove from the ready wait queue */
__bit_mem_wr(&thinkos_rt.wq_ready, thinkos_rt.active, 0);
#if THINKOS_ENABLE_TIMESHARE
/* if the ready queue is empty, collect
the threads from the CPU wait queue */
if (thinkos_rt.wq_ready == 0) {
thinkos_rt.wq_ready = thinkos_rt.wq_tmshare;
thinkos_rt.wq_tmshare = 0;
}
#endif
cm3_cpsie_i();
DCC_LOG2(LOG_INFO, "<%d> waiting for event %d.xx ...", self, wq);
/* signal the scheduler ... */
__thinkos_defer_sched();
}
示例2: __thinkos_idle_init
/* initialize the idle thread */
struct thinkos_context * __thinkos_idle_init(void)
{
struct thinkos_context * idle_ctx;
idle_ctx = (struct thinkos_context *)THINKOS_IDLE_STACK_BASE;
#if THINKOS_IDLE_STACK_BSS
DCC_LOG1(LOG_MSG, "BSS idle stack @ 0x%08x", THINKOS_IDLE_STACK_BASE);
#endif
#if THINKOS_IDLE_STACK_ALLOC
DCC_LOG1(LOG_MSG, "Alloc idle stack @ 0x%08x", THINKOS_IDLE_STACK_BASE);
#endif
idle_ctx->pc = (uint32_t)thinkos_idle_task;
idle_ctx->lr = (uint32_t)__thinkos_thread_exit;
idle_ctx->xpsr = CM_EPSR_T; /* set the thumb bit */
thinkos_rt.ctx[THINKOS_THREAD_IDLE] = idle_ctx;
#if (THINKOS_THREADS_MAX < 32)
/* put the IDLE thread in the ready queue */
__bit_mem_wr(&thinkos_rt.wq_ready, THINKOS_THREADS_MAX, 1);
#endif
#if THINKOS_ENABLE_THREAD_INFO
/* set the IDLE thread info */
thinkos_rt.th_inf[THINKOS_THREAD_IDLE] = &thinkos_idle_inf;
#endif
return idle_ctx;
}
示例3: stm32_flash_erase
int stm32_flash_erase(unsigned int offs, unsigned int len)
{
struct stm32_flash * flash = STM32_FLASH;
uint32_t addr;
uint32_t pecr;
int rem = len;
int cnt;
offs &= ~(FLASH_PAGE_SIZE - 1);
addr = (uint32_t)STM32_MEM_FLASH + offs;
DCC_LOG2(LOG_INFO, "addr=0x%08x len=%d", addr, len);
pecr = flash->pecr;
DCC_LOG1(LOG_INFO, "PECR=0x%08x", pecr);
if (pecr & FLASH_PRGLOCK) {
DCC_LOG(LOG_INFO, "unlocking flash...");
if (pecr & FLASH_PELOCK) {
flash->pekeyr = FLASH_PEKEY1;
flash->pekeyr = FLASH_PEKEY2;
}
flash->prgkeyr= FLASH_PRGKEYR1;
flash->prgkeyr= FLASH_PRGKEYR2;
}
cnt = 0;
rem = len;
while (rem) {
uint32_t pri;
uint32_t sr;
DCC_LOG1(LOG_INFO, "addr=0x%08x", addr);
pri = cm3_primask_get();
cm3_primask_set(1);
sr = stm32l_flash_blk_erase(flash, (uint32_t *)addr);
cm3_primask_set(pri);
if (sr & FLASH_ERR) {
#if DEBUG
DCC_LOG6(LOG_WARNING, "erase failed: %s%s%s%s%s%s",
sr & FLASH_RDERR ? "RDERR" : "",
sr & FLASH_OPTVERRUSR ? "OPTVERRUSR" : "",
sr & FLASH_OPTVERR ? "OPTVERR " : "",
sr & FLASH_SIZERR ? "SIZERR " : "",
sr & FLASH_PGAERR ? "PGAERR" : "",
sr & FLASH_WRPERR ? "WRPERR" : "");
#endif
cnt = -1;
break;
}
addr += FLASH_PAGE_SIZE;
rem -= FLASH_PAGE_SIZE;
cnt += FLASH_PAGE_SIZE;
}
return cnt;
}
示例4: stm32f_serial_init
int stm32f_serial_init(struct stm32f_serial_drv * drv,
unsigned int baudrate, unsigned int flags)
{
struct stm32_usart * uart = drv->uart;
DCC_LOG1(LOG_TRACE, "UART=0x%08x", uart);
DCC_LOG1(LOG_TRACE, "SERIAL_RX_FIFO_LEN=%d", SERIAL_RX_FIFO_LEN);
DCC_LOG1(LOG_TRACE, "SERIAL_TX_FIFO_LEN=%d", SERIAL_TX_FIFO_LEN);
DCC_LOG1(LOG_TRACE, "SERIAL_ENABLE_TX_MUTEX=%d", SERIAL_ENABLE_TX_MUTEX);
drv->rx_flag = thinkos_flag_alloc();
drv->tx_flag = thinkos_flag_alloc();
#if SERIAL_ENABLE_TX_MUTEX
drv->tx_mutex = thinkos_mutex_alloc();
DCC_LOG1(LOG_TRACE, "tx_mutex=%d", drv->tx_mutex);
#endif
drv->tx_fifo.head = drv->tx_fifo.tail = 0;
drv->rx_fifo.head = drv->rx_fifo.tail = 0;
drv->txie = CM3_BITBAND_DEV(&uart->cr1, 7);
thinkos_flag_give(drv->tx_flag);
stm32_usart_init(uart);
stm32_usart_baudrate_set(uart, baudrate);
stm32_usart_mode_set(uart, SERIAL_8N1);
/* enable RX interrupt */
uart->cr1 |= USART_RXNEIE | USART_IDLEIE;
/* enable UART */
stm32_usart_enable(uart);
return 0;
}
示例5: sndbuf_use
sndbuf_t * sndbuf_use(sndbuf_t * buf)
{
uint32_t primask;
/* critical section enter */
primask = cm3_primask_get();
cm3_primask_set(1);
/* check whether the buffer is valid or not */
if (buf == NULL) {
DCC_LOG(LOG_PANIC, "NULL pointer!");
} else {
if (buf->ref == 0) {
DCC_LOG1(LOG_WARNING, "buf=0x%08x invalid!", buf);
buf = NULL;
} else {
DCC_LOG1(LOG_INFO, "buf=%d", buf - (sndbuf_t *)sndbuf_pool.blk);
buf->ref++;
}
}
/* critical section exit */
cm3_primask_set(primask);
return buf;
}
示例6: thinkos_irq_wait_svc
void thinkos_irq_wait_svc(int32_t * arg)
{
unsigned int irq = arg[0];
int32_t self = thinkos_rt.active;
#if THINKOS_ENABLE_ARG_CHECK
if (irq >= THINKOS_IRQ_MAX) {
DCC_LOG1(LOG_ERROR, "invalid IRQ %d!", irq);
arg[0] = THINKOS_EINVAL;
return;
}
#endif
DCC_LOG1(LOG_MSG, "IRQ %d", irq);
/* store the thread info */
thinkos_rt.irq_th[irq] = self;
/* clear pending interrupt */
cm3_irq_pend_clr(irq);
/* enable this interrupt source */
cm3_irq_enable(irq);
/* prepare to wait ... */
__thinkos_wait(self);
}
示例7: serial_ctrl_task
int serial_ctrl_task(struct vcom * vcom)
{
struct serial_dev * serial = vcom->serial;
struct usb_cdc_class * usb = vcom->usb;
struct usb_cdc_state prev_state;
struct usb_cdc_state state;
DCC_LOG1(LOG_TRACE, "[%d] started.", thinkos_thread_self());
usb_cdc_state_get(usb, &prev_state);
while (1) {
usb_cdc_ctrl_event_wait(usb, 0);
usb_cdc_state_get(usb, &state);
#if 0
if (state.cfg != prev_state.cfg) {
DCC_LOG1(LOG_TRACE, "[%d] config changed.", thinkos_thread_self());
prev_state.cfg = state.cfg;
}
if (state.ctrl != prev_state.ctrl) {
DCC_LOG1(LOG_TRACE, "[%d] control changed.", thinkos_thread_self());
prev_state.ctrl = state.ctrl;
}
#endif
}
return 0;
}
示例8: usb_ctrl_task
int usb_ctrl_task(struct vcom * vcom)
{
struct serial_dev * serial = vcom->serial;
struct usb_cdc_class * usb = vcom->usb;
struct usb_cdc_state prev_state;
struct usb_cdc_state state;
DCC_LOG1(LOG_TRACE, "[%d] started.", thinkos_thread_self());
usb_cdc_state_get(usb, &prev_state);
while (1) {
usb_cdc_ctrl_event_wait(usb, 0);
usb_cdc_state_get(usb, &state);
if (memcmp(&state.cfg, &prev_state.cfg, sizeof(struct serial_config)) != 0) {
DCC_LOG1(LOG_TRACE, "[%d] config changed.", thinkos_thread_self());
prev_state.cfg = state.cfg;
}
if (memcmp(&state.ctrl, &prev_state.ctrl, sizeof(struct serial_control)) != 0) {
DCC_LOG1(LOG_TRACE, "[%d] control changed.", thinkos_thread_self());
prev_state.ctrl = state.ctrl;
}
}
return 0;
}
示例9: thinkos_sem_init_svc
void thinkos_sem_init_svc(int32_t * arg)
{
unsigned int wq = arg[0];
unsigned int sem = wq - THINKOS_SEM_BASE;
uint32_t value = (uint32_t)arg[1];
#if THINKOS_ENABLE_ARG_CHECK
if (sem >= THINKOS_SEMAPHORE_MAX) {
DCC_LOG1(LOG_ERROR, "object %d is not a semaphore!", wq);
arg[0] = THINKOS_EINVAL;
return;
}
#if THINKOS_ENABLE_SEM_ALLOC
if (__bit_mem_rd(thinkos_rt.sem_alloc, sem) == 0) {
DCC_LOG1(LOG_ERROR, "invalid semaphore %d!", wq);
arg[0] = THINKOS_EINVAL;
return;
}
#endif
#endif
DCC_LOG2(LOG_TRACE, "sem[%d] <= %d", sem, value);
thinkos_rt.sem_val[sem] = value;
arg[0] = 0;
}
示例10: uart_console_write
static int uart_console_write(struct uart_console_dev * dev, const void * buf,
unsigned int len)
{
char * cp = (char *)buf;
int c;
int n;
DCC_LOG1(LOG_INFO, "len=%d", len);
#if ENABLE_UART_TX_MUTEX
thinkos_mutex_lock(dev->tx_mutex);
#endif
for (n = 0; n < len; n++) {
c = cp[n];
if (c == '\n') {
DCC_LOG(LOG_INFO, "CR");
uart_putc(dev, '\r');
}
uart_putc(dev, c);
}
#if ENABLE_UART_TX_MUTEX
thinkos_mutex_unlock(dev->tx_mutex);
#endif
DCC_LOG1(LOG_INFO, "cnt=%d", n);
return n;
}
示例11: __attribute__
void __attribute__((noreturn)) serial_recv_task(struct vcom * vcom)
{
struct serial_dev * serial = vcom->serial;
struct usb_cdc_class * cdc = vcom->cdc;
uint8_t buf[VCOM_BUF_SIZE];
int len;
DCC_LOG1(LOG_TRACE, "[%d] started.", thinkos_thread_self());
/* wait for line configuration */
usb_cdc_acm_lc_wait(cdc);
/* enable serial */
serial_enable(serial);
for (;;) {
len = serial_read(serial, buf, VCOM_BUF_SIZE, 1000);
if (len > 0) {
// dbg_write(buf, len);
if (vcom->mode == VCOM_MODE_CONVERTER) {
led_flash(LED_AMBER, 50);
usb_cdc_write(cdc, buf, len);
}
if (vcom->mode == VCOM_MODE_SDU_TRACE) {
led_flash(LED_AMBER, 50);
sdu_decode(buf, len);
}
#if RAW_TRACE
if (len == 1)
DCC_LOG1(LOG_TRACE, "RX: %02x", buf[0]);
else if (len == 2)
DCC_LOG2(LOG_TRACE, "RX: %02x %02x",
buf[0], buf[1]);
else if (len == 3)
DCC_LOG3(LOG_TRACE, "RX: %02x %02x %02x",
buf[0], buf[1], buf[2]);
else if (len == 4)
DCC_LOG4(LOG_TRACE, "RX: %02x %02x %02x %02x",
buf[0], buf[1], buf[2], buf[3]);
else if (len == 5)
DCC_LOG5(LOG_TRACE, "RX: %02x %02x %02x %02x %02x",
buf[0], buf[1], buf[2], buf[3], buf[4]);
else if (len == 6)
DCC_LOG6(LOG_TRACE, "RX: %02x %02x %02x %02x %02x %02x",
buf[0], buf[1], buf[2], buf[3], buf[4], buf[5]);
else if (len == 7)
DCC_LOG7(LOG_TRACE, "RX: %02x %02x %02x %02x %02x %02x %02x ",
buf[0], buf[1], buf[2], buf[3],
buf[4], buf[5], buf[6]);
else
DCC_LOG8(LOG_TRACE, "RX: %02x %02x %02x %02x %02x %02x "
"%02x %02x ...", buf[0], buf[1], buf[2], buf[3],
buf[4], buf[5], buf[6], buf[7]);
#endif
#if SDU_TRACE
RX(buf, len);
#endif
}
}
}
示例12: dac_timer_init
static void dac_timer_init(uint32_t freq)
{
struct stm32f_rcc * rcc = STM32F_RCC;
struct stm32f_tim * tim = STM32F_TIM2;
uint32_t div;
uint32_t pre;
uint32_t n;
/* get the total divisior */
div = ((stm32f_tim1_hz) + (freq / 2)) / freq;
/* get the minimum pre scaler */
pre = (div / 65536) + 1;
/* get the reload register value */
n = (div * 2 + pre) / (2 * pre);
DCC_LOG1(LOG_TRACE, "stm32f_tim1_hz=%dHz", stm32f_tim1_hz);
DCC_LOG3(LOG_TRACE, "freq=%dHz pre=%d n=%d", freq, pre, n);
DCC_LOG1(LOG_TRACE, "real freq=%dHz\n", stm32f_tim1_hz / pre / n);
/* Timer clock enable */
rcc->apb1enr |= RCC_TIM2EN;
/* Timer configuration */
tim->psc = pre - 1;
tim->arr = n - 1;
tim->cnt = 0;
tim->egr = 0;
tim->dier = TIM_UIE; /* Update interrupt enable */
tim->ccmr1 = TIM_OC1M_PWM_MODE1;
tim->ccr1 = tim->arr / 2;
tim->cr2 = TIM_MMS_OC1REF;
}
示例13: serdrv_send
int serdrv_send(struct serdrv * dev, const void * buf, int len)
{
uint8_t * cp = (uint8_t *)buf;
int rem = len;
DCC_LOG1(LOG_INFO, "len=%d", len);
while (rem) {
unsigned int head;
int free;
int n;
int i;
thinkos_flag_take(SERDRV_TX_FLAG);
head = dev->tx_fifo.head;
free = UART_TX_FIFO_BUF_LEN - (int8_t)(head - dev->tx_fifo.tail);
DCC_LOG3(LOG_MSG, "head=%d tail=%d n=%d", head, dev->tx_fifo.tail, n);
n = MIN(rem, free);
for (i = 0; i < n; ++i)
dev->tx_fifo.buf[head++ & (UART_TX_FIFO_BUF_LEN - 1)] = *cp++;
dev->tx_fifo.head = head;
*dev->txie = 1;
if (free > n)
thinkos_flag_give(SERDRV_TX_FLAG);
rem -= n;
DCC_LOG1(LOG_INFO, "rem=%d", rem);
}
return len;
}
示例14: thinkos_sem_timedwait_svc
void thinkos_sem_timedwait_svc(int32_t * arg)
{
unsigned int wq = arg[0];
unsigned int sem = wq - THINKOS_SEM_BASE;
uint32_t ms = (uint32_t)arg[1];
int self = thinkos_rt.active;
#if THINKOS_ENABLE_ARG_CHECK
if (sem >= THINKOS_SEMAPHORE_MAX) {
DCC_LOG1(LOG_ERROR, "object %d is not a semaphore!", wq);
arg[0] = THINKOS_EINVAL;
return;
}
#if THINKOS_ENABLE_SEM_ALLOC
if (__bit_mem_rd(thinkos_rt.sem_alloc, sem) == 0) {
DCC_LOG1(LOG_ERROR, "invalid semaphore %d!", wq);
arg[0] = THINKOS_EINVAL;
return;
}
#endif
#endif
/* avoid possible race condition on sem_val */
/* this is only necessary in case we use the __uthread_sem_post() call
inside interrupt handlers */
/* TODO: study the possibility of using exclusive access instead of
disabling interrupts. */
cm3_cpsid_i();
if (thinkos_rt.sem_val[sem] > 0) {
thinkos_rt.sem_val[sem]--;
arg[0] = 0;
} else {
/* insert into the semaphore wait queue */
__thinkos_tmdwq_insert(wq, self, ms);
DCC_LOG2(LOG_INFO, "<%d> waiting on semaphore %d...", self, wq);
/* wait for event */
/* remove from the ready wait queue */
__bit_mem_wr(&thinkos_rt.wq_ready, self, 0);
#if THINKOS_ENABLE_TIMESHARE
/* if the ready queue is empty, collect
the threads from the CPU wait queue */
if (thinkos_rt.wq_ready == 0) {
thinkos_rt.wq_ready = thinkos_rt.wq_tmshare;
thinkos_rt.wq_tmshare = 0;
}
#endif
/* Set the default return value to timeout. The
sem_post call will change this to 0 */
arg[0] = THINKOS_ETIMEDOUT;
}
/* reenable interrupts ... */
cm3_cpsie_i();
/* signal the scheduler ... */
__thinkos_defer_sched();
}
示例15: __attribute__
void __attribute__((noreturn)) ifnet_input_task(void * arg)
{
struct ifnet * ifn = NULL;
unsigned int proto;
unsigned int idx;
uint8_t * pkt;
uint8_t * src;
int ret;
int len;
for (;;) {
DCC_LOG(LOG_INFO, "wait...");
/* wait for an event form a network interface */
idx = thinkos_ev_wait(__ifnet__.evset);
#if 0
if (idx < 0) {
DCC_LOG1(LOG_ERROR, "thinkos_ev_wait() failed: %d", idx);
abort();
} else if (idx > IFNET_INTERFACES_MAX) {
DCC_LOG1(LOG_ERROR, "thinkos_ev_wait() invalid event: %d", idx);
abort();
}
#endif
/* lookup the interface */
ifn = &__ifnet__.ifn[idx];
/* get the packet from the network interface */
while ((len = ifn_pkt_recv(ifn, &src, &proto, &pkt)) > 0) {
tcpip_net_lock();
NETIF_STAT_ADD(ifn, rx_pkt, 1);
if (proto == NTOHS(ETH_P_IP)) {
DCC_LOG(LOG_INFO, "IP");
DBG("IFNET: IP packet received.");
ret = ip_input(ifn, (struct iphdr *)pkt, len);
} else if (proto == NTOHS(ETH_P_ARP)) {
DCC_LOG(LOG_INFO, "ARP");
ret = etharp_input(ifn, (struct etharp*)pkt, len);
} else {
NETIF_STAT_ADD(ifn, rx_drop, 1);
DCC_LOG1(LOG_TRACE, "unhandled protocol: %d", proto);
WARN("IFNET: unhandled protocol: %d", proto);
ret = 0;
}
tcpip_net_unlock();
if (ret <= 0) {
ifn_pkt_free(ifn, pkt);
} else {
__ifnet__.stats.err++;
WARN("IFNET: not releasing packet: %d", pkt);
}
}
}
}