当前位置: 首页>>代码示例>>C++>>正文


C++ HSD_DBG函数代码示例

本文整理汇总了C++中HSD_DBG函数的典型用法代码示例。如果您正苦于以下问题:C++ HSD_DBG函数的具体用法?C++ HSD_DBG怎么用?C++ HSD_DBG使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。


在下文中一共展示了HSD_DBG函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: gpio_irq_handler

static irqreturn_t gpio_irq_handler(int irq, void *dev_id)
{
	struct hsd_info *hi = (struct hsd_info *) dev_id;

	int state = gpio_get_value_cansleep(hi->gpio_detect);

	wake_lock_timeout(&ear_hook_wake_lock, 2 * HZ);

	HSD_DBG("gpio_irq_handler [%d]", state);
	if (state == EARJACK_REMOVED) {
		if (switch_get_state(&hi->sdev) != NO_DEVICE 
#ifdef HEADSET_REMOVE_ERROR
			|| insert_state_check
#endif
			){
			HSD_DBG("==== LGE headset removing\n");
			cancel_delayed_work_sync(&(hi->work_for_insert));
			queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_remove), FSA8008_DETECT_DELAY_MS );
		} else {
			HSD_DBG("err_invalid_state state = %d\n", state);
		}
	} else {
		if (switch_get_state(&hi->sdev) == NO_DEVICE) {
			HSD_DBG("==== LGE headset inserting\n");
			queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_insert), FSA8008_DETECT_DELAY_MS );
		} else {
			HSD_DBG("err_invalid_state state = %d\n", state);
		}
	}

	return IRQ_HANDLED;
}
开发者ID:Rondeau7,项目名称:lge_f6mt_aosp,代码行数:32,代码来源:hds_fsa8008.c

示例2: detect_work

static void detect_work(struct work_struct *work)
{
    int state;
    unsigned long irq_flags;

    local_irq_save(irq_flags);
    disable_irq(hi->irq);
    local_irq_restore(irq_flags);

    state = gpio_get_value(hi->gpio);

    HSD_DBG("hs:%d\n", state);

    local_irq_save(irq_flags);
    enable_irq(hi->irq);
    local_irq_restore(irq_flags);

    if (state != 1) {
        if (switch_get_state(&hi->sdev) == LGE_HEADSET) {
            HSD_DBG("==== LGE headset removing\n");
            remove_headset();
        }
        return;
    }

    if (state == 1) {
        if (switch_get_state(&hi->sdev) == NO_DEVICE) {
            HSD_DBG("==== LGE headset inserting\n");
            insert_headset();
        }
    }
    else {
        HSD_ERR("Invalid state\n");
    }
}
开发者ID:kerneldevs,项目名称:lge-kernel-msm7x27-ics-3.0.8,代码行数:35,代码来源:board-swift-headset.c

示例3: gpio_irq_handler

static irqreturn_t gpio_irq_handler(int irq, void *dev_id)
{
	struct hsd_info *hi = (struct hsd_info *) dev_id;

	int state = gpio_get_value_cansleep(hi->gpio_detect);

	wake_lock_timeout(&ear_hook_wake_lock, 2 * HZ);

	HSD_DBG("gpio_irq_handler [%d]", state);

	if (state == EARJACK_REMOVED) {
/* 2012-12-04 Hoseong Kang([email protected]) do not check headset status before setting work queue [START] */
#if 1
		HSD_DBG("==== LGE headset removing\n");
		cancel_delayed_work_sync(&(hi->work_for_insert));
		queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_remove), FSA8008_DETECT_DELAY_MS );
	} else {
		HSD_DBG("==== LGE headset inserting\n");
		queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_insert), FSA8008_DETECT_DELAY_MS );
