创建一个可以在kernel4.19下执行的线程,需要同时并发执行这两个函数lcd_bl_set_led_brightness(bl_lvl)和lcd_bias_set_led_brightness(bl_lvl)
时间: 2023-08-15 16:05:27 浏览: 106
在Linux系统中,可以使用pthread库来创建线程。以下是一个示例代码,让你可以在kernel4.19下执行两个函数并发执行:
```c
#include <pthread.h>
void *lcd_bl_set_led_brightness(void *arg) {
// 第一个函数的代码
return NULL;
}
void *lcd_bias_set_led_brightness(void *arg) {
// 第二个函数的代码
return NULL;
}
int main() {
pthread_t thread1, thread2;
int bl_lvl = 50; // 亮度值
// 创建线程,分别执行上面的两个函数
pthread_create(&thread1, NULL, lcd_bl_set_led_brightness, (void *)&bl_lvl);
pthread_create(&thread2, NULL, lcd_bias_set_led_brightness, (void *)&bl_lvl);
// 等待线程结束
pthread_join(thread1, NULL);
pthread_join(thread2, NULL);
return 0;
}
```
这样就可以实现两个函数的并发执行了。注意,在多线程编程中,需要注意线程安全问题,例如共享变量的访问等。
相关问题
创建一个可以在kernel4.19下执行的线程,需要同时调用执行这两个函数
好的,以下是在 kernel4.19 下执行的线程的示例代码,可以同时调用 `lcd_bl_set_led_brightness()` 和 `lcd_bias_set_led_brightness()` 函数:
```c
#include <pthread.h>
#include <stdio.h>
void *thread_function(void *arg)
{
int bl_lvl = *(int*)arg;
// 调用 lcd_bl_set_led_brightness() 函数
lcd_bl_set_led_brightness(bl_lvl);
// 调用 lcd_bias_set_led_brightness() 函数
lcd_bias_set_led_brightness(bl_lvl);
pthread_exit(NULL);
}
int main()
{
pthread_t thread;
int bl_lvl = 50; // 设置 bl_lvl 参数为 50
// 创建线程并调用 thread_function() 函数
int ret = pthread_create(&thread, NULL, thread_function, &bl_lvl);
if (ret != 0) {
printf("Error: pthread_create() failed\n");
return 1;
}
// 等待线程结束
pthread_join(thread, NULL);
return 0;
}
```
这个示例代码中,我们定义了一个 `thread_function()` 函数作为线程的入口函数,它接受一个 `void*` 类型的参数,这个参数指向 `bl_lvl` 变量。在函数中,我们首先将 `bl_lvl` 参数传递给 `lcd_bl_set_led_brightness()` 函数和 `lcd_bias_set_led_brightness()` 函数以调用它们。然后,线程调用 `pthread_exit()` 函数以退出。
在 `main()` 函数中,我们首先定义了一个 `pthread_t` 类型的变量 `thread` 作为线程的标识符,并将 `bl_lvl` 参数设置为 50。然后,我们调用 `pthread_create()` 函数创建线程,并将线程的入口函数设置为 `thread_function()` 函数。如果创建线程成功,`pthread_create()` 函数将返回 0,否则返回一个非零值。在这个示例代码中,如果 `pthread_create()` 函数返回一个非零值,我们将输出一个错误信息并退出程序。
最后,我们调用 `pthread_join()` 函数等待线程结束。这个函数会阻塞当前线程,直到指定的线程结束为止。在这个示例代码中,我们将 `pthread_join()` 函数的第二个参数设置为 `NULL`,表示我们不需要线程的返回值。
如上面贴给你的dsi_panel_set_backlight这个函数,我需要在case DSI_BACKLIGHT_EXTERNAL:下,同时并发执行lcd_bl_set_led_brightness和lcd_bias_set_led_brightness两个函数来设置背光亮度。
要在case DSI_BACKLIGHT_EXTERNAL下同时并发执行lcd_bl_set_led_brightness和lcd_bias_set_led_brightness两个函数来设置背光亮度,可以使用多线程来实现。以下是一个简单的示例代码:
```c
int dsi_panel_set_backlight(struct dsi_panel *panel, u32 bl_lvl) {
int rc = 0;
struct dsi_backlight_config *bl = &panel->bl_config;
if (panel->host_config.ext_bridge_mode)
return 0;
DSI_DEBUG("backlight type:%d lvl:%d\n", bl->type, bl_lvl);
switch (bl->type) {
case DSI_BACKLIGHT_WLED:
rc = backlight_device_set_brightness(bl->raw_bd, bl_lvl);
break;
case DSI_BACKLIGHT_DCS:
rc = dsi_panel_update_backlight(panel, bl_lvl);
break;
case DSI_BACKLIGHT_EXTERNAL:
{
pthread_t thread1, thread2;
int bl_lvl1 = bl_lvl, bl_lvl2 = bl_lvl;
// 创建两个线程,分别执行lcd_bl_set_led_brightness和lcd_bias_set_led_brightness函数
pthread_create(&thread1, NULL, lcd_bl_set_led_brightness, (void *)&bl_lvl1);
pthread_create(&thread2, NULL, lcd_bias_set_led_brightness, (void *)&bl_lvl2);
// 等待线程结束
pthread_join(thread1, NULL);
pthread_join(thread2, NULL);
}
break;
case DSI_BACKLIGHT_PWM:
rc = dsi_panel_update_pwm_backlight(panel, bl_lvl);
break;
default:
DSI_ERR("Backlight type(%d) not supported\n", bl->type);
rc = -ENOTSUPP;
}
return rc;
}
```
在case DSI_BACKLIGHT_EXTERNAL下,我们创建了两个线程,分别执行lcd_bl_set_led_brightness和lcd_bias_set_led_brightness函数。线程的创建和等待使用了pthread库中的函数pthread_create和pthread_join。注意,在多线程编程中,需要注意线程安全问题,例如共享变量的访问等。
阅读全文