diff options
| author | 2023-03-28 17:06:24 +0000 | |
|---|---|---|
| committer | 2023-03-28 17:06:24 +0000 | |
| commit | 5fdd417397c36aa725c64e64477db43bc604c0cb (patch) | |
| tree | d5c6a5cf94a7800a0fb35281b9526b8b6ab683d9 | |
| parent | e63277b276d34156701f9dceb740bc8e8dfb001c (diff) | |
| parent | 53522d89c172898ae4ea07533dbc43666cbb1924 (diff) | |
Merge "Handle invalid data during job loading." into sc-v2-dev
| -rw-r--r-- | apex/jobscheduler/service/java/com/android/server/job/JobStore.java | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/apex/jobscheduler/service/java/com/android/server/job/JobStore.java b/apex/jobscheduler/service/java/com/android/server/job/JobStore.java index 7a2840709d15..7799c2ff04f6 100644 --- a/apex/jobscheduler/service/java/com/android/server/job/JobStore.java +++ b/apex/jobscheduler/service/java/com/android/server/job/JobStore.java @@ -733,6 +733,10 @@ public final class JobStore { } } catch (XmlPullParserException | IOException e) { Slog.wtf(TAG, "Error jobstore xml.", e); + } catch (Exception e) { + // Crashing at this point would result in a boot loop, so live with a general + // Exception for system stability's sake. + Slog.wtf(TAG, "Unexpected exception", e); } finally { if (mPersistInfo.countAllJobsLoaded < 0) { // Only set them once. mPersistInfo.countAllJobsLoaded = numJobs; @@ -869,6 +873,9 @@ public final class JobStore { } catch (IOException e) { Slog.d(TAG, "Error I/O Exception.", e); return null; + } catch (IllegalArgumentException e) { + Slog.e(TAG, "Constraints contained invalid data", e); + return null; } parser.next(); // Consume </constraints> @@ -965,8 +972,14 @@ public final class JobStore { return null; } - PersistableBundle extras = PersistableBundle.restoreFromXml(parser); - jobBuilder.setExtras(extras); + final PersistableBundle extras; + try { + extras = PersistableBundle.restoreFromXml(parser); + jobBuilder.setExtras(extras); + } catch (IllegalArgumentException e) { + Slog.e(TAG, "Persisted extras contained invalid data", e); + return null; + } parser.nextTag(); // Consume </extras> final JobInfo builtJob; |