udl_drv.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. /*
  2. * Copyright (C) 2012 Red Hat
  3. *
  4. * based in parts on udlfb.c:
  5. * Copyright (C) 2009 Roberto De Ioris <roberto@unbit.it>
  6. * Copyright (C) 2009 Jaya Kumar <jayakumar.lkml@gmail.com>
  7. * Copyright (C) 2009 Bernie Thompson <bernie@plugable.com>
  8. *
  9. * This file is subject to the terms and conditions of the GNU General Public
  10. * License v2. See the file COPYING in the main directory of this archive for
  11. * more details.
  12. */
  13. #ifndef UDL_DRV_H
  14. #define UDL_DRV_H
  15. #include <linux/usb.h>
  16. #define DRIVER_NAME "udl"
  17. #define DRIVER_DESC "DisplayLink"
  18. #define DRIVER_DATE "20120220"
  19. #define DRIVER_MAJOR 0
  20. #define DRIVER_MINOR 0
  21. #define DRIVER_PATCHLEVEL 1
  22. struct udl_device;
  23. struct urb_node {
  24. struct list_head entry;
  25. struct udl_device *dev;
  26. struct delayed_work release_urb_work;
  27. struct urb *urb;
  28. };
  29. struct urb_list {
  30. struct list_head list;
  31. spinlock_t lock;
  32. struct semaphore limit_sem;
  33. int available;
  34. int count;
  35. size_t size;
  36. };
  37. struct udl_fbdev;
  38. struct udl_device {
  39. struct device *dev;
  40. struct drm_device *ddev;
  41. int sku_pixel_limit;
  42. struct urb_list urbs;
  43. atomic_t lost_pixels; /* 1 = a render op failed. Need screen refresh */
  44. struct udl_fbdev *fbdev;
  45. char mode_buf[1024];
  46. uint32_t mode_buf_len;
  47. atomic_t bytes_rendered; /* raw pixel-bytes driver asked to render */
  48. atomic_t bytes_identical; /* saved effort with backbuffer comparison */
  49. atomic_t bytes_sent; /* to usb, after compression including overhead */
  50. atomic_t cpu_kcycles_used; /* transpired during pixel processing */
  51. };
  52. struct udl_gem_object {
  53. struct drm_gem_object base;
  54. struct page **pages;
  55. void *vmapping;
  56. struct sg_table *sg;
  57. };
  58. #define to_udl_bo(x) container_of(x, struct udl_gem_object, base)
  59. struct udl_framebuffer {
  60. struct drm_framebuffer base;
  61. struct udl_gem_object *obj;
  62. bool active_16; /* active on the 16-bit channel */
  63. };
  64. #define to_udl_fb(x) container_of(x, struct udl_framebuffer, base)
  65. /* modeset */
  66. int udl_modeset_init(struct drm_device *dev);
  67. void udl_modeset_cleanup(struct drm_device *dev);
  68. int udl_connector_init(struct drm_device *dev, struct drm_encoder *encoder);
  69. struct drm_encoder *udl_encoder_init(struct drm_device *dev);
  70. struct urb *udl_get_urb(struct drm_device *dev);
  71. int udl_submit_urb(struct drm_device *dev, struct urb *urb, size_t len);
  72. void udl_urb_completion(struct urb *urb);
  73. int udl_driver_load(struct drm_device *dev, unsigned long flags);
  74. int udl_driver_unload(struct drm_device *dev);
  75. int udl_fbdev_init(struct drm_device *dev);
  76. void udl_fbdev_cleanup(struct drm_device *dev);
  77. void udl_fbdev_unplug(struct drm_device *dev);
  78. struct drm_framebuffer *
  79. udl_fb_user_fb_create(struct drm_device *dev,
  80. struct drm_file *file,
  81. struct drm_mode_fb_cmd2 *mode_cmd);
  82. int udl_render_hline(struct drm_device *dev, int bpp, struct urb **urb_ptr,
  83. const char *front, char **urb_buf_ptr,
  84. u32 byte_offset, u32 byte_width,
  85. int *ident_ptr, int *sent_ptr);
  86. int udl_dumb_create(struct drm_file *file_priv,
  87. struct drm_device *dev,
  88. struct drm_mode_create_dumb *args);
  89. int udl_gem_mmap(struct drm_file *file_priv, struct drm_device *dev,
  90. uint32_t handle, uint64_t *offset);
  91. int udl_dumb_destroy(struct drm_file *file_priv, struct drm_device *dev,
  92. uint32_t handle);
  93. int udl_gem_init_object(struct drm_gem_object *obj);
  94. void udl_gem_free_object(struct drm_gem_object *gem_obj);
  95. struct udl_gem_object *udl_gem_alloc_object(struct drm_device *dev,
  96. size_t size);
  97. struct drm_gem_object *udl_gem_prime_import(struct drm_device *dev,
  98. struct dma_buf *dma_buf);
  99. int udl_gem_vmap(struct udl_gem_object *obj);
  100. void udl_gem_vunmap(struct udl_gem_object *obj);
  101. int udl_drm_gem_mmap(struct file *filp, struct vm_area_struct *vma);
  102. int udl_gem_fault(struct vm_area_struct *vma, struct vm_fault *vmf);
  103. int udl_handle_damage(struct udl_framebuffer *fb, int x, int y,
  104. int width, int height);
  105. int udl_drop_usb(struct drm_device *dev);
  106. #define CMD_WRITE_RAW8 "\xAF\x60" /**< 8 bit raw write command. */
  107. #define CMD_WRITE_RL8 "\xAF\x61" /**< 8 bit run length command. */
  108. #define CMD_WRITE_COPY8 "\xAF\x62" /**< 8 bit copy command. */
  109. #define CMD_WRITE_RLX8 "\xAF\x63" /**< 8 bit extended run length command. */
  110. #define CMD_WRITE_RAW16 "\xAF\x68" /**< 16 bit raw write command. */
  111. #define CMD_WRITE_RL16 "\xAF\x69" /**< 16 bit run length command. */
  112. #define CMD_WRITE_COPY16 "\xAF\x6A" /**< 16 bit copy command. */
  113. #define CMD_WRITE_RLX16 "\xAF\x6B" /**< 16 bit extended run length command. */
  114. #endif