#else // origin
		if (switch_get_state(&hi->sdev) != NO_DEVICE) {
			HSD_DBG("==== LGE headset removing\n");
			cancel_delayed_work_sync(&(hi->work_for_insert));
			queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_remove), FSA8008_DETECT_DELAY_MS );
		} else {
			HSD_DBG("err_invalid_state state = %d\n", state);
		}
	} else {
		if (switch_get_state(&hi->sdev) == NO_DEVICE) {
开发者ID:SinxOner,项目名称:android_kernel_lge_p710,代码行数:29,代码来源:fsa8008.c

示例4: button_pressed

static void button_pressed(struct work_struct *work)
{
	struct delayed_work *dwork = container_of(work, struct delayed_work, work);
	struct hsd_info *hi = container_of(dwork, struct hsd_info, work_for_key_pressed);

	if (gpio_get_value_cansleep(hi->gpio_key) != BUTTON_PRESSED) {
		HSD_ERR("button_pressed but actually Fake pressed state!!\n");
		return;
	}
	if (gpio_get_value_cansleep(hi->gpio_detect) == EARJACK_REMOVED
		|| (switch_get_state(&hi->sdev) != LGE_HEADSET)) {
		HSD_ERR("button_pressed but ear jack is plugged out already! just ignore the event.\n");
		return;
	}
	if(atomic_read(&hi->btn_state)) {
		HSD_ERR("button_pressed but already pressed state!!\n");
		return;
	}

	hi->gpio_key_cnt += 1;
	if(hi->gpio_key_cnt < FSA8008_KEY_PRESS_TH_CNT) {
		queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_key_pressed), hi->latency_for_key );
		return;
	}

	HSD_DBG("button_pressed [%d] \n", hi->gpio_key_cnt);

	atomic_set(&hi->btn_state, 1);
	input_report_key(hi->input, hi->key_code, 1);
	input_sync(hi->input);
}
开发者ID:SinxOner,项目名称:android_kernel_lge_p710,代码行数:31,代码来源:fsa8008.c

示例5: remove_headset

static void remove_headset(struct hsd_info *hi)
{
    HSD_DBG("remove_headset");

    gpio_set_value_cansleep(hi->gpio_mic_en, 0);
    if (hi->set_headset_mic_bias) hi->set_headset_mic_bias(FALSE);

    atomic_set(&hi->is_3_pole_or_not, 1);
    mutex_lock(&hi->mutex_lock);
    switch_set_state(&hi->sdev, NO_DEVICE);
    mutex_unlock(&hi->mutex_lock);

    if (atomic_read(&hi->irq_key_enabled)) {
        unsigned long irq_flags;

        local_irq_save(irq_flags);
        disable_irq(hi->irq_key);
        local_irq_restore(irq_flags);
        atomic_set(&hi->irq_key_enabled, FALSE);
    }

    if (atomic_read(&hi->btn_state))
        button_released(hi);

}
开发者ID:mtmichaelson,项目名称:LGE_Connect_Kernel,代码行数:25,代码来源:fsa8008.c

示例6: button_released

static void button_released(struct work_struct *work)
{
	struct delayed_work *dwork = container_of(work, struct delayed_work, work);
	struct hsd_info *hi = container_of(dwork, struct hsd_info, work_for_key_released);

	if (gpio_get_value_cansleep(hi->gpio_key) != BUTTON_RELEASED) {
		HSD_ERR("button_released but actually Fake released state!!\n");
		return;
	}
	if (gpio_get_value_cansleep(hi->gpio_detect) == EARJACK_REMOVED
		|| (switch_get_state(&hi->sdev) != LGE_HEADSET)) {
		HSD_ERR("button_released but ear jack is plugged out already! just ignore the event.\n");
		return;
	}
	if(!atomic_read(&hi->btn_state)) {
		HSD_ERR("button_released but already released state!!\n");
		return;
	}

	HSD_DBG("button_released \n");

	atomic_set(&hi->btn_state, 0);
	hi->gpio_key_cnt = 0;
	input_report_key(hi->input, hi->key_code, 0);
	input_sync(hi->input);
}
开发者ID:SinxOner,项目名称:android_kernel_lge_p710,代码行数:26,代码来源:fsa8008.c

