1 /* 2 * Copyright (c) 2016 Intel Corporation. 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #include <sample_usbd.h> 8 9 #include <zephyr/kernel.h> 10 #include <zephyr/sys/printk.h> 11 #include <zephyr/usb/usb_device.h> 12 #include <zephyr/usb/usbd.h> 13 #include <zephyr/drivers/uart.h> 14 15 BUILD_ASSERT(DT_NODE_HAS_COMPAT(DT_CHOSEN(zephyr_console), zephyr_cdc_acm_uart), 16 "Console device is not ACM CDC UART device"); 17 18 #if defined(CONFIG_USB_DEVICE_STACK_NEXT) 19 static struct usbd_context *sample_usbd; 20 enable_usb_device_next(void)21static int enable_usb_device_next(void) 22 { 23 int err; 24 25 sample_usbd = sample_usbd_init_device(NULL); 26 if (sample_usbd == NULL) { 27 return -ENODEV; 28 } 29 30 err = usbd_enable(sample_usbd); 31 if (err) { 32 return err; 33 } 34 35 return 0; 36 } 37 #endif /* defined(CONFIG_USB_DEVICE_STACK_NEXT) */ 38 main(void)39int main(void) 40 { 41 const struct device *const dev = DEVICE_DT_GET(DT_CHOSEN(zephyr_console)); 42 uint32_t dtr = 0; 43 44 #if defined(CONFIG_USB_DEVICE_STACK_NEXT) 45 if (enable_usb_device_next()) { 46 return 0; 47 } 48 #else 49 if (usb_enable(NULL)) { 50 return 0; 51 } 52 #endif 53 54 /* Poll if the DTR flag was set */ 55 while (!dtr) { 56 uart_line_ctrl_get(dev, UART_LINE_CTRL_DTR, &dtr); 57 /* Give CPU resources to low priority threads. */ 58 k_sleep(K_MSEC(100)); 59 } 60 61 while (1) { 62 printk("Hello World! %s\n", CONFIG_ARCH); 63 k_sleep(K_SECONDS(1)); 64 } 65 } 66