10-14-2018, 03:55 PM | #31 |
Linux User
Posts: 2,281
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
I'm trying to use the --refresh option, any way to do a full screen refresh by default (after restoring a previously saved framebuffer state)?
For some reason I end up getting a Segmentation fault on my H2O. Code:
# fbink --refresh top=0,left=0,width=1080,height=1429 [FBInk] Clock tick frequency appears to be 100 Hz [FBInk] Variable fb info: 1080x1440, 32bpp @ rotation: 1 (Clockwise, 90°) [FBInk] Enabled Kobo viewport insanity (1080x1440 -> 1080x1429), top-left corner is @ (0, 11) [FBInk] Fontsize set to 24x24 (IBM base glyph size: 8x8) [FBInk] Line length: 45 cols, Page size: 59 rows [FBInk] Horizontal fit is perfect! [FBInk] Vertical fit isn't perfect, shitfting rows by 7 pixels to the bottom [FBInk] Fixed fb info: ID is "mxc_epdc_fb", length of fb mem: 6684672 bytes & line length: 4352 bytes [FBInk] Pen colors set to #000000 for the foreground and #FFFFFF for the background Refreshing the screen from top=0, left=0 for width=1080, height=1429 with waveform mode (null) Segmentation fault |
10-14-2018, 11:02 PM | #32 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
At a quick glance, I appear to have completely bungled the input validation of the refresh flag .
You're missing the wfm suboption, which currently should have caused fbink to abort with a relevant warning, but that check is busted, and the final sanity check has its logic inverted, so, double fail on my part here ;p. TL;DR: Try with wfm=auto, and I'll fix that check when I get back to my computer . |
Advert | |
|
10-15-2018, 12:54 AM | #33 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
There, master should no longer segfault when the wfm suboption is missing, providing a slightly more useful error message in the process .
(Also, verbose logging when the option passed doesn't get recognized and falls back to AUTO). Thanks! EDIT: Random comment about your test command: if you want to mimic nickel, you want top=11,left=0,width=1080,height=1429, if not, top=0,left=0,width=1080,height=1440 (otherwise you'd be skipping the visible bottom 11 pixels) . (The options are passed as-is to the ioctl, so the purported viewport trickery isn't actually done for a "manual" refresh call ). EDIT²: For anyone else reading this, that's a quirk specific to the H2O . Last edited by NiLuJe; 10-15-2018 at 01:00 AM. |
10-15-2018, 05:40 AM | #34 |
Linux User
Posts: 2,281
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
I keep clicking that [karma] button but the forum software won't let me.
Thanks! |
10-23-2018, 03:08 PM | #35 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
PSA: I'm expecting mild annoyances related to Mobius and/or rotation on the Forma, which *hopefully* won't affect KFMon too badly, but, still, I'd let things sit for a few days if you're not confident in your Kobo-fu .
I do have a few ideas of what might go wrong and how, and what I can do about it, but I kind of have to see how exactly stuff breaks (if it does) first . FWIW, I do intend to get a Forma, so I'll eventually suffer those very same issues myself, but a student's income (or lack thereof ;p) being what it is, this'll probably have to wait for the winter break . |
Advert | |
|
10-24-2018, 02:12 PM | #36 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
Ideally, I'd only need a kind soul with a Forma (and shell access) to run a test command (say, fbink -mv "Hi") in all four orientations, and post the full output each time .
(While mentioning where on the screen the message appeared, which, for the record, should be the middle of the top row). The cherry on top would be doing the input test from this thread, too . Last edited by NiLuJe; 10-25-2018 at 11:59 PM. |
10-27-2018, 05:45 PM | #37 |
Linux User
Posts: 2,281
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
This seems to work well most of the time, however when switching to USB connection mode, fbink suddenly starts showing things without applying the offset anymore. Until you disconnect from PC then it is back to normal. So I see things (like the miniclock from the other thread) shifting up by 11px while connected to USB.
|
10-27-2018, 06:26 PM | #38 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
@frostschutz: Ah, right, the device identification currently relies on Nickel's version tag file (/mnt/onboard/.kobo/version), which is obviously unavailable if onboard is not mounted.
I'd really like to avoid having to do the hwconfig dance myself, because getting the PCB IDs right is going to be extremely unfun... |
10-27-2018, 06:46 PM | #39 | |
Linux User
Posts: 2,281
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
Quote:
another thing I do is steal nickel's own environment /proc/$(pidof nickel)/environ and sometimes you're forced to do that (some versions of pickel segfault without those env vars set) while on topic of subsequent calls, it would be cool if fbink could remember the last line it printed and print the next line on the next call. well, I was wondering how to keep track of this myself, so I don't just overwrite the previous message on every call. so maybe there's already another way sometimes its intentional to overwrite text (like updating the clock every minute) sometimes you just want to print more stuff like a text terminal of sorts Last edited by frostschutz; 10-27-2018 at 06:53 PM. |
|
10-27-2018, 07:36 PM | #40 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
@frostschutz:
Turns out doing it with NTX's HWConfig thingy is less gnarly than I thought (plus, @pazos did most of the heavy lifting for the Cervantes port anyway ), so that's coming along nicely (as a fallback, because the distinction between some specific devices is harder to make... and of course, among those is one that's already crappy to handle right between the two versions, namely, the H2O² -_-"). As for your line issue, yep, you have a couple of choices: the -L flag usurps the process exit code to set it to the number of lines printed, while the -l flag does the same the old-fashioned way, by outputting it to stdout (which means it enforces the extra-silent mode of operation). Yes, I had weird constraints on Kindle where non-zero return codes where a big no-no, hence the crappy workaround . EDIT: See this for one example of how I'm using that in shell. It's of course much easier in C, because fbink_print just returns that number, plain and simple, you just have to check for errors, which are always negative . Last edited by NiLuJe; 10-27-2018 at 07:39 PM. |
10-27-2018, 08:19 PM | #41 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
@frostschutz:
Okay, this one should ID everything properly, even with onboard unmounted . Last edited by NiLuJe; 11-02-2018 at 04:27 PM. Reason: 1.8.0 is now out! :) |
11-02-2018, 04:30 PM | #42 |
BLAM!
Posts: 13,499
Karma: 26047188
Join Date: Jun 2010
Location: Paris, France
Device: Kindle 2i, 3g, 4, 5w, PW, PW2, PW5; Kobo H2O, Forma, Elipsa, Sage, C2E
|
Released v1.8.0!
A fairly juicy release, since it introduces OpenType/TrueType rendering, thanks to @sherman's work! It also properly detects the new Forma . And as mentioned earlier, it now properly detects Kobo devices even when onboard is unavailable. It also makes an attempt at handling the native boot rotation properly... This is a bit tricky, and means I *may* have broken 16bpp rotation handling on a few devices (mainly, the H2O²r1, possibly r2 too). If you're still running an old FW that runs in a 16bpp modeset, and stuff is badly rotated after this update, give me a shout . |
11-02-2018, 05:27 PM | #43 |
Linux User
Posts: 2,281
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
Thanks for the update. Testing the TrueTypes as soon as I can
|
11-02-2018, 05:39 PM | #44 |
Guru
Posts: 869
Karma: 2676800
Join Date: Sep 2008
Location: Taranaki - NZ
Device: Kobo Aura H2O, Kobo Forma
|
Hi
Just a couple of notes for those using the new OpenType/TrueType functionality, as there are some differences compared to the traditional FBInk printing methods. Unicode linebreaking is used for wrapping lines. This means, that when printing OT/TT, the line will try to avoid breaking mid-word. OT support uses margins, instead of cells, for positioning. That means you can set a printable area with top, bottom, left and right margins. The margins are specified in pixels, so at the moment API users may want to use the fbink_get_state() function to get the current screen resolution. You can also align text WITHIN the printable area defined by the margins. This allows for both horizontal and vertical alignment. With the combination of alignment and margins, some creative positioning can be obtained... Bold and Italics support is enabled via a simple markdown syntax (eg *italic*, **bold**, ***bold italic***). This is a very simplistic parser, so I would advise doing anything to complicated with it. EDIT: and it will abort if you don't have the appropriate bold and/or italic font loaded, so beware! Other than that, have fun! Huge thanks to NiLuJe for letting me play in the FBInk sandbox, and for graciously polishing my code. (Also, if NiLuJe ever offers you a copy of Bookerly, run far far away. It is an evil version of the font, which made my code blow up...) Last edited by sherman; 11-02-2018 at 05:42 PM. |
11-02-2018, 05:55 PM | #45 |
Linux User
Posts: 2,281
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
found some bugs:
- font size 256pt is understood as 0pt (integer overflow)? - characters missing when using UTF-8 (string length miscalculation)? xyzäöü1234567890 leaves out 890 presumably because 3 umlauts. is worse for CJK characters presumably because 3-4-byte chars instead of 2-byte-chars. Otherwise great! I will try to find a way to use this in my FlashCard mod. |
|
Similar Threads | ||||
Thread | Thread Starter | Forum | Replies | Last Post |
Aura HD Small tool for filling book library in Kobo Aura | Paxerus | Kobo Developer's Corner | 2 | 12-31-2013 08:05 PM |
Small print | Broadback | Conversion | 12 | 12-12-2011 03:31 PM |
Small Tool to change book order (PRS-x50) | goaspy | Sony Reader | 113 | 10-14-2011 04:28 PM |
small print | breezeman | Introduce Yourself | 13 | 07-03-2011 10:02 AM |