On 9 June 2014 15:52, Andrew Jones <drjones@xxxxxxxxxx> wrote: > On Mon, Jun 09, 2014 at 02:34:03PM +0200, Christoffer Dall wrote: >> On Mon, Jun 09, 2014 at 01:39:06PM +0200, Andrew Jones wrote: >> > On Mon, Jun 09, 2014 at 11:54:48AM +0200, Andrew Jones wrote: >> > > On Mon, Jun 09, 2014 at 11:08:32AM +0200, Christoffer Dall wrote: >> > > > On Mon, Jun 09, 2014 at 10:23:27AM +0200, Andrew Jones wrote: >> > > > > On Fri, Jun 06, 2014 at 08:39:09PM +0200, Christoffer Dall wrote: >> > > > > > On Thu, Apr 10, 2014 at 06:56:51PM +0200, Andrew Jones wrote: >> > > > > > > Architecture neutral code may need to call low-level io accessors, >> > > > > > > or use spinlocks. Create a generic io.h to ensure those accessors >> > > > > > > are defined, and a generic spinlock.h that complains when included, >> > > > > > > as we can't write a generic spinlock. These files can be overridden >> > > > > > > or extended by architecture specific versions placed in >> > > > > > > lib/$ARCH/asm/. >> > > > > > > >> > > > > > > Signed-off-by: Andrew Jones <drjones@xxxxxxxxxx> >> > > > > > > --- >> > > > > > > v4: introduce lib/asm symlink to get rid of #ifdef __arm__, >> > > > > > > add spinlock.h too >> > > > > > > v3: wrt to io.h (was libio.[ch]) only >> > > > > > > - get rid of CONFIG_64BIT, replace with asserts >> > > > > > > - get rid of {read,write}_len() [libio.c] >> > > > > > > - fix bad *64_to_cpu macros >> > > > > > > --- >> > > > > > > .gitignore | 1 + >> > > > > > > Makefile | 6 +- >> > > > > > > configure | 11 ++++ >> > > > > > > lib/asm-generic/io.h | 154 +++++++++++++++++++++++++++++++++++++++++++++ >> > > > > > > lib/asm-generic/spinlock.h | 4 ++ >> > > > > > > 5 files changed, 173 insertions(+), 3 deletions(-) >> > > > > > > create mode 100644 lib/asm-generic/io.h >> > > > > > > create mode 100644 lib/asm-generic/spinlock.h >> > > > > > > >> > > > > > > diff --git a/.gitignore b/.gitignore >> > > > > > > index 775d0dfd8263e..e21939a8771e9 100644 >> > > > > > > --- a/.gitignore >> > > > > > > +++ b/.gitignore >> > > > > > > @@ -9,6 +9,7 @@ patches >> > > > > > > .stgit-* >> > > > > > > cscope.* >> > > > > > > *.swp >> > > > > > > +/lib/asm >> > > > > > > /config.mak >> > > > > > > /*-run >> > > > > > > /test.log >> > > > > > > diff --git a/Makefile b/Makefile >> > > > > > > index fba58e36f272f..51cacdac00615 100644 >> > > > > > > --- a/Makefile >> > > > > > > +++ b/Makefile >> > > > > > > @@ -76,11 +76,11 @@ libfdt_clean: >> > > > > > > $(LIBFDT_objdir)/.*.d >> > > > > > > >> > > > > > > distclean: clean libfdt_clean >> > > > > > > - $(RM) config.mak $(TEST_DIR)-run test.log msr.out cscope.* >> > > > > > > + $(RM) lib/asm config.mak $(TEST_DIR)-run test.log msr.out cscope.* >> > > > > > > >> > > > > > > -cscope: common_dirs = lib lib/libfdt >> > > > > > > +cscope: common_dirs = lib lib/libfdt lib/asm lib/asm-generic >> > > > > > > cscope: >> > > > > > > $(RM) ./cscope.* >> > > > > > > - find $(TEST_DIR) lib/$(TEST_DIR) $(common_dirs) -maxdepth 1 \ >> > > > > > > + find -L $(TEST_DIR) lib/$(TEST_DIR) $(common_dirs) -maxdepth 1 \ >> > > > > > > -name '*.[chsS]' -print | sed 's,^\./,,' > ./cscope.files >> > > > > > > cscope -bk >> > > > > > > diff --git a/configure b/configure >> > > > > > > index 6cfc64943f6e6..8a81bf92e27b7 100755 >> > > > > > > --- a/configure >> > > > > > > +++ b/configure >> > > > > > > @@ -95,6 +95,17 @@ if [ $exit -eq 0 ]; then >> > > > > > > fi >> > > > > > > rm -f lib_test.c >> > > > > > > >> > > > > > > +# link lib/asm for the architecture >> > > > > > > +rm -f lib/asm >> > > > > > > +asm=asm-generic >> > > > > > > +if [ -d lib/$arch/asm ]; then >> > > > > > > + asm=$arch/asm >> > > > > > > +elif [ -d lib/$testdir/asm ]; then >> > > > > > > + asm=$testdir/asm >> > > > > > >> > > > > > why do you need this elif? can you not make sure arch is always set? >> > > > > >> > > > > arch is always set, but there's a chance some arch may not add it's own >> > > > > lib/$arch dir. It's a pretty small chance... but the elif shouldn't hurt. >> > > > > >> > > > If we don't have any code that uses this scheme now then let's now have >> > > > Makefile rules that encourages non-standard behavior (unless I'm missing >> > > > the point and this provides a 'feature' for specific archs or something >> > > > like that). >> > > > >> > > >> > > It would be something of a feature for some imaginary arch. However, as >> > > that imaginary arch doesn't exist right now, then I'm fine removing it. >> > > Whoever makes the imaginary arch a reality can bring it back. >> > > >> > >> > Oh wait, it's actually not imaginary (just unused). x86 is an example of >> > such a testdir that doesn't == arch. So, if either i386 or x86_64 wanted >> > to use lib/asm, then they need this elif. >> > >> ah, ok. I'll shut up then. > > Before you go completely silent on it, how about an Ack? > ack Acked-by: Christoffer Dall <christoffer.dall@xxxxxxxxxx> -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html