@@ -64,7 +64,7 @@ static int do_font_size(struct cmd_tbl *cmdtp, int flag, int argc,
if (uclass_first_device_err(UCLASS_VIDEO_CONSOLE, &dev))
return CMD_RET_FAILURE;
- ret = vidconsole_get_font_size(dev, &font_name, &size);
+ ret = vidconsole_get_font_size(dev, NULL, &font_name, &size);
if (ret) {
printf("Failed (error %d)\n", ret);
return CMD_RET_FAILURE;
@@ -319,7 +319,8 @@ int console_probe(struct udevice *dev)
return 0;
}
-const char *console_simple_get_font_size(struct udevice *dev, uint *sizep)
+const char *console_simple_get_font_size(struct udevice *dev, void *ctx,
+ uint *sizep)
{
struct console_simple_priv *priv = dev_get_priv(dev);
@@ -1234,9 +1234,10 @@ static int truetype_get_cursor_info(struct udevice *dev, void *vctx)
return 0;
}
-const char *console_truetype_get_font_size(struct udevice *dev, uint *sizep)
+const char *console_truetype_get_font_size(struct udevice *dev, void *vctx,
+ uint *sizep)
{
- struct console_tt_ctx *ctx = vidconsole_ctx(dev);
+ struct console_tt_ctx *ctx = vctx;
if (ctx->cur_fontdata) {
/* Using fixed font */
@@ -636,14 +636,17 @@ int vidconsole_get_font(struct udevice *dev, int seq,
return ops->get_font(dev, seq, info);
}
-int vidconsole_get_font_size(struct udevice *dev, const char **name, uint *sizep)
+int vidconsole_get_font_size(struct udevice *dev, void *ctx, const char **name,
+ uint *sizep)
{
struct vidconsole_ops *ops = vidconsole_get_ops(dev);
+ if (!ctx)
+ ctx = vidconsole_ctx(dev);
if (!ops->get_font_size)
return -ENOSYS;
- *name = ops->get_font_size(dev, sizep);
+ *name = ops->get_font_size(dev, ctx, sizep);
return 0;
}
@@ -170,7 +170,8 @@ int console_probe(struct udevice *dev);
* Internal function to be used in as ops.
* See details in video_console.h get_font_size function
**/
-const char *console_simple_get_font_size(struct udevice *dev, uint *sizep);
+const char *console_simple_get_font_size(struct udevice *dev, void *ctx,
+ uint *sizep);
/**
* Internal function to be used in as ops.
@@ -325,10 +325,12 @@ struct vidconsole_ops {
* get_font_size() - get the current font name and size
*
* @dev: vidconsole device
+ * @ctx: vidconsole context to use (cannot be NULL)
* @sizep: Place to put the font size (nominal height in pixels)
* Returns: Current font name
*/
- const char *(*get_font_size)(struct udevice *dev, uint *sizep);
+ const char *(*get_font_size)(struct udevice *dev, void *ctx,
+ uint *sizep);
/**
* select_font() - Select a particular font by name / size
@@ -842,11 +844,13 @@ void vidconsole_list_fonts(struct udevice *dev);
* vidconsole_get_font_size() - get the current font name and size
*
* @dev: vidconsole device
+ * @ctx: vidconsole context to use (NULL to use default)
* @sizep: Place to put the font size (nominal height in pixels)
* @name: pointer to font name, a placeholder for result
* Return: 0 if OK, -ENOSYS if not implemented in driver
*/
-int vidconsole_get_font_size(struct udevice *dev, const char **name, uint *sizep);
+int vidconsole_get_font_size(struct udevice *dev, void *ctx, const char **name,
+ uint *sizep);
/**
* vidconsole_set_quiet() - Select whether the console should output stdio
@@ -43,7 +43,7 @@ static int font_test_base(struct unit_test_state *uts)
ut_assert_console_end();
- ut_assertok(vidconsole_get_font_size(dev, &name, &size));
+ ut_assertok(vidconsole_get_font_size(dev, NULL, &name, &size));
if (IS_ENABLED(CONFIG_CONSOLE_TRUETYPE_ANKACODER))
ut_asserteq_str("ankacoder_c75_r", name);
else if (IS_ENABLED(CONFIG_CONSOLE_TRUETYPE_NIMBUS))
@@ -71,7 +71,7 @@ static int font_test_base(struct unit_test_state *uts)
ut_assertok(ret);
ut_assert_console_end();
- ut_assertok(vidconsole_get_font_size(dev, &name, &size));
+ ut_assertok(vidconsole_get_font_size(dev, NULL, &name, &size));
ut_asserteq_str("cantoraone_regular", name);
ut_asserteq(40, size);
ut_assertok(ut_check_console_end(uts));
@@ -90,7 +90,7 @@ static int font_test_base(struct unit_test_state *uts)
ut_assertok(run_command("font select", 0));
ut_assertok(ut_check_console_end(uts));
- ut_assertok(vidconsole_get_font_size(dev, &name, &size));
+ ut_assertok(vidconsole_get_font_size(dev, NULL, &name, &size));
ut_asserteq_str("nimbus_sans_l_regular", name);
ut_asserteq(CONFIG_CONSOLE_TRUETYPE_SIZE, size);