I added a new system service (builds as part of services.jar) and everything works fine except when I want to make calls from that service to a .jar library (extender.jar sits in /system/framework). The calling service gets a broken pipe error and in logcat I find the following:
E/AndroidRuntime(14629): *** FATAL EXCEPTION IN SYSTEM PROCESS: Binder_B
E/AndroidRuntime(14629): java.lang.NoClassDefFoundError: Failed resolution of: Lcom/android/server/extender/TestExtender;
E/AndroidRuntime(14629): at com.android.server.newservice.NewService.onTransact(NewService.java:79)
E/AndroidRuntime(14629): at android.os.Binder.execTransact(Binder.java:446)
E/AndroidRuntime(14629): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.android.server.extender.TestExtender" on path: DexPathList[[zip file "/system/framework/services.jar", zip file "/system/framework/ethernet-service.jar", zip file "/system/framework/wifi-service.jar"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
E/AndroidRuntime(14629): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
E/AndroidRuntime(14629): at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
E/AndroidRuntime(14629): at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
E/AndroidRuntime(14629): ... 2 more
E/AndroidRuntime(14629): Suppressed: java.lang.ClassNotFoundException: Didn't find class "com.android.server.extender.TestExtender" on path: DexPathList[[directory "."],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
E/AndroidRuntime(14629): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
E/AndroidRuntime(14629): at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
E/AndroidRuntime(14629): at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
E/AndroidRuntime(14629): ... 3 more
E/AndroidRuntime(14629): Suppressed: java.lang.ClassNotFoundException: com.android.server.extender.TestExtender
E/AndroidRuntime(14629): at java.lang.Class.classForName(Native Method)
E/AndroidRuntime(14629): at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
E/AndroidRuntime(14629): at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
E/AndroidRuntime(14629): at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
E/AndroidRuntime(14629): ... 4 more
E/AndroidRuntime(14629): Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available