示例7: lge_hsd_remove

static int lge_hsd_remove(struct platform_device *pdev)
{
    struct hsd_info *hi = (struct hsd_info *)platform_get_drvdata(pdev);

    HSD_DBG("lge_hsd_remove");

    if (switch_get_state(&hi->sdev))
        remove_headset(hi);

    input_unregister_device(hi->input);
    switch_dev_unregister(&hi->sdev);

    free_irq(hi->irq_key, 0);
    free_irq(hi->irq_detect, 0);

    gpio_free(hi->gpio_mic_en);
    gpio_free(hi->gpio_key);
    gpio_free(hi->gpio_jpole);
    gpio_free(hi->gpio_detect);

    mutex_destroy(&hi->mutex_lock);

    kfree(hi);

    return 0;
}
开发者ID:mtmichaelson,项目名称:LGE_Connect_Kernel,代码行数:26,代码来源:fsa8008.c

示例8: remove_headset

static void remove_headset(struct hsd_info *hi)
{

	int has_mic = switch_get_state(&hi->sdev);

	HSD_DBG("remove_headset\n");
	if(atomic_read(&hi->is_3_pole_or_not) == 1)
		spmi_write(0x80);
	if(atomic_read(&hi->is_3_pole_or_not) == 0)
		gpio_direction_output(hi->gpio_mic_en, 0);

	atomic_set(&hi->is_3_pole_or_not, 1);
	mutex_lock(&hi->mutex_lock);
	switch_set_state(&hi->sdev, NO_DEVICE);
	mutex_unlock(&hi->mutex_lock);

	input_report_switch(hi->input, SW_HEADPHONE_INSERT, 0);
	if (has_mic == LGE_HEADSET)
		input_report_switch(hi->input, SW_MICROPHONE_INSERT, 0);
	input_sync(hi->input);

	if (atomic_read(&hi->irq_key_enabled)) {
		atomic_set(&hi->irq_key_enabled, FALSE);
	}

	if (atomic_read(&hi->btn_state))
		schedule_delayed_work(&(hi->work_for_key_released_remove),
				hi->latency_for_key );
	atomic_set(&hi->isdetect,FALSE);
}
开发者ID:JSkernel,项目名称:G_pro2_msm8974_JSKernel,代码行数:30,代码来源:hds_max1462x.c

示例9: lge_hsd_remove

static int lge_hsd_remove(struct platform_device *pdev)
{
	struct hsd_info *hi = (struct hsd_info *)platform_get_drvdata(pdev);

	HSD_DBG("lge_hsd_remove");

	if (switch_get_state(&hi->sdev))
#ifdef CONFIG_LGE_AUDIO_FSA8008_MODIFY
		queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_remove), 0 );
#else
		remove_headset(hi);
#endif

	input_unregister_device(hi->input);
	switch_dev_unregister(&hi->sdev);

	free_irq(hi->irq_key, 0);
	free_irq(hi->irq_detect, 0);

	gpio_free(hi->gpio_mic_en);
	gpio_free(hi->gpio_key);
	gpio_free(hi->gpio_jpole);
	gpio_free(hi->gpio_detect);

	mutex_destroy(&hi->mutex_lock);

	kfree(hi);

	return 0;
}
开发者ID:Rondeau7,项目名称:lge_f6mt_aosp,代码行数:30,代码来源:hds_fsa8008.c

示例10: button_irq_handler

static irqreturn_t button_irq_handler(int irq, void *dev_id)
{
	struct hsd_info *hi = (struct hsd_info *) dev_id;

	int value;

	wake_lock_timeout(&ear_hook_wake_lock, 2 * HZ);

	HSD_DBG("button_irq_handler");
/*
	if(gpio_get_value_cansleep(hi->gpio_mic_en) == 0)
	{
        HSD_DBG("button press returned");
        gpio_set_value_cansleep(hi->gpio_mic_en, 1);
		return IRQ_HANDLED;
	}
	*/
	value = gpio_get_value_cansleep(hi->gpio_key);

#ifdef	CONFIG_FSA8008_USE_LOCAL_WORK_QUEUE
	if (value) queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_key_pressed), hi->latency_for_key );
	else queue_delayed_work(local_fsa8008_workqueue, &(hi->work_for_key_released), hi->latency_for_key );
