-
-
Notifications
You must be signed in to change notification settings - Fork 1.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
MDEV-35785 innodb_log_file_mmap is not defined on 32-bit systems #3732
Conversation
|
4268d64 needs to be tested on the Debian CI by @ottok, because we have neither RISC-V nor LoongArch on https://buildbot.mariadb.org. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good that we are getting rid of some conditional paths HAVE_INNODB_MMAP
. Please check the backup source file too. I wonder if some backup test should have caught it,
I am in the process of testing with riscv64, but builds are very slow.. |
I converted this to a draft so it does not get accidentally merged before it has been finalized and rebased so the fixup commit is squashed into the first one. |
To summarize original situation in MariaDB 11.4.4:
|
I pointed this out a week ago, including some reasoning why we can’t support persistent memory on IBM System Z (s390x), or on any 32-bit architecture. |
I intend this to be merged as 2 commits, addressing separate issues in the same area. |
@@ -5,13 +5,13 @@ | |||
|
|||
--vertical_results | |||
--replace_regex /^\/\S+/PATH/ /\.\//PATH/ | |||
--replace_result 'resides in persistent memory or ' '' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alright, I see this unifies the variation in the help text:
--innodb-log-file-mmap
- Whether ib_logfile0 resides in persistent memory or
- should initially be memory-mapped
+ Whether ib_logfile0 should initially be memory-mapped
(Defaults to on; use --skip-innodb-log-file-mmap to disable.)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That’s right.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Typically places that have documentation to users show one version per software version. For example https://manpages.debian.org/unstable/mariadb-server-core/mariadbd.8.en.html has 3 versions for the 3 versions of MariaDB in Debian currently. Now it seems that the text will be different depending on architecture, so documentation should maybe have its own version per architecture.. obviously that would not make sense in any online collection of documentation, but for binaries outputting different help texts on different platforms it is less clear that may be the case
@@ -5,13 +5,13 @@ | |||
|
|||
--vertical_results | |||
--replace_regex /^\/\S+/PATH/ /\.\//PATH/ | |||
--replace_result 'resides in persistent memory or ' '' | |||
select VARIABLE_NAME, SESSION_VALUE, DEFAULT_VALUE, VARIABLE_SCOPE, VARIABLE_TYPE, VARIABLE_COMMENT, NUMERIC_MIN_VALUE, NUMERIC_MAX_VALUE, NUMERIC_BLOCK_SIZE, ENUM_VALUE_LIST, READ_ONLY, COMMAND_LINE_ARGUMENT from information_schema.system_variables | |||
where variable_name like 'innodb%' and | |||
variable_name not in ( | |||
'innodb_numa_interleave', # only available WITH_NUMA |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
..and this seems to be a collection of all variables that appear/disappear based on platform capabilities, even though the source code and dependency versions would be the same.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Typically places that have documentation to users show one version per software version. For example https://manpages.debian.org/unstable/mariadb-server-core/mariadbd.8.en.html has 3 versions for the 3 versions of MariaDB in Debian currently. Now it seems that the text will be different depending on architecture, so documentation should maybe have its own version per architecture.. obviously that would not make sense in any online collection of documentation, but for binaries outputting different help texts on different platforms it is less clear that may be the case
My riscv64 test build is still running.. so slow, and also host/queue seems to be busy |
Thanks for clarification. I misunderstood that "fixup" keyword as it (or "!fixup") is typically used as command words for The third commit is a merge commit, surely you don't want that? Maybe it came because Daniel updated with "Merge" instead of "Rebase" in the UI? (Wondering why GitHub even offers merge updates at all, or as primary option) |
I prefer to push this manually (first rebasing and force-pushing the source branch, then pushing it to the target branch as soon as the tests on the mandatory builders have completed), because it is not clear to me how and when the GitHub auto-merge is being triggered.
Would that be acceptable? |
Unfortunately the riscv64 build is now failing on unrelated error:
Trying to debug it.. |
|
Sound good.The text from --help and first sentence of wiki (https://mariadb.com/kb/en/innodb-system-variables/#innodb_log_file_mmap) should perhaps be identical so that they are aligned and later easy to keep aligned? |
@ottok Thank you for the testing. Did you have a chance to run this on LoongArch? This is about covering the following function: void pmem_persist(const void *buf, size_t size)
{
# if defined __riscv && __riscv_xlen == 64
__asm__ __volatile__("fence w,w" ::: "memory");
# elif defined __loongarch64
__asm__ __volatile__("dbar 0" ::: "memory");
# else
# error "Missing implementation; recompile with cmake -DWITH_INNODB_PMEM=OFF"
# endif
} According to https://godbolt.org,
https://loongson.github.io/LoongArch-Documentation/LoongArch-Vol1-EN#_dbar Hence, it seems to me that it is not strictly necessary to wait for the test results for RISC-V. Curiously, https://gcc.gnu.org/onlinedocs/gcc/RISC-V-Built-in-Functions.html does not mention any barrier instructions, only diff --git a/include/my_cpu.h b/include/my_cpu.h
index 003087dd94d..0aa3c748d27 100644
--- a/include/my_cpu.h
+++ b/include/my_cpu.h
@@ -104,6 +104,8 @@ static inline void MY_RELAX_CPU(void)
#elif defined __GNUC__ && (defined __arm__ || defined __aarch64__)
/* Mainly, prevent the compiler from optimizing away delay loops */
__asm__ __volatile__ ("":::"memory");
+#elif defined __riscv
+ __builtin_riscv_pause();
#else
int32 var, oldval = 0;
my_atomic_cas32_strong_explicit(&var, &oldval, 1, MY_MEMORY_ORDER_RELAXED, Curiously, |
No, I don't have access to a LoongArch machine other than as an official Debian builder. I will upload the contents of https://salsa.debian.org/mariadb-team/mariadb-server/-/commits/debian/latest to Debian now so results for the full build and Debian CI on all platforms should be available in a couple of days. Commit log of what uploaded to Debian is visible at https://salsa.debian.org/mariadb-team/mariadb-server/-/commits/debian/latest |
innodb_log_file_mmap: Use a constant documentation string that refers to persistent memory also when it is not available in the build. HAVE_INNODB_MMAP: Remove, and unconditionally enable this code. log_mmap(): On 32-bit systems, ensure that the size fits in 32 bits. log_t::resize_start(), log_t::resize_abort(): Only handle memory-mapping if HAVE_PMEM is defined. The generic memory-mapped interface is only for reading the log in recovery. Writable memory mappings are only for persistent memory, that is, Linux file systems with mount -o dax. Reviewed by: Debarun Banerjee, Otto Kekäläinen
Let us enable pmem_persist() on RISC-V and LoongArch, because those are available in the Debian CI. In commit 3f9f5ca these were initially disabled by default. According to the available documentation, these instructions are available in all ISA versions. On LoongArch there would also be __builtin_loongarch_dbar() that generates the same code.
d5867eb
to
4fc3a44
Compare
I filed #3752 for putting |
Follow-up:
|
Thank you, Otto! |
Description
HAVE_INNODB_MMAP
: Remove, and unconditionally enable this code.log_mmap()
: On 32-bit systems, ensure that the size fits in 32 bits.log_t::resize_start()
,log_t::resize_abort()
: Only handle memory-mapping ifHAVE_PMEM
is defined. The generic memory-mapped interface is only for reading the log in recovery. Writable memory mappings are only for persistent memory, that is, Linux file systems withmount -o dax
.Release Notes
The configuration parameter
innodb_log_file_mmap
will be available in all target platforms.How can this PR be tested?
This is covered by the regression test suite. The test
sys_vars.sysvars_innodb
will ensure that the parameter is present.I tested this by running the regression test suite on IA-32 and AMD64 in my local development environment.
Basing the PR against the correct MariaDB version
main
branch.PR quality check