| /* |
| * This file is part of the coreboot project. |
| * |
| * Copyright 2015 Google Inc. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; version 2 of the License. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License |
| * along with this program; if not, write to the Free Software |
| * Foundation, Inc. |
| */ |
| #ifndef ASSETS_H |
| #define ASSETS_H |
| |
| #include <region.h> |
| |
| /* An asset represents data used to boot the system. It can be found within |
| * CBFS or some other mechanism. While CBFS can be a source of an asset, note |
| * that using the asset API implies querying of other sources. */ |
| |
| enum asset_type { |
| ASSET_UNKNOWN, |
| ASSET_VERSTAGE, |
| ASSET_ROMSTAGE, |
| ASSET_RAMSTAGE, |
| ASSET_REFCODE, |
| ASSET_PAYLOAD, |
| ASSET_BL31, |
| ASSET_BL32, |
| }; |
| |
| struct asset { |
| enum asset_type type; |
| const char *name; |
| struct region_device rdev; |
| }; |
| |
| static inline const char *asset_name(const struct asset *asset) |
| { |
| return asset->name; |
| } |
| |
| static inline enum asset_type asset_type(const struct asset *asset) |
| { |
| return asset->type; |
| } |
| |
| static struct region_device *asset_rdev(struct asset *asset) |
| { |
| return &asset->rdev; |
| } |
| |
| static inline size_t asset_size(const struct asset *asset) |
| { |
| return region_device_sz(&asset->rdev); |
| } |
| |
| /* Returns NULL on error. */ |
| static inline void *asset_mmap(const struct asset *asset) |
| { |
| return rdev_mmap_full(&asset->rdev); |
| } |
| |
| #define ASSET_INIT(type_, name_) \ |
| { \ |
| .type = (type_), \ |
| .name = (name_), \ |
| } |
| |
| /* Locate the asset as described by the parameter. It will query all known |
| * asset providers. Returns 0 on success. < 0 on error. */ |
| int asset_locate(struct asset *asset); |
| |
| struct asset_provider { |
| const char *name; |
| /* Determines if the provider is the active one. If so returns 1 else 0 |
| * or < 0 on error. */ |
| int (*is_active)(struct asset *asset); |
| /* Returns < 0 on error or 0 on success. This function locates |
| * the rdev representing the file data associated with the passed in |
| * prog. */ |
| int (*locate)(struct asset *asset); |
| }; |
| |
| #endif /* ASSETS_H */ |