#else
	if (value) schedule_delayed_work(&(hi->work_for_key_pressed), hi->latency_for_key );
	else schedule_delayed_work(&(hi->work_for_key_released), hi->latency_for_key );
#endif

	return IRQ_HANDLED;
}
开发者ID:Rondeau7,项目名称:lge_f6mt_aosp,代码行数:29,代码来源:hds_fsa8008.c

示例11: button_pressed

static void button_pressed(struct work_struct *work)
{
	struct delayed_work *dwork = container_of(work, struct delayed_work, work);
	struct hsd_info *hi = container_of(dwork, struct hsd_info, work_for_key_pressed);
	struct qpnp_vadc_result result;
	int acc_read_value = 0;
	int i, rc;
	struct ear_3button_info_table *table;
	int table_size = ARRAY_SIZE(max1462x_ear_3button_type_data);

	if (hi->gpio_get_value_func(hi->gpio_detect) || (atomic_read(&hi->is_3_pole_or_not))) {
		HSD_ERR("button_pressed but 4 pole ear jack is plugged out already! just ignore the event.\n");
		return;
	}

	rc = qpnp_vadc_read(switch_vadc, P_MUX6_1_1, &result);

	if (rc < 0) {
		if (rc == -ETIMEDOUT) {
			pr_err("[DEBUG] button_pressed : adc read timeout \n");
		} else {
			pr_err("button_pressed: adc read error - %d\n", rc);
		}
	}
	acc_read_value = (int)result.physical;
	pr_info("%s: acc_read_value - %d\n", __func__, acc_read_value);

	for (i = 0; i < table_size; i++) {
		table = &max1462x_ear_3button_type_data[i];
		/*                                  
                                                              
   */
		if ((acc_read_value <= table->PERMISS_REANGE_MAX) &&
				(acc_read_value >= table->PERMISS_REANGE_MIN)) {
			HSD_DBG("button_pressed \n");
			atomic_set(&hi->btn_state, 1);
			switch (table->ADC_HEADSET_BUTTON) {
			case  KEY_MEDIA:
				input_report_key(hi->input, KEY_MEDIA, 1);
				pr_info("%s: KEY_MEDIA \n", __func__);
				break;
			case KEY_VOLUMEUP:
				input_report_key(hi->input, KEY_VOLUMEUP, 1);
				pr_info("%s: KEY_VOLUMEUP \n", __func__);
				break;
			case KEY_VOLUMEDOWN:
				input_report_key(hi->input, KEY_VOLUMEDOWN, 1);
				pr_info("%s: KEY_VOLUMDOWN \n", __func__);
				break;
			default:
				break;
			}
			table->PRESS_OR_NOT = 1;
			input_sync(hi->input);
			break;
		}
	}
	return;
}
开发者ID:romanbb,项目名称:android_kernel_lge_d851,代码行数:59,代码来源:hds_max1462x.c

示例12: insert_headset

