本文整理匯總了C++中AM_DEBUG函數的典型用法代碼示例。如果您正苦於以下問題:C++ AM_DEBUG函數的具體用法?C++ AM_DEBUG怎麽用?C++ AM_DEBUG使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了AM_DEBUG函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: AM_LocalConnect
/**\brief 通過本地socket連接到服務
* \param[in] name 服務名稱
* \param[out] fd 返回socket
* \return
* - AM_SUCCESS 成功
* - 其他值 錯誤代碼
*/
AM_ErrorCode_t AM_LocalConnect(const char *name, int *fd)
{
struct sockaddr_un addr;
int s, ret;
#if 0
assert(name && fd);
s = socket(AF_LOCAL, SOCK_STREAM, 0);
if(s==-1)
{
AM_DEBUG(1, "cannot create local socket \"%s\"", strerror(errno));
return AM_FAILURE;
}
addr.sun_family = AF_LOCAL;
strncpy(addr.sun_path, name, sizeof(addr.sun_path)-1);
ret = connect(s, (struct sockaddr*)&addr, SUN_LEN(&addr));
if(ret==-1)
{
AM_DEBUG(1, "connect to \"%s\" failed \"%s\"", name, strerror(errno));
close(s);
return AM_FAILURE;
}
*fd = s;
#endif
return AM_SUCCESS;
}
示例2: AM_OSD_MapPixel
/**\brief 將像素映射為顏色
* \param[in] fmt 圖形模式
* \param[in] pix 像素值
* \param[out] col 返回映射的顏色值
* \return
* - AM_SUCCESS 成功
* - 其他值 錯誤代碼(見am_osd.h)
*/
AM_ErrorCode_t AM_OSD_MapPixel(AM_OSD_PixelFormat_t *fmt, uint32_t pix, AM_OSD_Color_t *col)
{
assert(fmt && col);
if(AM_OSD_PIXEL_FORMAT_TYPE_IS_PALETTE(fmt->type))
{
if(pix>=fmt->palette.color_count)
{
AM_DEBUG(1, "illegal pixel, must in (0~%d)", fmt->palette.color_count-1);
return AM_OSD_ERR_ILLEGAL_PIXEL;
}
*col = fmt->palette.colors[pix];
}
else if(AM_OSD_PIXEL_FORMAT_TYPE_IS_YUV(fmt->type))
{
AM_DEBUG(1, "cannot map YUV pixel to color");
return AM_OSD_ERR_NOT_SUPPORTED;
}
else
{
AM_RGB_PIXEL_TO_COLOR(fmt, pix, col);
}
return AM_SUCCESS;
}
示例3: AM_LocalSendCmd
/**\brief 通過本地socket發送命令
* \param fd socket
* \param[in] cmd 命令字符串
* \return
* - AM_SUCCESS 成功
* - 其他值 錯誤代碼
*/
AM_ErrorCode_t AM_LocalSendCmd(int fd, const char *cmd)
{
AM_ErrorCode_t ret;
int len;
assert(cmd);
len = strlen(cmd)+1;
ret = try_write(fd, (const char*)&len, sizeof(int));
if(ret!=AM_SUCCESS)
{
AM_DEBUG(1, "write local socket failed");
return ret;
}
ret = try_write(fd, cmd, len);
if(ret!=AM_SUCCESS)
{
AM_DEBUG(1, "write local socket failed");
return ret;
}
AM_DEBUG(2, "write cmd: %s", cmd);
return AM_SUCCESS;
}
示例4: dvb_open
/****************************************************************************
* Functions
***************************************************************************/
static AM_ErrorCode_t dvb_open (AM_FEND_Device_t *dev, const AM_FEND_OpenPara_t *para)
{
char name[PATH_MAX];
int fd;
#if 1
snprintf(name, sizeof(name), "/dev/dvb0.frontend%d", dev->dev_no);
fd = open(name, O_RDWR);
if(fd==-1)
{
AM_DEBUG(1, "cannot open %s, error:%s", name, strerror(errno));
return AM_FEND_ERR_CANNOT_OPEN;
}
if(ioctl(fd, FE_GET_INFO, &dev->info))
{
close(fd);
AM_DEBUG(1, "cannot get frontend's infomation, error:%s", strerror(errno));
return AM_FEND_ERR_IO;
}
dev->drv_data = (void*)fd;
#endif
return AM_SUCCESS;
}
示例5: AM_LocalGetResp
/**\brief 通過本地socket接收響應字符串
* \param fd socket
* \param[out] buf 緩衝區
* \param len 緩衝區大小
* \return
* - AM_SUCCESS 成功
* - 其他值 錯誤代碼
*/
AM_ErrorCode_t AM_LocalGetResp(int fd, char *buf, int len)
{
AM_ErrorCode_t ret;
int bytes;
assert(buf);
ret = try_read(fd, (char*)&bytes, sizeof(int));
if(ret!=AM_SUCCESS)
{
AM_DEBUG(1, "read local socket failed");
return ret;
}
if(len<bytes)
{
AM_DEBUG(1, "respond buffer is too small");
return AM_FAILURE;
}
ret = try_read(fd, buf, bytes);
if(ret!=AM_SUCCESS)
{
AM_DEBUG(1, "read local socket failed");
return ret;
}
return AM_SUCCESS;
}
示例6: dvb_sec_begin_cb
static AM_ErrorCode_t dvb_sec_begin_cb (void *user_data, const char *sec)
{
AM_DVBConfig_t *conf=(AM_DVBConfig_t*)user_data;
if(conf->in_service_sec)
{
AM_DEBUG(1, "unknown section");
return AM_CFG_ERR_SYNTAX;
}
if(!strcmp(sec, "service"))
{
if(conf->service_count<MAX_SERVICE_COUNT)
{
conf->service_count++;
}
else
{
AM_DEBUG(1, "too many services");
}
conf->in_service_sec = 1;
return AM_SUCCESS;
}
return AM_CFG_ERR_UNKNOWN_TAG;
}
示例7: vol_update
static int vol_update (DTV_Window_t *win, AM_OSD_Surface_t *s)
{
AM_ErrorCode_t ret = AM_SUCCESS;
AM_OSD_Rect_t sr, dr;
int i =0 ,tmp;
ret = AM_AOUT_GetVolume(DTV_AOUT_DEV_NO, &(vol.cur_vol_value));
if(ret!=AM_SUCCESS)
{
printf("AM_AOUT_SetVolume fail!\n");
}
else
{
AM_DEBUG(1, "vol_value = %d",vol.cur_vol_value);
}
//draw vol bar
sr.x = 0;
sr.y = 0;
sr.w = gfx.volume_img->width;
sr.h = gfx.volume_img->height;
dr.x = 300;
dr.y = 450;
dr.w = gfx.volume_img->width;
dr.h = gfx.volume_img->height;
AM_OSD_Blit(gfx.volume_img, &sr, s, &dr, NULL);
if(tmp = vol.cur_vol_value / VOL_VALUE_STEP)
AM_DEBUG(1, "%d\n",tmp);
for(i=0;i<tmp;i++)
{
sr.x = 0;
sr.w = 0;
sr.w = gfx.volume_value_img->width;
sr.h = gfx.volume_value_img->height;
dr.x = 376 + ( i * (gfx.volume_value_img->width + 4));
dr.y = 459;
dr.w = gfx.volume_value_img->width;
dr.h = gfx.volume_value_img->height;
AM_OSD_Blit(gfx.volume_value_img, &sr, s, &dr, NULL);
}
AM_TIME_GetClock(&now);
return 0;
}
示例8: dump_bytes
static void dump_bytes(int dev_no, int fid, const uint8_t *data, int len, void *user_data)
{
FILE *fp;
int did = data[8];
int sec = data[6];
#if 0
if(did!=3)
return;
if(sections[sec].got)
{
if((sections[sec].len!=len) || memcmp(sections[sec].data, data, len))
{
AM_DEBUG(1, "SECTION %d MISMATCH LEN: %d", sec, len);
}
}
else
{
sections[sec].len = len;
sections[sec].got = 1;
memcpy(sections[sec].data, data, len);
AM_DEBUG(1, "GET SECTION %d LEN: %d", sec, len);
}
#endif
#if 0
int did = data[8];
int bid = (data[9]<<24)|(data[10]<<16)|(data[11]<<8)|data[12];
int sec = data[6];
if(did!=3)
return;
if(sec_mask[sec])
return;
sec_mask[sec] = 1;
AM_DEBUG(1, "get section %d", sec);
fseek(fp, bid*4030, SEEK_SET);
fwrite(data+13, 1, len-17, fp);
#endif
#if 1
int i;
printf("section:\n");
for(i=0;i<len;i++)
{
printf("%02x ", data[i]);
if(((i+1)%16)==0) printf("\n");
}
if((i%16)!=0) printf("\n");
#endif
}
示例9: si_section_callback
static void si_section_callback(int dev_no, int fid, const uint8_t *data, int len, void *user_data)
{
int hsi;
int t;
AM_SI_SectionHeader_t header;
void *p_table;
AM_DEBUG(1, "GET A SECTION LEN: %d", len);
t = get_sec_by_hfilter(fid);
if (t == -1)
{
AM_DEBUG(1, "Unknown filter id 0x%x", fid);
return;
}
/*Copy the data*/
memcpy(si_sections[t].data, data, len);
AM_SI_Create(&hsi);
AM_SI_GetSectionHeader(hsi, (uint8_t*)si_sections[t].data, (uint16_t)len, &header);
/*Print the header*/
AM_DEBUG(1, "SectionHeader::\n\ttable_id\t\t0x%x\n\tsyntax_indicator\t0x%x\n\tprv_indicator\t\t0x%x\n\tlength\t\t\t0x%x\n\textension\t\t0x%x\n\tverion\t\t\t0x%x\n\tcur_next\t\t0x%x\n\tsec_num\t\t\t0x%x\n\tlast_sec_num\t\t0x%x",
header.table_id,header.syntax_indicator,header.private_indicator,
header.length, header.extension, header.version,
header.cur_next_indicator, header.sec_num, header.last_sec_num);
/*Decode*/
if (AM_SI_DecodeSection(hsi, si_sections[t].pid,
(uint8_t*)si_sections[t].data,
(uint16_t)len, &p_table) == AM_SUCCESS)
{
AM_DEBUG(1, "Section Successfully decoded");
/*Print detail*/
if (si_sections[t].print)
si_sections[t].print(p_table);
AM_SI_ReleaseSection(hsi, p_table->i_table_id, (void*)p_table);
}
else
{
AM_DEBUG(1, "Section decoded failed");
}
AM_SI_Destroy(hsi);
si_sections[t].last_sec = header.last_sec_num;
/*Start next section receive*/
si_test_table_start_next_section(t);
}
示例10: AM_CFG_Value2Int
/**\brief 將字符串值轉化為整數
* \param[in] value 字符串值
* \param[out] pv 輸出整數的指針
* \return
* - AM_SUCCESS 成功
* - 其他值 錯誤代碼(見am_cfg.h)
*/
AM_ErrorCode_t AM_CFG_Value2Int(const char *value, int *pv)
{
int rc;
assert(value && pv);
if(value[0]=='0')
{
if((value[1]=='x')||(value[1]=='X'))
{
rc = sscanf(value+2, "%x", pv);
}
else
{
rc = sscanf(value, "%o", pv);
}
}
else
{
rc = sscanf(value, "%d", pv);
}
if(rc!=1)
{
AM_DEBUG(1, "key is not an integer");
return AM_CFG_ERR_BAD_FOTMAT;
}
return AM_SUCCESS;
}
示例11: AM_EVT_Subscribe
/**\brief 注冊一個事件回調函數
* \param dev_no 回調函數對應的設備ID
* \param event_type 回調函數對應的事件類型
* \param cb 回調函數指針
* \param data 傳遞給回調函數的用戶定義參數
* \return
* - AM_SUCCESS 成功
* - 其他值 錯誤代碼
*/
AM_ErrorCode_t AM_EVT_Subscribe(int dev_no, int event_type, AM_EVT_Callback_t cb, void *data)
{
AM_Event_t *evt;
int pos;
assert(cb);
/*分配事件*/
evt = malloc(sizeof(AM_Event_t));
if(!evt)
{
AM_DEBUG(1, "not enough memory");
return AM_EVT_ERR_NO_MEM;
}
evt->dev_no = dev_no;
evt->type = event_type;
evt->cb = cb;
evt->data = data;
pos = event_type%AM_EVT_BUCKET_COUNT;
/*加入事件哈希表中*/
pthread_mutex_lock(&lock);
evt->next = events[pos];
events[pos] = evt;
pthread_mutex_unlock(&lock);
return AM_SUCCESS;
}
示例12: table_cell_create
/**\brief 創建一個單元格控件*/
static AM_ErrorCode_t table_cell_create(AM_GUI_Table_t *tab, AM_GUI_Widget_t **cell, int row, int col, int hspan, int vspan)
{
AM_GUI_TableCell_t *c;
AM_ErrorCode_t ret;
c = (AM_GUI_TableCell_t*)malloc(sizeof(AM_GUI_TableCell_t));
if(!cell)
{
AM_DEBUG(1, "not enough memory");
return AM_GUI_ERR_NO_MEM;
}
ret = AM_GUI_WidgetInit(AM_GUI_WIDGET(tab)->gui, AM_GUI_WIDGET(c));
if(ret!=AM_SUCCESS)
{
free(c);
return ret;
}
AM_GUI_WIDGET(c)->type = AM_GUI_WIDGET_TABLE_CELL;
c->row = row;
c->col = col;
c->hspan = hspan;
c->vspan = vspan;
*cell = AM_GUI_WIDGET(c);
return AM_SUCCESS;
}
示例13: dvb_set_source
static AM_ErrorCode_t dvb_set_source(AM_DMX_Device_t *dev, AM_DMX_Source_t src)
{
char buf[32];
char *cmd;
snprintf(buf, sizeof(buf), "/sys/class/stb/demux%d_source", dev->dev_no);
switch(src)
{
case AM_DMX_SRC_TS0:
cmd = "ts0";
break;
case AM_DMX_SRC_TS1:
cmd = "ts1";
break;
case AM_DMX_SRC_TS2:
cmd = "ts2";
break;
case AM_DMX_SRC_HIU:
cmd = "hiu";
break;
default:
AM_DEBUG(1, "do not support demux source %d", src);
return AM_DMX_ERR_NOT_SUPPORTED;
}
return AM_FileEcho(buf, cmd);
}
示例14: aml_write
AM_ErrorCode_t aml_write (AM_SMC_Device_t *dev, const uint8_t *data, int *len, int timeout)
{
struct pollfd pfd;
int fd = (int)dev->drv_data;
int ret;
pfd.fd = fd;
pfd.events = POLLOUT;
ret = poll(&pfd, 1, timeout);
if(ret!=1)
{
return AM_SMC_ERR_TIMEOUT;
}
ret = write(fd, data, *len);
if(ret<0)
{
AM_DEBUG(1, "card write error %s", strerror(errno));
return AM_SMC_ERR_IO;
}
*len = ret;
return AM_SUCCESS;
}
示例15: AM_FEND_IBlindScanAPI_Start
/**\brief Performs a blind scan operation.*/
static AM_ErrorCode_t AM_FEND_IBlindScanAPI_Start(int dev_no)
{
AM_FEND_Device_t *dev = NULL;
AM_ErrorCode_t ret = AM_SUCCESS;
fend_get_openned_dev(dev_no, &dev);
if(!dev->drv->blindscan_scan)
{
AM_DEBUG(1, "fronend %d no not support blindscan_scan", dev_no);
return AM_FEND_ERR_NOT_SUPPORTED;
}
pthread_mutex_lock(&dev->lock);
struct dvbsx_blindscanpara * pbsPara = &(dev->bs_setting.bsPara);
/*driver need to set in blindscan mode*/
ret = dev->drv->blindscan_scan(dev, pbsPara);
if(ret != AM_SUCCESS)
{
ret = AM_FEND_ERR_BLINDSCAN;
pthread_mutex_unlock(&dev->lock);
return ret;
}
pthread_mutex_unlock(&dev->lock);
return ret;
}