printk.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. //
  2. // Created by longjin on 2022/1/21.
  3. //
  4. #pragma once
  5. #define PAD_ZERO 1 // 0填充
  6. #define LEFT 2 // 靠左对齐
  7. #define RIGHT 4 // 靠右对齐
  8. #define PLUS 8 // 在正数前面显示加号
  9. #define SPACE 16
  10. #define SPECIAL 32 // 在八进制数前面显示 '0o',在十六进制数前面显示 '0x' 或 '0X'
  11. #define SMALL 64 // 十进制以上数字显示小写字母
  12. #define SIGN 128 // 显示符号位
  13. #define is_digit(c) ((c) >= '0' && (c) <= '9') // 用来判断是否是数字的宏
  14. // 字体颜色的宏定义
  15. #define WHITE 0x00ffffff //白
  16. #define BLACK 0x00000000 //黑
  17. #define RED 0x00ff0000 //红
  18. #define ORANGE 0x00ff8000 //橙
  19. #define YELLOW 0x00ffff00 //黄
  20. #define GREEN 0x0000ff00 //绿
  21. #define BLUE 0x000000ff //蓝
  22. #define INDIGO 0x0000ffff //靛
  23. #define PURPLE 0x008000ff //紫
  24. // 异常的宏定义
  25. #define EPOS_OVERFLOW 1 // 坐标溢出
  26. #define EFB_MISMATCH 2 // 帧缓冲区与指定的屏幕大小不匹配
  27. #define EUNSUPPORTED 3 // 当前操作暂不被支持
  28. #include "font.h"
  29. #include "glib.h"
  30. //#include "linkage.h"
  31. #include <stdarg.h>
  32. struct screen_info
  33. {
  34. int width, height; //屏幕大小
  35. int max_x, max_y; // 最大x、y字符数
  36. int x, y; //光标位置
  37. int char_size_x, char_size_y;
  38. uint *FB_address; //帧缓冲区首地址
  39. unsigned long FB_length; // 帧缓冲区长度(乘以4才是字节数)
  40. };
  41. extern unsigned char font_ascii[256][16]; //导出ascii字体的bitmap(8*16大小) ps:位于font.h中
  42. char buf[4096]; // vsprintf()的缓冲区
  43. /**
  44. * @brief 初始化printk的屏幕信息
  45. *
  46. * @param char_size_x 字符的列坐标
  47. * @param char_size_y 字符的行坐标
  48. */
  49. int printk_init(const int char_size_x, const int char_size_y);
  50. /**
  51. * @brief Set the printk pos object
  52. *
  53. * @param x 列坐标
  54. * @param y 行坐标
  55. */
  56. int set_printk_pos(const int x, const int y);
  57. /**
  58. * @brief 将字符串按照fmt和args中的内容进行格式化,然后保存到buf中
  59. *
  60. * @param buf 结果缓冲区
  61. * @param fmt 格式化字符串
  62. * @param args 内容
  63. * @return 最终字符串的长度
  64. */
  65. static int vsprintf(char *buf, const char *fmt, va_list args);
  66. /**
  67. * @brief 将数字按照指定的要求转换成对应的字符串(2~36进制)
  68. *
  69. * @param str 要返回的字符串
  70. * @param num 要打印的数值
  71. * @param base 基数
  72. * @param field_width 区域宽度
  73. * @param precision 精度
  74. * @param flags 标志位
  75. */
  76. static char *write_num(char *str,ul num, int base, int field_width, int precision, int flags);
  77. static char *write_float_point_num(char *str, double num, int field_width, int precision, int flags);
  78. /**
  79. * @brief 在屏幕上指定位置打印字符
  80. *
  81. * @param fb 帧缓存线性地址
  82. * @param Xsize 行分辨率
  83. * @param x 左上角列像素点位置
  84. * @param y 左上角行像素点位置
  85. * @param FRcolor 字体颜色
  86. * @param BKcolor 背景颜色
  87. * @param font 字符的bitmap
  88. */
  89. static void putchar(uint *fb, int Xsize, int x, int y, unsigned int FRcolor, unsigned int BKcolor, unsigned char font);
  90. /**
  91. * @brief 格式化打印字符串
  92. *
  93. * @param FRcolor 前景色
  94. * @param BKcolor 背景色
  95. * @param ... 格式化字符串
  96. */
  97. #define printk(...) printk_color(WHITE, BLACK, __VA_ARGS__)
  98. int printk_color(unsigned int FRcolor, unsigned int BKcolor, const char *fmt, ...);
  99. /**
  100. * @brief 滚动窗口(尚不支持向下滚动)
  101. *
  102. * @param direction 方向,向上滑动为true,否则为false
  103. * @param pixels 要滑动的像素数量
  104. * @param animation 是否包含滑动动画
  105. */
  106. int scroll(bool direction, int pixels, bool animation);
  107. /**
  108. * @brief 清屏
  109. *
  110. */
  111. int cls();
  112. /**
  113. * @brief 获取VBE帧缓存区的物理地址
  114. *
  115. */
  116. ul get_VBE_FB_phys_addr();
  117. /**
  118. * @brief 获取VBE帧缓冲区长度
  119. */
  120. ul get_VBE_FB_length();
  121. /**
  122. * @brief 设置pos变量中的VBE帧缓存区的线性地址
  123. * @param virt_addr VBE帧缓存区线性地址
  124. */
  125. void set_pos_VBE_FB_addr(uint* virt_addr);
  126. uint* get_pos_VBE_FB_addr();