-
Notifications
You must be signed in to change notification settings - Fork 9
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
New Smesher API #145
New Smesher API #145
Changes from 5 commits
d391501
8450d9c
560a13e
2ef8fb2
2dbd0d3
81ae866
1e18c71
4d79a9b
5297d99
7e631f5
eb70040
f54df33
3679ef8
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,14 +4,19 @@ option go_package = "github.com/spacemeshos/api/release/go/spacemesh/v1"; | |
import "spacemesh/v1/types.proto"; | ||
import "google/rpc/status.proto"; | ||
|
||
message IsSmeshingResponse { | ||
bool is_smeshing = 1; | ||
message SmeshingStatusResponse { | ||
avive marked this conversation as resolved.
Show resolved
Hide resolved
|
||
enum SmeshingStatus { | ||
lrettig marked this conversation as resolved.
Show resolved
Hide resolved
|
||
SMESHING_STATUS_UNSPECIFIED = 0; // Lane's favorite impossible value | ||
SMESHING_STATUS_IDLE = 1; | ||
avive marked this conversation as resolved.
Show resolved
Hide resolved
|
||
SMESHING_STATUS_CREATING_POST_DATA = 2; | ||
SMESHING_STATUS_ACTIVE = 3; | ||
} | ||
SmeshingStatus status = 1; | ||
} | ||
|
||
message StartSmeshingRequest { | ||
AccountId coinbase = 1; | ||
string data_dir = 2; | ||
SimpleInt commitment_size = 3; | ||
PostInitOpts opts = 2; | ||
} | ||
|
||
message StartSmeshingResponse { | ||
|
@@ -42,13 +47,6 @@ message SetMinGasResponse { | |
google.rpc.Status status = 1; | ||
} | ||
|
||
message CreatePostDataResponse { | ||
google.rpc.Status status = 1; | ||
} | ||
|
||
message StopPostDataCreationSessionResponse { | ||
google.rpc.Status status = 1; | ||
} | ||
|
||
message SmesherIDResponse { | ||
AccountId account_id = 1; | ||
|
@@ -77,57 +75,37 @@ enum ComputeApiClass { | |
COMPUTE_API_CLASS_VULKAN = 3; | ||
} | ||
|
||
// Basic post data. Used for users to provide requested post data and by | ||
// other messages which contain post data. | ||
message PostData { | ||
string path = 1; // User provided path to create the post data files at | ||
uint64 data_size = 2; // Requested post data size | ||
bool append = 3; // Append to existing files if they exist. Otherwise overwrite. | ||
bool throttle = 4; // Throttle down setup phase computations while user is interactive on system | ||
uint32 provider_id = 5; // A PostProvider id | ||
// Post init options. Used to define the requested options and by | ||
// other messages which contain the options. | ||
message PostInitOpts { | ||
string data_dir = 1; // User provided path to create the post data files at | ||
uint32 num_units = 2; // Number of PoST data commitment units to generate | ||
uint32 num_files = 3; // Number of files to equally distribute the labels among | ||
uint32 compute_provider_id = 4; // A PostProvider id | ||
bool throttle = 5; // Throttle down setup phase computations while user is interactive on system | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Couldn't this be an int, to allow more fine-tuned throttling? E.g., max CPU percentage? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's referring to the utilization of GPU cores, not CPU time. The API complies with the internal API of There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. For the release of gpu-post lib for post it is indeed a boolean and it is not going to change to an int. Let's consider this feature for next release. We need to finalize and ship and we shouldn't change features so late in the cycle. |
||
} | ||
|
||
message CreatePostDataRequest { | ||
PostData data = 1; | ||
PostInitOpts opts = 1; | ||
} | ||
|
||
// Param passed to methods to indicate a request to delete data files | ||
message StopSmeshingRequest { | ||
bool delete_files = 1; | ||
} | ||
|
||
message StopPostDataCreationSessionRequest { | ||
bool delete_files = 1; | ||
message PostComputeProvidersRequest { | ||
bool benchmark = 1; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What does benchmark mean here? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Request to run a short benchmarking session for each provider, so that the Documentation is still missing and will be complete soon. |
||
} | ||
|
||
// Proof of space data status | ||
message PostStatus { | ||
PostData post_data = 1; // basic post data (set previously by the user) | ||
enum FilesStatus { | ||
FILES_STATUS_UNSPECIFIED = 0; // Lane's favorite impossible value | ||
FILES_STATUS_NOT_FOUND = 1; // Expected data files do not exist | ||
FILES_STATUS_PARTIAL = 2; // Some files exist and init can be continued (and may be in progress) | ||
FILES_STATUS_COMPLETE = 3; // Expected data files are available and verified | ||
} | ||
FilesStatus files_status = 2; | ||
bool init_in_progress = 3; // True if init process is currently in progress | ||
uint64 bytes_written = 4; // Bytes written to the data files (actual total files sizes) | ||
string error_message = 5; // Last init process error message | ||
enum ErrorType { | ||
ERROR_TYPE_UNSPECIFIED = 0; // Lane's favorite imposible value | ||
ERROR_TYPE_FILE_NOT_FOUND = 1; // All expected post data files not found in expected path | ||
ERROR_TYPE_READ_ERROR = 2; // Failure to read from a data file | ||
ERROR_TYPE_WRITE_ERROR = 3; // Failure to write to a data file | ||
} | ||
ErrorType error_type = 6; | ||
} | ||
|
||
message PostStatusResponse { | ||
PostStatus status = 1; | ||
// Proof of space data creation session status | ||
message SessionStatus { | ||
PostInitOpts session_opts = 1; // The current session init options | ||
uint64 num_labels_written = 2; // Number of labels written to the data files | ||
} | ||
|
||
message PostDataCreationProgressStreamResponse { | ||
PostStatus status = 1; | ||
SessionStatus status = 1; | ||
} | ||
|
||
message EstimatedRewardsRequest {} | ||
|
@@ -138,6 +116,13 @@ message EstimatedRewardsRequest {} | |
message EstimatedRewardsResponse { | ||
// The amount of the total estimated reward in the next upcoming epoch | ||
Amount amount = 1; | ||
// The commitment size that this estimated reward corresponds to (part of global config) | ||
uint64 data_size = 2; | ||
// The number of PoST data commitment units that this estimated reward corresponds to (part of global config) | ||
uint32 num_units = 2; | ||
} | ||
|
||
message ConfigResponse { | ||
uint32 bits_per_label = 1; | ||
uint64 labels_per_unit = 2; | ||
uint32 min_num_units = 3; | ||
uint32 max_num_units = 4; | ||
} |
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.
What does this mean? is it a typo?
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.
It means that if the data is incomplete or missing, data creation session will occur and must complete before smeshing can start. Feel free to fix my english, but I plan to revise all the documentation anyway.