static void insert_headset(struct hsd_info *hi)
{
    int earjack_type;

    HSD_DBG("insert_headset");

    if (hi->set_headset_mic_bias) hi->set_headset_mic_bias(TRUE);
    gpio_set_value_cansleep(hi->gpio_mic_en, 1);

    msleep(hi->latency_for_detection);

    earjack_type = gpio_get_value_cansleep(hi->gpio_jpole);

    if (earjack_type == 1) {
        HSD_DBG("3 polarity earjack");

        atomic_set(&hi->is_3_pole_or_not, 1);

        mutex_lock(&hi->mutex_lock);
        switch_set_state(&hi->sdev, LGE_HEADSET_NO_MIC);
        mutex_unlock(&hi->mutex_lock);

        gpio_set_value_cansleep(hi->gpio_mic_en, 0);
        if (hi->set_headset_mic_bias) hi->set_headset_mic_bias(FALSE);

    } else {
        HSD_DBG("4 polarity earjack");

        atomic_set(&hi->is_3_pole_or_not, 0);

        mutex_lock(&hi->mutex_lock);
        switch_set_state(&hi->sdev, LGE_HEADSET);
        mutex_unlock(&hi->mutex_lock);

        if (!atomic_read(&hi->irq_key_enabled)) {
            unsigned long irq_flags;

            local_irq_save(irq_flags);
            enable_irq(hi->irq_key);
            local_irq_restore(irq_flags);

            atomic_set(&hi->irq_key_enabled, TRUE);
        }
    }

}
开发者ID:mtmichaelson,项目名称:LGE_Connect_Kernel,代码行数:46,代码来源:fsa8008.c

示例13: detect_work

static void detect_work(struct work_struct *work)
{
	int state;
	#if 0
	unsigned long irq_flags;
	#endif
	struct delayed_work *dwork = container_of(work, struct delayed_work, work);
	struct hsd_info *hi = container_of(dwork, struct hsd_info, work);

	HSD_DBG("detect_work");

	#if 0
	local_irq_save(irq_flags);
	disable_irq(hi->irq_detect);
	local_irq_restore(irq_flags);
#endif

	printk(KERN_INFO " dev=0x%x\n",(unsigned int)hi);

	state = gpio_get_value_cansleep(hi->gpio_detect);

	if (state == 1) {
		if (switch_get_state(&hi->sdev) != NO_DEVICE) {
			HSD_DBG("==== LGE headset removing\n");
			remove_headset(hi);
		} else {
			HSD_DBG("err_invalid_state state = %d\n", state);
		}
	} else {

		if (switch_get_state(&hi->sdev) == NO_DEVICE) {
			HSD_DBG("==== LGE headset inserting\n");
			insert_headset(hi);
		} else {
			HSD_DBG("err_invalid_state state = %d\n", state);
		}
	}

	#if 0
	local_irq_save(irq_flags);
	enable_irq(hi->irq_detect);
	local_irq_restore(irq_flags);
#endif
}
开发者ID:Rondeau7,项目名称:lge_f6mt_aosp,代码行数:44,代码来源:hds_fsa8008.c

示例14: button_irq_handler

static irqreturn_t button_irq_handler(int irq, void *dev_id)
{
    struct hsd_info *hi = (struct hsd_info *) dev_id;
    int value = 0;
    int fp = read_file(EARJACK_FILENAME);

    if(fp < 0)
    {


        HSD_DBG("button_irq_handler");

        value = gpio_get_value_cansleep(hi->gpio_key);

        if (value) button_pressed(hi);
        else button_released(hi);

        return IRQ_HANDLED;
    }
    else
    {
        if(fp)
        {

            HSD_DBG("button_irq_handler");

            value = gpio_get_value_cansleep(hi->gpio_key);

            if (value) button_pressed(hi);
            else button_released(hi);

            return IRQ_HANDLED;
        }
        else
        {

            return IRQ_NONE;
        }
    }

    return IRQ_NONE;
}
开发者ID:mtmichaelson,项目名称:LGE_Connect_Kernel,代码行数:42,代码来源:fsa8008.c

示例15: lge_hsd_init

static int __init lge_hsd_init(void)
{
    int ret;

    HSD_DBG("lge_hsd_init");
    ret = platform_driver_register(&lge_hsd_driver);
    if (ret) {
        HSD_ERR("Fail to register platform driver\n");
    }

    return ret;
}
开发者ID:mtmichaelson,项目名称:LGE_Connect_Kernel,代码行数:12,代码来源:fsa8008.c


注:本文中的HSD_DBG函数示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。